70 return (pos == 0 || pos == 5) &&
name.find(
"::",
name.rfind(
">")) == std::string::npos;
89 obj,
const_cast<char*
>(
meth),
const_cast<char*
>(
"O"),
arg1);
103 if (idx >=
size || (idx < 0 && idx < -
size)) {
122 if ((step > 0 && stop <= start) || (step < 0 && start <= stop))
125 if (start < 0) start = 0;
129 stop = step > 0 ? std::min(
nlen, stop) : (stop >= 0 ? stop : -1);
220#if PY_VERSION_HEX < 0x03040000
221#define PyObject_LengthHint _PyObject_LengthHint
233struct CountedItemGetter :
public ItemGetter {
238struct TupleItemGetter :
public CountedItemGetter {
239 using CountedItemGetter::CountedItemGetter;
252struct ListItemGetter :
public CountedItemGetter {
253 using CountedItemGetter::CountedItemGetter;
266struct SequenceItemGetter :
public CountedItemGetter {
267 using CountedItemGetter::CountedItemGetter;
279struct IterItemGetter :
public ItemGetter {
280 using ItemGetter::ItemGetter;
285static ItemGetter* GetGetter(
PyObject* args)
288 ItemGetter*
getter =
nullptr;
306 getter =
new SequenceItemGetter(
fi);
310 getter =
new IterItemGetter{iter};
332namespace __cppyy_internal {
339 ptr_iterator(T *c, T *e) : cur(c), end(e) {}
341 T &operator*() const { return *cur; }
342 ptr_iterator &operator++()
347 bool operator==(const ptr_iterator &other) const { return cur == other.cur; }
348 bool operator!=(const ptr_iterator &other) const { return !(*this == other); }
352ptr_iterator<T> make_iter(T *begin, T *end)
357} // namespace __cppyy_internal
359// Note: for const span<T>, T is const-qualified here
361auto __cppyy_internal_begin(T &s) noexcept
363 return __cppyy_internal::make_iter(s.data(), s.data() + s.size());
366// Note: for const span<T>, T is const-qualified here
368auto __cppyy_internal_end(T &s) noexcept
370 // end iterator = begin iterator with cur == end
371 return __cppyy_internal::make_iter(s.data() + s.size(), s.data() + s.size());
386 "'__cppyy_internal_begin' for std::span pythonization");
401 "'__cppyy_internal_end' for std::span pythonization");
459 for (
int i = 0; ; ++i) {
536 ItemGetter*
getter = GetGetter(args);
588 ItemGetter*
getter = GetGetter(args);
668 if (!
vi)
return nullptr;
671 vi->ii_container =
v;
704 vi->vi_converter =
nullptr;
706 if (value_type.back() !=
'*')
715 vi->vi_converter =
nullptr;
727 vi->vi_data =
nullptr;
729 vi->vi_converter =
nullptr;
747 if (!
self->GetObject()) {
786 "require object of type std::vector<bool>, but %s given",
791 if (!
self->GetObject()) {
826 std::vector<bool>*
vb = (std::vector<bool>*)
self->GetObject();
840 "require object of type std::vector<bool>, but %s given",
845 if (!
self->GetObject()) {
862 std::vector<bool>*
vb = (std::vector<bool>*)
self->GetObject();
970#if PY_VERSION_HEX < 0x03000000
1048 IterItemGetter
getter{iter};
1146 if (!
ii)
return nullptr;
1149 ii->ii_container =
c;
1202 else if ((
int)idx == 1)
1235#if PY_VERSION_HEX >= 0x03000000
1259#define CPPYY_IMPL_STRING_PYTHONIZATION(type, name) \
1261PyObject* name##StringGetData(PyObject* self, bool native=true) \
1263 if (CPyCppyy::CPPInstance_Check(self)) { \
1264 type* obj = ((type*)((CPPInstance*)self)->GetObject()); \
1265 if (obj) return CPyCppyy_PyString_FromCppString(*obj, native); \
1267 PyErr_Format(PyExc_TypeError, "object mismatch (%s expected)", #type); \
1271PyObject* name##StringStr(PyObject* self) \
1273 PyObject* pyobj = name##StringGetData(self, false); \
1277 PyObject* pybytes = name##StringGetData(self, true); \
1279 pyobj = PyObject_Str(pybytes); \
1280 Py_DECREF(pybytes); \
1286PyObject* name##StringBytes(PyObject* self) \
1288 return name##StringGetData(self, true); \
1291PyObject* name##StringRepr(PyObject* self) \
1293 PyObject* data = name##StringGetData(self, true); \
1295 PyObject* repr = PyObject_Repr(data); \
1302PyObject* name##StringIsEqual(PyObject* self, PyObject* obj) \
1304 PyObject* data = name##StringGetData(self, PyBytes_Check(obj)); \
1306 PyObject* result = PyObject_RichCompare(data, obj, Py_EQ); \
1313PyObject* name##StringIsNotEqual(PyObject* self, PyObject* obj) \
1315 PyObject* data = name##StringGetData(self, PyBytes_Check(obj)); \
1317 PyObject* result = PyObject_RichCompare(data, obj, Py_NE); \
1325#define CPPYY_IMPL_STRING_PYTHONIZATION_CMP(type, name) \
1326CPPYY_IMPL_STRING_PYTHONIZATION(type, name) \
1327PyObject* name##StringCompare(PyObject* self, PyObject* obj) \
1329 PyObject* data = name##StringGetData(self, PyBytes_Check(obj)); \
1332 result = PyObject_Compare(data, obj); \
1335 if (PyErr_Occurred()) \
1337 return PyInt_FromLong(result); \
1350 std::string* obj = (std::string*)
self->GetObject();
1363 char*
keywords[] = {(
char*)
"encoding", (
char*)
"errors", (
char*)
nullptr};
1364 const char* encoding =
nullptr;
const char*
errors =
nullptr;
1382 if (obj->find(
needle) != std::string::npos) {
1419#define CPYCPPYY_STRING_FINDMETHOD(name, cppname, pyname) \
1420PyObject* STLString##name(CPPInstance* self, PyObject* args, PyObject* ) \
1422 std::string* obj = GetSTLString(self); \
1426 PyObject* cppmeth = PyObject_GetAttrString((PyObject*)self, (char*)#cppname);\
1428 PyObject* result = PyObject_Call(cppmeth, args, nullptr); \
1429 Py_DECREF(cppmeth); \
1431 if (PyLongOrInt_AsULong64(result) == (PY_ULONG_LONG)std::string::npos) {\
1432 Py_DECREF(result); \
1433 return PyInt_FromLong(-1); \
1440 PyObject* pystr = CPyCppyy_PyText_FromStringAndSize(obj->data(), obj->size());\
1441 PyObject* pymeth = PyObject_GetAttrString(pystr, (char*)#pyname); \
1443 PyObject* result = PyObject_CallObject(pymeth, args); \
1444 Py_DECREF(pymeth); \
1550 for (
auto&
p:
dmc) {
1597#define COMPLEX_METH_GETSET(name, cppname) \
1598static PyObject* name##ComplexGet(PyObject* self, void*) { \
1599 return PyObject_CallMethodNoArgs(self, cppname); \
1601static int name##ComplexSet(PyObject* self, PyObject* value, void*) { \
1602 PyObject* result = PyObject_CallMethodOneArg(self, cppname, value); \
1604 Py_DECREF(result); \
1609PyGetSetDef name##Complex{(char*)#name, (getter)name##ComplexGet, (setter)name##ComplexSet, nullptr, nullptr};
1616 if (!
real)
return nullptr;
1623 if (!
imag)
return nullptr;
1634 if (!
real)
return nullptr;
1641 if (!
imag)
return nullptr;
1647 std::ostringstream s;
1648 s <<
'(' <<
r <<
'+' << i <<
"j)";
1662 ((std::complex<double>*)
self->GetObject())->
real(
d);
1679 ((std::complex<double>*)
self->GetObject())->
imag(
d);
1687 double r = ((std::complex<double>*)
self->GetObject())->
real();
1688 double i = ((std::complex<double>*)
self->GetObject())->
imag();
1744#if PY_VERSION_HEX >= 0x03000000
1772 if (
resname.find(
"iterator") == std::string::npos)
1854 name.compare(0, 6,
"tuple<", 6) != 0) {
1863 initdef <<
"namespace __cppyy_internal {\n"
1864 <<
"void init_" <<
rname <<
"(" <<
name <<
"*& self";
1877 if (
res_clean ==
"internal_enum_type_t")
1880 if (res.rfind(
']') == std::string::npos && res.rfind(
')') == std::string::npos) {
1882 else arg_types.push_back(
"const "+
res_clean+
"&");
1898 for (std::vector<std::string>::size_type i = 0; i < arg_types.size(); ++i) {
1903 for (std::vector<std::string>::size_type i = 0; i <
arg_names.size(); ++i) {
1980 if (
vtype.rfind(
"value_type") == std::string::npos) {
2035 else if (
name ==
"string" ||
name ==
"std::string") {
2056 else if (
name ==
"basic_string_view<char,char_traits<char> >" ||
name ==
"std::basic_string_view<char>") {
2067 else if (
name ==
"basic_string<wchar_t,char_traits<wchar_t>,allocator<wchar_t> >" ||
name ==
"std::basic_string<wchar_t,std::char_traits<wchar_t>,std::allocator<wchar_t> >") {
2076 else if (
name ==
"complex<double>" ||
name ==
"std::complex<double>") {
#define PyInt_FromSsize_t
#define CPyCppyy_PyText_FromStringAndSize
#define CPyCppyy_PySliceCast
#define CPyCppyy_PyText_AsString
static PyObject * PyObject_CallMethodOneArg(PyObject *obj, PyObject *name, PyObject *arg)
#define PyBytes_FromStringAndSize
#define CPyCppyy_PyText_Type
static PyObject * PyObject_CallMethodNoArgs(PyObject *obj, PyObject *name)
#define CPyCppyy_PyText_FromString
#define CPyCppyy_PyText_Check
#define CPPYY_IMPL_STRING_PYTHONIZATION_CMP(type, name)
static bool run_pythonizors(PyObject *pyclass, PyObject *pyname, const std::vector< PyObject * > &v)
#define COMPLEX_METH_GETSET(name, cppname)
#define CPYCPPYY_STRING_FINDMETHOD(name, cppname, pyname)
#define PyObject_LengthHint
std::ios_base::fmtflags fFlags
void FillVector(std::vector< double > &v, int size, T *a)
size_t size(const MatrixT &matrix)
retrieve the size of a square matrix
ROOT::Detail::TRangeCast< T, true > TRangeDynCast
TRangeDynCast is an adapter class that allows the typed iteration through a TCollection.
winID h TVirtualViewer3D TVirtualGLPainter p
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void data
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t r
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t result
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t index
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void value
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t attr
const_iterator end() const
void cppscope_to_legalname(std::string &cppscope)
std::string clean_type(const std::string &cppname, bool template_strip=true, bool const_strip=true)
std::string compound(const std::string &name)
std::string extract_namespace(const std::string &name)
Py_ssize_t GetBuffer(PyObject *pyobject, char tc, int size, void *&buf, bool check=true)
bool AddToClass(PyObject *pyclass, const char *label, PyCFunction cfunc, int flags=METH_VARARGS)
PyTypeObject VectorIter_Type
PyObject * GetScopeProxy(Cppyy::TCppScope_t)
static PyObject * GetAttrDirect(PyObject *pyclass, PyObject *pyname)
bool Pythonize(PyObject *pyclass, const std::string &name)
bool CPPOverload_Check(T *object)
std::map< std::string, std::vector< PyObject * > > & pythonizations()
bool CPPScope_Check(T *object)
bool LowLevelView_Check(T *object)
bool CPPInstance_Check(T *object)
PyTypeObject IndexIter_Type
CPYCPPYY_EXTERN Converter * CreateConverter(const std::string &name, cdims_t=0)
std::set< std::string > gIteratorTypes
RPY_EXPORTED size_t SizeOf(TCppType_t klass)
RPY_EXPORTED bool IsDefaultConstructable(TCppType_t type)
RPY_EXPORTED bool IsEnum(const std::string &type_name)
RPY_EXPORTED std::vector< TCppIndex_t > GetMethodIndicesFromName(TCppScope_t scope, const std::string &name)
RPY_EXPORTED TCppIndex_t GetNumDatamembers(TCppScope_t scope, bool accept_namespace=false)
RPY_EXPORTED bool Compile(const std::string &code, bool silent=false)
RPY_EXPORTED TCppScope_t gGlobalScope
RPY_EXPORTED std::string ResolveName(const std::string &cppitem_name)
RPY_EXPORTED bool IsAggregate(TCppType_t type)
RPY_EXPORTED std::string GetScopedFinalName(TCppType_t type)
RPY_EXPORTED bool IsPublicData(TCppScope_t scope, TCppIndex_t idata)
RPY_EXPORTED bool IsBuiltin(const std::string &type_name)
RPY_EXPORTED bool IsStaticData(TCppScope_t scope, TCppIndex_t idata)
RPY_EXPORTED std::string GetDatamemberType(TCppScope_t scope, TCppIndex_t idata)
RPY_EXPORTED TCppMethod_t GetMethod(TCppScope_t scope, TCppIndex_t imeth)
RPY_EXPORTED bool IsSmartPtr(TCppType_t type)
RPY_EXPORTED TCppScope_t GetScope(const std::string &scope_name)
RPY_EXPORTED std::string GetMethodResultType(TCppMethod_t)
RPY_EXPORTED std::string GetDatamemberName(TCppScope_t scope, TCppIndex_t idata)