diff options
-rw-r--r-- | sipgen/gencode.c | 494 | ||||
-rw-r--r-- | siplib/apiversions.c | 4 | ||||
-rw-r--r-- | siplib/descriptors.c | 8 | ||||
-rw-r--r-- | siplib/sip-tqt.h | 94 | ||||
-rw-r--r-- | siplib/siplib.c | 671 | ||||
-rw-r--r-- | siplib/tqtlib.c | 7 | ||||
-rw-r--r-- | siplib/voidptr.c | 169 |
7 files changed, 53 insertions, 1394 deletions
diff --git a/sipgen/gencode.c b/sipgen/gencode.c index 0a9bc41..7d0dd63 100644 --- a/sipgen/gencode.c +++ b/sipgen/gencode.c @@ -75,7 +75,6 @@ static void generateConsolidatedCpp(sipSpec *pt, const char *codeDir, static void generateComponentCpp(sipSpec *pt, const char *codeDir, const char *consModule); static void generateSipImport(moduleDef *mod, FILE *fp); -static void generateSipImportVariables(FILE *fp); static void generateModInitStart(moduleDef *mod, int gen_c, FILE *fp); static void generateModDefinition(moduleDef *mod, const char *methods, FILE *fp); @@ -246,8 +245,6 @@ static void prCachedName(FILE *fp, nameDef *nd, const char *prefix); static void generateSignalTableEntry(sipSpec *pt, classDef *cd, overDef *sig, memberDef *md, int membernr, FILE *fp); static void generateTypesTable(sipSpec *pt, moduleDef *mod, FILE *fp); -static int py2OnlySlot(slotType st); -static int py2_5LaterSlot(slotType st); static int keepPyReference(argDef *ad); static int isDuplicateProtected(classDef *cd, overDef *target); static char getEncoding(argType atype); @@ -865,11 +862,7 @@ static void generateCompositeCpp(sipSpec *pt, const char *codeDir) "\n" "static void sip_import_component_module(PyObject *d, const char *name)\n" "{\n" -"#if PY_VERSION_HEX >= 0x02050000\n" " PyObject *mod = PyImport_ImportModule(name);\n" -"#else\n" -" PyObject *mod = PyImport_ImportModule((char *)name);\n" -"#endif\n" "\n" " /*\n" " * Note that we don't complain if the module can't be imported. This\n" @@ -891,11 +884,7 @@ static void generateCompositeCpp(sipSpec *pt, const char *codeDir) "\n" " PyObject *sipModule, *sipModuleDict;\n" "\n" -"#if PY_MAJOR_VERSION >= 3\n" " sipModule = PyModule_Create(&sip_module_def);\n" -"#else\n" -" sipModule = Py_InitModule(\"%s\", 0);\n" -"#endif\n" "\n" " if (sipModule == NULL)\n" " SIP_MODULE_RETURN(NULL);\n" @@ -956,11 +945,7 @@ static void generateConsolidatedCpp(sipSpec *pt, const char *codeDir, for (mod = pt->modules; mod != NULL; mod = mod->next) if (mod->container == pt->module) prcode(fp, -"#if PY_MAJOR_VERSION >= 3\n" -"extern PyObject *sip_init_%s(void);\n" -"#else\n" -"extern void sip_init_%s(void);\n" -"#endif\n" + "extern PyObject *sip_init_%s(void);\n" , mod->name , mod->name); @@ -980,11 +965,7 @@ static void generateConsolidatedCpp(sipSpec *pt, const char *codeDir, "{\n" " struct component {\n" " const char *name;\n" -"#if PY_MAJOR_VERSION >= 3\n" " PyObject *(*init)(void);\n" -"#else\n" -" void (*init)(void);\n" -"#endif\n" " };\n" "\n" " static struct component components[] = {\n" @@ -1003,27 +984,14 @@ static void generateConsolidatedCpp(sipSpec *pt, const char *codeDir, " const char *name;\n" " struct component *scd;\n" "\n" -"#if PY_MAJOR_VERSION >= 3\n" " name = PyBytes_AsString(arg);\n" -"#else\n" -" name = PyString_AsString(arg);\n" -"#endif\n" "\n" " if (name == NULL)\n" " return NULL;\n" "\n" " for (scd = components; scd->name != NULL; ++scd)\n" " if (strcmp(scd->name, name) == 0)\n" -"#if PY_MAJOR_VERSION >= 3\n" " return (*scd->init)();\n" -"#else\n" -" {\n" -" (*scd->init)();\n" -"\n" -" Py_INCREF(Py_None);\n" -" return Py_None;\n" -" }\n" -"#endif\n" "\n" " PyErr_Format(PyExc_ImportError, \"unknown component module %%s\", name);\n" "\n" @@ -1044,13 +1012,9 @@ static void generateConsolidatedCpp(sipSpec *pt, const char *codeDir, prcode(fp, "\n" -"#if PY_MAJOR_VERSION >= 3\n" " return PyModule_Create(&sip_module_def);\n" -"#else\n" -" Py_InitModule(\"%s\", sip_methods);\n" -"#endif\n" "}\n" - , mname); + ); closeFile(fp); free(cppfile); @@ -1088,18 +1052,10 @@ static void generateComponentCpp(sipSpec *pt, const char *codeDir, prcode(fp, " /* Ask the consolidated module to do the initialistion. */\n" -"#if PY_MAJOR_VERSION >= 3\n" " sip_result = PyObject_CallMethod(sip_mod, \"init\", \"y\", \"%s\");\n" -"#else\n" -" sip_result = PyObject_CallMethod(sip_mod, \"init\", \"s\", \"%s\");\n" -"#endif\n" " Py_DECREF(sip_mod);\n" "\n" -"#if PY_MAJOR_VERSION >= 3\n" " return sip_result;\n" -"#else\n" -" Py_XDECREF(sip_result);\n" -"#endif\n" "}\n" , pt->module->fullname->text , pt->module->fullname->text); @@ -1311,24 +1267,10 @@ static void generateCpp(sipSpec *pt, moduleDef *mod, const char *codeDir, for (od = mod->overs; od != NULL; od = od->next) if (od->common == md) { - if (py2OnlySlot(md->slot)) - prcode(fp, -"#if PY_MAJOR_VERSION < 3\n" - ); - else if (py2_5LaterSlot(md->slot)) - prcode(fp, -"#if PY_VERSION_HEX >= 0x02050000\n" - ); - prcode(fp, " {(void *)slot_%s, %s, {0, 0, 0}},\n" , md->pyname->text, slotName(md->slot)); - if (py2OnlySlot(md->slot) || py2_5LaterSlot(md->slot)) - prcode(fp, -"#endif\n" - ); - break; } } @@ -1336,15 +1278,6 @@ static void generateCpp(sipSpec *pt, moduleDef *mod, const char *codeDir, for (cd = mod->proxies; cd != NULL; cd = cd->next) for (md = cd->members; md != NULL; md = md->next) { - if (py2OnlySlot(md->slot)) - prcode(fp, -"#if PY_MAJOR_VERSION < 3\n" - ); - else if (py2_5LaterSlot(md->slot)) - prcode(fp, -"#if PY_VERSION_HEX >= 0x02050000\n" - ); - prcode(fp, " {(void *)slot_%L_%s, %s, ", cd->iff, md->pyname->text, slotName(md->slot)); @@ -1352,11 +1285,6 @@ static void generateCpp(sipSpec *pt, moduleDef *mod, const char *codeDir, prcode(fp, "},\n" ); - - if (py2OnlySlot(md->slot) || py2_5LaterSlot(md->slot)) - prcode(fp, -"#endif\n" - ); } prcode(fp, @@ -1430,23 +1358,9 @@ static void generateCpp(sipSpec *pt, moduleDef *mod, const char *codeDir, if ((stype = slotName(slot->slot)) != NULL) { - if (py2OnlySlot(slot->slot)) - prcode(fp, -"#if PY_MAJOR_VERSION < 3\n" - ); - else if (py2_5LaterSlot(slot->slot)) - prcode(fp, -"#if PY_VERSION_HEX >= 0x02050000\n" - ); - prcode(fp, " {(void *)slot_%C_%s, %s},\n" , ed->fqcname, slot->pyname->text, stype); - - if (py2OnlySlot(slot->slot) || py2_5LaterSlot(slot->slot)) - prcode(fp, -"#endif\n" - ); } } @@ -1904,15 +1818,9 @@ static void generateCpp(sipSpec *pt, moduleDef *mod, const char *codeDir, if (mod->container == pt->module) prcode(fp, "\n" -"#if PY_MAJOR_VERSION >= 3\n" "#define SIP_MODULE_DISCARD(r) Py_DECREF(r)\n" "#define SIP_MODULE_RETURN(r) return (r)\n" "PyObject *sip_init_%s()\n" -"#else\n" -"#define SIP_MODULE_DISCARD(r)\n" -"#define SIP_MODULE_RETURN(r) return\n" -"void sip_init_%s()\n" -"#endif\n" "{\n" , mname , mname); @@ -1966,31 +1874,12 @@ static void generateCpp(sipSpec *pt, moduleDef *mod, const char *codeDir, " PyObject *sipModule, *sipModuleDict;\n" ); - generateSipImportVariables(fp); - /* Generate any pre-initialisation code. */ generateCppCodeBlock(mod->preinitcode, fp); prcode(fp, " /* Initialise the module and get it's dictionary. */\n" -"#if PY_MAJOR_VERSION >= 3\n" " sipModule = PyModule_Create(&sip_module_def);\n" -"#elif PY_VERSION_HEX >= 0x02050000\n" -" sipModule = Py_InitModule(%N, sip_methods);\n" -"#else\n" - , mod->fullname); - - if (generating_c) - prcode(fp, -" sipModule = Py_InitModule((char *)%N, sip_methods);\n" - , mod->fullname); - else - prcode(fp, -" sipModule = Py_InitModule(const_cast<char *>(%N), sip_methods);\n" - , mod->fullname); - - prcode(fp, -"#endif\n" "\n" " if (sipModule == NULL)\n" " SIP_MODULE_RETURN(NULL);\n" @@ -2008,9 +1897,6 @@ static void generateCpp(sipSpec *pt, moduleDef *mod, const char *codeDir, " /* Export the module and publish it's API. */\n" " if (sipExportModule(&sipModuleAPI_%s,SIP_TQT_API_MAJOR_NR,SIP_TQT_API_MINOR_NR,0) < 0)\n" " {\n" -"#if !defined(SIP_USE_PYCAPSULE)\n" -" Py_DECREF(sip_sipmod);\n" -"#endif\n" " SIP_MODULE_DISCARD(sipModule);\n" " SIP_MODULE_RETURN(0);\n" " }\n" @@ -2034,9 +1920,6 @@ static void generateCpp(sipSpec *pt, moduleDef *mod, const char *codeDir, " /* Initialise the module now all its dependencies have been set up. */\n" " if (sipInitModule(&sipModuleAPI_%s,sipModuleDict) < 0)\n" " {\n" -"#if !defined(SIP_USE_PYCAPSULE)\n" -" Py_DECREF(sip_sipmod);\n" -"#endif\n" " SIP_MODULE_DISCARD(sipModule);\n" " SIP_MODULE_RETURN(0);\n" " }\n" @@ -2076,11 +1959,7 @@ static void generateCpp(sipSpec *pt, moduleDef *mod, const char *codeDir, prcode(fp, "\n" " if ((exceptionsTable[%d] = PyErr_NewException(\n" -"#if PY_MAJOR_VERSION >= 3\n" " \"%s.%s\",\n" -"#else\n" -" const_cast<char *>(\"%s.%s\"),\n" -"#endif\n" " " , xd->exceptionnr , xd->iff->module->name, xd->pyname @@ -2095,9 +1974,6 @@ static void generateCpp(sipSpec *pt, moduleDef *mod, const char *codeDir, prcode(fp, ",NULL)) == NULL || PyDict_SetItemString(sipModuleDict,\"%s\",exceptionsTable[%d]) < 0)\n" " {\n" -"#if !defined(SIP_USE_PYCAPSULE)\n" -" Py_DECREF(sip_sipmod);\n" -"#endif\n" " SIP_MODULE_DISCARD(sipModule);\n" " SIP_MODULE_RETURN(0);\n" " }\n" @@ -2215,8 +2091,6 @@ static void generateSipImport(moduleDef *mod, FILE *fp) { prcode(fp, " /* Get the SIP-TQt module's API. */\n" -"#if defined(SIP_USE_PYCAPSULE)\n" -"\n" ); if (generating_c) @@ -2235,71 +2109,7 @@ static void generateSipImport(moduleDef *mod, FILE *fp) " SIP_MODULE_DISCARD(sipModule);\n" " SIP_MODULE_RETURN(NULL);\n" " }\n" -"\n" -"#else\n" -"\n" -"#if PY_VERSION_HEX >= 0x02050000\n" -" sip_sipmod = PyImport_ImportModule(\"sip_tqt\");\n" -"#else\n" - , mod->name); - - if (generating_c) - prcode(fp, -" sip_sipmod = PyImport_ImportModule((char *)\"sip_tqt\");\n" - ); - else - prcode(fp, -" sip_sipmod = PyImport_ImportModule(const_cast<char *>(\"sip_tqt\"));\n" - ); - - prcode(fp, -"#endif\n" -"\n" -" if (sip_sipmod == NULL)\n" -" {\n" -" SIP_MODULE_DISCARD(sipModule);\n" -" SIP_MODULE_RETURN(NULL);\n" -" }\n" -"\n" -" sip_capiobj = PyDict_GetItemString(PyModule_GetDict(sip_sipmod), \"_C_API\");\n" -"\n" -" if (sip_capiobj == NULL || !PyCObject_Check(sip_capiobj))\n" -" {\n" -" Py_DECREF(sip_sipmod);\n" -" SIP_MODULE_DISCARD(sipModule);\n" -" SIP_MODULE_RETURN(NULL);\n" -" }\n" -"\n" - ); - - if (generating_c) - prcode(fp, -" sipAPI_%s = (const sipAPIDef *)PyCObject_AsVoidPtr(sip_capiobj);\n" , mod->name); - else - prcode(fp, -" sipAPI_%s = reinterpret_cast<const sipAPIDef *>(PyCObject_AsVoidPtr(sip_capiobj));\n" - , mod->name); - - prcode(fp, -"\n" -"#endif\n" -"\n" - ); -} - - -/* - * Generate the variables needed by generateSipImport(). - */ -static void generateSipImportVariables(FILE *fp) -{ - prcode(fp, -"#if !defined(SIP_USE_PYCAPSULE)\n" -" PyObject *sip_sipmod, *sip_capiobj;\n" -"#endif\n" -"\n" - ); } @@ -2312,17 +2122,10 @@ static void generateModInitStart(moduleDef *mod, int gen_c, FILE *fp) "\n" "\n" "/* The Python module initialisation function. */\n" -"#if PY_MAJOR_VERSION >= 3\n" "#define SIP_MODULE_ENTRY PyInit_%s\n" "#define SIP_MODULE_TYPE PyObject *\n" "#define SIP_MODULE_DISCARD(r) Py_DECREF(r)\n" "#define SIP_MODULE_RETURN(r) return (r)\n" -"#else\n" -"#define SIP_MODULE_ENTRY init%s\n" -"#define SIP_MODULE_TYPE void\n" -"#define SIP_MODULE_DISCARD(r)\n" -"#define SIP_MODULE_RETURN(r) return\n" -"#endif\n" "\n" "#if (defined(__GNUC__) && __GNUC__ >= 4) || defined(__clang__)\n" "#pragma GCC visibility push(default)\n" @@ -2350,7 +2153,6 @@ static void generateModDefinition(moduleDef *mod, const char *methods, { prcode(fp, "\n" -"#if PY_MAJOR_VERSION >= 3\n" " static PyModuleDef sip_module_def = {\n" " PyModuleDef_HEAD_INIT,\n" " \"%s\",\n" @@ -2362,7 +2164,6 @@ static void generateModDefinition(moduleDef *mod, const char *methods, " NULL,\n" " NULL\n" " };\n" -"#endif\n" , mod->fullname->text , methods); } @@ -4363,11 +4164,7 @@ static void generateVariableGetter(ifaceFileDef *scope, varDef *vd, FILE *fp) case utf8_string_type: if (vd->type.nrderefs == 0) prcode(fp, -"#if PY_MAJOR_VERSION >= 3\n" " return PyUnicode_FromStringAndSize(&sipVal, 1);\n" -"#else\n" -" return PyUnicode_DecodeUTF8(&sipVal, 1, NULL);\n" -"#endif\n" ); else prcode(fp, @@ -4377,11 +4174,7 @@ static void generateVariableGetter(ifaceFileDef *scope, varDef *vd, FILE *fp) " return Py_None;\n" " }\n" "\n" -"#if PY_MAJOR_VERSION >= 3\n" " return PyUnicode_FromString(sipVal);\n" -"#else\n" -" return PyUnicode_DecodeUTF8(sipVal, strlen(sipVal), NULL);\n" -"#endif\n" ); break; @@ -4394,7 +4187,7 @@ static void generateVariableGetter(ifaceFileDef *scope, varDef *vd, FILE *fp) if (vd->type.nrderefs == 0) prcode(fp, -" return SIPBytes_FromStringAndSize(%s&sipVal, 1);\n" +" return PyBytes_FromStringAndSize(%s&sipVal, 1);\n" , cast); else prcode(fp, @@ -4404,7 +4197,7 @@ static void generateVariableGetter(ifaceFileDef *scope, varDef *vd, FILE *fp) " return Py_None;\n" " }\n" "\n" -" return SIPBytes_FromString(%ssipVal);\n" +" return PyBytes_FromString(%ssipVal);\n" , cast); } @@ -4458,7 +4251,7 @@ static void generateVariableGetter(ifaceFileDef *scope, varDef *vd, FILE *fp) case cint_type: case int_type: prcode(fp, -" return SIPLong_FromLong(sipVal);\n" +" return PyLong_FromLong(sipVal);\n" ); break; @@ -4789,7 +4582,7 @@ static int generateObjToCppConversion(argDef *ad,FILE *fp) break; case enum_type: - prcode(fp, "(%E)SIPLong_AsLong(sipPy);\n" + prcode(fp, "(%E)PyLong_AsLong(sipPy);\n" , ad->u.ed); break; @@ -4866,7 +4659,7 @@ static int generateObjToCppConversion(argDef *ad,FILE *fp) case bool_type: case cbool_type: - rhs = "(bool)SIPLong_AsLong(sipPy)"; + rhs = "(bool)PyLong_AsLong(sipPy)"; break; case ushort_type: @@ -4874,7 +4667,7 @@ static int generateObjToCppConversion(argDef *ad,FILE *fp) break; case short_type: - rhs = "(short)SIPLong_AsLong(sipPy)"; + rhs = "(short)PyLong_AsLong(sipPy)"; break; case uint_type: @@ -4883,7 +4676,7 @@ static int generateObjToCppConversion(argDef *ad,FILE *fp) case int_type: case cint_type: - rhs = "(int)SIPLong_AsLong(sipPy)"; + rhs = "(int)PyLong_AsLong(sipPy)"; break; case ulong_type: @@ -5146,15 +4939,6 @@ static void generateSlot(moduleDef *mod, classDef *cd, enumDef *ed, "\n" ); - if (py2OnlySlot(md->slot)) - prcode(fp, -"#if PY_MAJOR_VERSION < 3\n" - ); - else if (py2_5LaterSlot(md->slot)) - prcode(fp, -"#if PY_VERSION_HEX >= 0x02050000\n" - ); - if (!generating_c) { prcode(fp, @@ -5204,7 +4988,7 @@ static void generateSlot(moduleDef *mod, classDef *cd, enumDef *ed, , (md->slot == cmp_slot ? "-2" : (ret_int ? "-1" : "0"))); else prcode(fp, -" %S sipCpp = static_cast<%S>(SIPLong_AsLong(sipSelf));\n" +" %S sipCpp = static_cast<%S>(PyLong_AsLong(sipSelf));\n" "\n" , fqcname, fqcname); } @@ -5311,11 +5095,6 @@ static void generateSlot(moduleDef *mod, classDef *cd, enumDef *ed, prcode(fp, "}\n" ); - - if (py2OnlySlot(md->slot) || py2_5LaterSlot(md->slot)) - prcode(fp, -"#endif\n" - ); } @@ -5564,7 +5343,6 @@ static void generateClassFunctions(sipSpec *pt, moduleDef *mod, classDef *cd, prcode(fp, "\n" "\n" -"#if PY_MAJOR_VERSION >= 3\n" ); if (!generating_c) @@ -5596,7 +5374,6 @@ static void generateClassFunctions(sipSpec *pt, moduleDef *mod, classDef *cd, "\n" " return sipRes;\n" "}\n" -"#endif\n" ); } @@ -5605,7 +5382,6 @@ static void generateClassFunctions(sipSpec *pt, moduleDef *mod, classDef *cd, prcode(fp, "\n" "\n" -"#if PY_MAJOR_VERSION >= 3\n" ); if (!generating_c) @@ -5629,158 +5405,6 @@ static void generateClassFunctions(sipSpec *pt, moduleDef *mod, classDef *cd, prcode(fp, "}\n" -"#endif\n" - ); - } - - if (cd->readbufcode != NULL) - { - prcode(fp, -"\n" -"\n" -"#if PY_MAJOR_VERSION < 3\n" - ); - - if (!generating_c) - prcode(fp, -"extern \"C\" {static SIP_SSIZE_T getreadbuffer_%C(PyObject *, void *, SIP_SSIZE_T, void **);}\n" - , classFTQCName(cd)); - - prcode(fp, -"static SIP_SSIZE_T getreadbuffer_%C(PyObject *%s, void *sipCppV, SIP_SSIZE_T %s, void **%s)\n" -"{\n" -" ", classFTQCName(cd) - , argName("sipSelf", cd->readbufcode) - , argName("sipSegment", cd->readbufcode) - , argName("sipPtrPtr", cd->readbufcode)); - - generateClassFromVoid(cd, "sipCpp", "sipCppV", fp); - - prcode(fp, ";\n" -" SIP_SSIZE_T sipRes;\n" -"\n" - ); - - generateCppCodeBlock(cd->readbufcode, fp); - - prcode(fp, -"\n" -" return sipRes;\n" -"}\n" -"#endif\n" - ); - } - - if (cd->writebufcode != NULL) - { - prcode(fp, -"\n" -"\n" -"#if PY_MAJOR_VERSION < 3\n" - ); - - if (!generating_c) - prcode(fp, -"extern \"C\" {static SIP_SSIZE_T getwritebuffer_%C(PyObject *, void *, SIP_SSIZE_T, void **);}\n" - , classFTQCName(cd)); - - prcode(fp, -"static SIP_SSIZE_T getwritebuffer_%C(PyObject *%s, void *sipCppV, SIP_SSIZE_T %s, void **%s)\n" -"{\n" -" ", classFTQCName(cd) - , argName("sipSelf", cd->writebufcode) - , argName("sipSegment", cd->writebufcode) - , argName("sipPtrPtr", cd->writebufcode)); - - generateClassFromVoid(cd, "sipCpp", "sipCppV", fp); - - prcode(fp, ";\n" -" SIP_SSIZE_T sipRes;\n" -"\n" - ); - - generateCppCodeBlock(cd->writebufcode, fp); - - prcode(fp, -"\n" -" return sipRes;\n" -"}\n" -"#endif\n" - ); - } - - if (cd->segcountcode != NULL) - { - prcode(fp, -"\n" -"\n" -"#if PY_MAJOR_VERSION < 3\n" - ); - - if (!generating_c) - prcode(fp, -"extern \"C\" {static SIP_SSIZE_T getsegcount_%C(PyObject *, void *, SIP_SSIZE_T *);}\n" - , classFTQCName(cd)); - - prcode(fp, -"static SIP_SSIZE_T getsegcount_%C(PyObject *%s, void *sipCppV, SIP_SSIZE_T *%s)\n" -"{\n" -" ", classFTQCName(cd) - , argName("sipSelf", cd->segcountcode) - , argName("sipLenPtr", cd->segcountcode)); - - generateClassFromVoid(cd, "sipCpp", "sipCppV", fp); - - prcode(fp, ";\n" -" SIP_SSIZE_T sipRes;\n" -"\n" - ); - - generateCppCodeBlock(cd->segcountcode, fp); - - prcode(fp, -"\n" -" return sipRes;\n" -"}\n" -"#endif\n" - ); - } - - if (cd->charbufcode != NULL) - { - prcode(fp, -"\n" -"\n" -"#if PY_MAJOR_VERSION < 3\n" - ); - - if (!generating_c) - prcode(fp, -"extern \"C\" {static SIP_SSIZE_T getcharbuffer_%C(PyObject *, void *, SIP_SSIZE_T, void **);}\n" - , classFTQCName(cd)); - - prcode(fp, -"static SIP_SSIZE_T getcharbuffer_%C(PyObject *%s, void *sipCppV, SIP_SSIZE_T %s, void **%s)\n" -"{\n" -" ", classFTQCName(cd) - , argName("sipSelf", cd->charbufcode) - , argName("sipSegment", cd->charbufcode) - , argName("sipPtrPtr", cd->charbufcode)); - - generateClassFromVoid(cd, "sipCpp", "sipCppV", fp); - - prcode(fp, ";\n" -" SIP_SSIZE_T sipRes;\n" -"\n" - ); - - generateCppCodeBlock(cd->charbufcode, fp); - - prcode(fp, -"\n" -" return sipRes;\n" -"}\n" -"#endif\n" ); } @@ -8962,23 +8586,9 @@ static void generateTypeDefinition(sipSpec *pt, classDef *cd, FILE *fp) if ((stype = slotName(md->slot)) != NULL) { - if (py2OnlySlot(md->slot)) - prcode(fp, -"#if PY_MAJOR_VERSION < 3\n" - ); - else if (py2_5LaterSlot(md->slot)) - prcode(fp, -"#if PY_VERSION_HEX >= 0x02050000\n" - ); - prcode(fp, " {(void *)slot_%L_%s, %s},\n" , cd->iff, md->pyname->text, stype); - - if (py2OnlySlot(md->slot) || py2_5LaterSlot(md->slot)) - prcode(fp, -"#endif\n" - ); } } @@ -9398,10 +9008,6 @@ static void generateTypeDefinition(sipSpec *pt, classDef *cd, FILE *fp) " 0,\n" ); - prcode(fp, -"#if PY_MAJOR_VERSION >= 3\n" - ); - if (cd->getbufcode != NULL) prcode(fp, " getbuffer_%C,\n" @@ -9420,50 +9026,6 @@ static void generateTypeDefinition(sipSpec *pt, classDef *cd, FILE *fp) " 0,\n" ); - prcode(fp, -"#else\n" - ); - - if (cd->readbufcode != NULL) - prcode(fp, -" getreadbuffer_%C,\n" - , classFTQCName(cd)); - else - prcode(fp, -" 0,\n" - ); - - if (cd->writebufcode != NULL) - prcode(fp, -" getwritebuffer_%C,\n" - , classFTQCName(cd)); - else - prcode(fp, -" 0,\n" - ); - - if (cd->segcountcode != NULL) - prcode(fp, -" getsegcount_%C,\n" - , classFTQCName(cd)); - else - prcode(fp, -" 0,\n" - ); - - if (cd->charbufcode != NULL) - prcode(fp, -" getcharbuffer_%C,\n" - , classFTQCName(cd)); - else - prcode(fp, -" 0,\n" - ); - - prcode(fp, -"#endif\n" - ); - if (needDealloc(cd)) prcode(fp, " dealloc_%L,\n" @@ -9615,28 +9177,6 @@ static void generateSignalTableEntry(sipSpec *pt, classDef *cd, overDef *sig, /* - * Return TRUE if the slot is specific to Python v2. - */ -static int py2OnlySlot(slotType st) -{ - /* - * Note that we place interpretations on div_slot and idiv_slot for Python - * v3 so they are not included. - */ - return (st == long_slot || st == cmp_slot); -} - - -/* - * Return TRUE if the slot is specific to Python v2.5 and later. - */ -static int py2_5LaterSlot(slotType st) -{ - return (st == index_slot); -} - - -/* * Return the sip module's string equivalent of a slot. */ static const char *slotName(slotType st) @@ -10912,11 +10452,7 @@ static void generateHandleResult(overDef *od, int isNew, int result_size, case utf8_string_type: if (ad->nrderefs == 0) prcode(fp, -"#if PY_MAJOR_VERSION >= 3\n" " %s PyUnicode_FromStringAndSize(&%s, 1);\n" -"#else\n" -" %s PyUnicode_DecodeUTF8(&%s, 1, NULL);\n" -"#endif\n" , prefix, vname , prefix, vname); else @@ -10927,11 +10463,7 @@ static void generateHandleResult(overDef *od, int isNew, int result_size, " return Py_None;\n" " }\n" "\n" -"#if PY_MAJOR_VERSION >= 3\n" " %s PyUnicode_FromString(%s);\n" -"#else\n" -" %s PyUnicode_DecodeUTF8(%s, strlen(%s), NULL);\n" -"#endif\n" , vname , prefix, vname , prefix, vname, vname); @@ -10943,7 +10475,7 @@ static void generateHandleResult(overDef *od, int isNew, int result_size, case string_type: if (ad->nrderefs == 0) prcode(fp, -" %s SIPBytes_FromStringAndSize(%s&%s,1);\n" +" %s PyBytes_FromStringAndSize(%s&%s,1);\n" ,prefix,(ad->atype != string_type) ? "(char *)" : "",vname); else prcode(fp, @@ -10953,7 +10485,7 @@ static void generateHandleResult(overDef *od, int isNew, int result_size, " return Py_None;\n" " }\n" "\n" -" %s SIPBytes_FromString(%s%s);\n" +" %s PyBytes_FromString(%s%s);\n" ,vname ,prefix,(ad->atype != string_type) ? "(char *)" : "",vname); @@ -10994,7 +10526,7 @@ static void generateHandleResult(overDef *od, int isNew, int result_size, case int_type: case cint_type: prcode(fp, -" %s SIPLong_FromLong(%s);\n" +" %s PyLong_FromLong(%s);\n" ,prefix,vname); break; diff --git a/siplib/apiversions.c b/siplib/apiversions.c index f278c6b..cb2aaa6 100644 --- a/siplib/apiversions.c +++ b/siplib/apiversions.c @@ -194,11 +194,7 @@ PyObject *sipGetAPI(PyObject *self, PyObject *args) return NULL; } -#if PY_MAJOR_VERSION >= 3 return PyLong_FromLong(avd->version_nr); -#else - return PyInt_FromLong(avd->version_nr); -#endif } diff --git a/siplib/descriptors.c b/siplib/descriptors.c index 009a03e..1498c44 100644 --- a/siplib/descriptors.c +++ b/siplib/descriptors.c @@ -123,13 +123,7 @@ static PyObject *sipMethodDescr_repr(PyObject *self) { sipMethodDescr *md = (sipMethodDescr *)self; - return -#if PY_MAJOR_VERSION >= 3 - PyUnicode_FromFormat -#else - PyString_FromFormat -#endif - ("<built-in method %s>", md->pmd->ml_name); + return PyUnicode_FromFormat("<built-in method %s>", md->pmd->ml_name); } diff --git a/siplib/sip-tqt.h b/siplib/sip-tqt.h index e3a306f..7fb0bb5 100644 --- a/siplib/sip-tqt.h +++ b/siplib/sip-tqt.h @@ -46,8 +46,8 @@ extern "C" { /* Sanity check on the Python version. */ -#if PY_VERSION_HEX < 0x02030000 -#error "This version of SIP-TQt requires Python v2.3 or later" +#if PY_VERSION_HEX < 0x03020000 +#error "This version of SIP-TQt requires Python v3.2 or later" #endif @@ -178,63 +178,12 @@ extern "C" { #endif -/* Some Python compatibility stuff. */ -#if PY_VERSION_HEX >= 0x02050000 - #define SIP_SSIZE_T Py_ssize_t #define SIP_MLNAME_CAST(s) (s) #define SIP_MLDOC_CAST(s) (s) #define SIP_TPNAME_CAST(s) (s) -#else - -#define SIP_SSIZE_T int - -#define SIP_MLNAME_CAST(s) ((char *)(s)) -#define SIP_MLDOC_CAST(s) ((char *)(s)) -#define SIP_TPNAME_CAST(s) ((char *)(s)) - -#endif - -#if PY_MAJOR_VERSION >= 3 - -#define SIPLong_FromLong PyLong_FromLong -#define SIPLong_AsLong PyLong_AsLong - -#define SIPBytes_Check PyBytes_Check -#define SIPBytes_FromString PyBytes_FromString -#define SIPBytes_FromStringAndSize PyBytes_FromStringAndSize -#define SIPBytes_AS_STRING PyBytes_AS_STRING -#define SIPBytes_GET_SIZE PyBytes_GET_SIZE - -#if (PY_MAJOR_VERSION > 3) || ((PY_MAJOR_VERSION == 3) && (PY_MINOR_VERSION >= 1)) -#define SIP_USE_PYCAPSULE -#endif - -#if (PY_MAJOR_VERSION == 3) && (PY_MINOR_VERSION < 2) -#define SIP_SUPPORT_PYCOBJECT -#endif - -#else - -#define SIPLong_FromLong PyInt_FromLong -#define SIPLong_AsLong PyInt_AsLong - -#define SIPBytes_Check PyString_Check -#define SIPBytes_FromString PyString_FromString -#define SIPBytes_FromStringAndSize PyString_FromStringAndSize -#define SIPBytes_AS_STRING PyString_AS_STRING -#define SIPBytes_GET_SIZE PyString_GET_SIZE - -#if PY_MINOR_VERSION >= 7 -#define SIP_USE_PYCAPSULE -#endif - -#define SIP_SUPPORT_PYCOBJECT - -#endif - #if !defined(Py_REFCNT) #define Py_REFCNT(ob) (((PyObject*)(ob))->ob_refcnt) #endif @@ -371,13 +320,8 @@ typedef void *(*sipInitFunc)(sipSimpleWrapper *, PyObject *, PyObject *, PyObject **, PyObject **, PyObject **); typedef int (*sipTraverseFunc)(void *, visitproc, void *); typedef int (*sipClearFunc)(void *); -#if PY_MAJOR_VERSION >= 3 typedef int (*sipGetBufferFunc)(PyObject *, void *, Py_buffer *, int); typedef void (*sipReleaseBufferFunc)(PyObject *, void *, Py_buffer *); -#else -typedef SIP_SSIZE_T (*sipBufferFunc)(PyObject *, void *, SIP_SSIZE_T, void **); -typedef SIP_SSIZE_T (*sipSegCountFunc)(PyObject *, void *, SIP_SSIZE_T *); -#endif typedef void (*sipDeallocFunc)(sipSimpleWrapper *); typedef void *(*sipCastFunc)(void *, const struct _sipTypeDef *); typedef const struct _sipTypeDef *(*sipSubClassConvertFunc)(void **); @@ -509,9 +453,6 @@ typedef enum { typedef enum { str_slot, /* __str__ */ int_slot, /* __int__ */ -#if PY_MAJOR_VERSION < 3 - long_slot, /* __long__ */ -#endif float_slot, /* __float__ */ len_slot, /* __len__ */ contains_slot, /* __contains__ */ @@ -554,18 +495,13 @@ typedef enum { ne_slot, /* __ne__ */ gt_slot, /* __gt__ */ ge_slot, /* __ge__ */ -#if PY_MAJOR_VERSION < 3 - cmp_slot, /* __cmp__ */ -#endif bool_slot, /* __bool__, __nonzero__ */ neg_slot, /* __neg__ */ repr_slot, /* __repr__ */ hash_slot, /* __hash__ */ pos_slot, /* __pos__ */ abs_slot, /* __abs__ */ -#if PY_VERSION_HEX >= 0x02050000 index_slot, /* __index__ */ -#endif iter_slot, /* __iter__ */ next_slot, /* __next__ */ } sipPySlotType; @@ -736,25 +672,11 @@ typedef struct _sipClassTypeDef { /* The clear function. */ sipClearFunc ctd_clear; -#if PY_MAJOR_VERSION >= 3 /* The get buffer function. */ sipGetBufferFunc ctd_getbuffer; /* The release buffer function. */ sipReleaseBufferFunc ctd_releasebuffer; -#else - /* The read buffer function. */ - sipBufferFunc ctd_readbuffer; - - /* The write buffer function. */ - sipBufferFunc ctd_writebuffer; - - /* The segment count function. */ - sipSegCountFunc ctd_segcount; - - /* The char buffer function. */ - sipBufferFunc ctd_charbuffer; -#endif /* The deallocation function. */ sipDeallocFunc ctd_dealloc; @@ -1196,11 +1118,6 @@ typedef struct _sipPyMethod { /* Self if it is a bound method. */ PyObject *mself; - -#if PY_MAJOR_VERSION < 3 - /* The class. */ - PyObject *mclass; -#endif } sipPyMethod; @@ -1474,16 +1391,9 @@ typedef struct _sipTQtAPI { #define sipIsExactWrappedType(wt) (sipTypeAsPyTypeObject((wt)->type) == (PyTypeObject *)(wt)) -#if PY_VERSION_HEX >= 0x03020000 #define sipConvertFromSliceObject(o,len,start,stop,step,slen) \ PySlice_GetIndicesEx((o), (len), (start), (stop), \ (step), (slen)) -#else -#define sipConvertFromSliceObject(o,len,start,stop,step,slen) \ - PySlice_GetIndicesEx((PySliceObject *)(o), (len), (start), (stop), \ - (step), (slen)) -#endif - /* * The following are deprecated parts of the public API. diff --git a/siplib/siplib.c b/siplib/siplib.c index 242a1cb..ea9bbd1 100644 --- a/siplib/siplib.c +++ b/siplib/siplib.c @@ -656,19 +656,11 @@ static sipExportedModuleDef *isModuleLoaded(sipExportedModuleDef *table, /* * The Python module initialisation function. */ -#if PY_MAJOR_VERSION >= 3 #define SIP_MODULE_ENTRY PyInit_sip_tqt #define SIP_MODULE_TYPE PyObject * #define SIP_MODULE_DISCARD(m) Py_DECREF(m) #define SIP_FATAL(s) return NULL #define SIP_MODULE_RETURN(m) return (m) -#else -#define SIP_MODULE_ENTRY initsip_tqt -#define SIP_MODULE_TYPE void -#define SIP_MODULE_DISCARD(m) -#define SIP_FATAL(s) Py_FatalError(s) -#define SIP_MODULE_RETURN(m) -#endif #if defined(SIP_STATIC_MODULE) SIP_MODULE_TYPE SIP_MODULE_ENTRY(void) @@ -695,7 +687,6 @@ PyMODINIT_FUNC SIP_MODULE_ENTRY(void) {NULL, NULL, 0, NULL} }; -#if PY_MAJOR_VERSION >= 3 static PyModuleDef module_def = { PyModuleDef_HEAD_INIT, "sip_tqt", /* m_name */ @@ -707,7 +698,6 @@ PyMODINIT_FUNC SIP_MODULE_ENTRY(void) NULL, /* m_clear */ NULL, /* m_free */ }; -#endif int rc; PyObject *mod, *mod_dict, *obj; @@ -730,10 +720,8 @@ PyMODINIT_FUNC SIP_MODULE_ENTRY(void) #if defined(STACKLESS) sipWrapper_Type.super.tp_base = (PyTypeObject *)&sipSimpleWrapper_Type; -#elif PY_VERSION_HEX >= 0x02050000 - sipWrapper_Type.super.ht_type.tp_base = (PyTypeObject *)&sipSimpleWrapper_Type; #else - sipWrapper_Type.super.type.tp_base = (PyTypeObject *)&sipSimpleWrapper_Type; + sipWrapper_Type.super.ht_type.tp_base = (PyTypeObject *)&sipSimpleWrapper_Type; #endif if (PyType_Ready((PyTypeObject *)&sipWrapper_Type) < 0) @@ -753,11 +741,7 @@ PyMODINIT_FUNC SIP_MODULE_ENTRY(void) if (PyType_Ready(&sipVoidPtr_Type) < 0) SIP_FATAL("sip-tqt: Failed to initialise sip_tqt.voidptr type"); -#if PY_MAJOR_VERSION >= 3 mod = PyModule_Create(&module_def); -#else - mod = Py_InitModule("sip_tqt", methods); -#endif if (mod == NULL) SIP_FATAL("sip-tqt: Failed to intialise sip_tqt module"); @@ -775,11 +759,7 @@ PyMODINIT_FUNC SIP_MODULE_ENTRY(void) } /* Publish the SIP-TQt API. */ -#if defined(SIP_USE_PYCAPSULE) obj = PyCapsule_New((void *)&sip_api, "sip_tqt._C_API", NULL); -#else - obj = PyCObject_FromVoidPtr((void *)&sip_api, NULL); -#endif if (obj == NULL) { @@ -797,11 +777,7 @@ PyMODINIT_FUNC SIP_MODULE_ENTRY(void) } /* Add the SIP-TQt version number, but don't worry about errors. */ -#if PY_MAJOR_VERSION >= 3 obj = PyLong_FromLong(SIP_TQT_VERSION); -#else - obj = PyInt_FromLong(SIP_TQT_VERSION); -#endif if (obj != NULL) { @@ -809,11 +785,7 @@ PyMODINIT_FUNC SIP_MODULE_ENTRY(void) Py_DECREF(obj); } -#if PY_MAJOR_VERSION >= 3 obj = PyUnicode_FromString(SIP_TQT_VERSION_STR); -#else - obj = PyString_FromString(SIP_TQT_VERSION_STR); -#endif if (obj != NULL) { @@ -897,11 +869,7 @@ static PyObject *dumpWrapper(PyObject *self, PyObject *args) { print_object(NULL, (PyObject *)sw); -#if PY_VERSION_HEX >= 0x02050000 printf(" Reference count: %" PY_FORMAT_SIZE_T "d\n", Py_REFCNT(sw)); -#else - printf(" Reference count: %d\n", Py_REFCNT(sw)); -#endif printf(" Address of wrapped object: %p\n", sip_api_get_address(sw)); printf(" To be destroyed by: %s\n", (sipIsPyOwned(sw) ? "Python" : "C/C++")); printf(" Derived class?: %s\n", (sipIsDerived(sw) ? "yes" : "no")); @@ -1264,11 +1232,7 @@ static int sip_api_export_module(sipExportedModuleDef *client, } /* Convert the module name to an object. */ -#if PY_MAJOR_VERSION >= 3 client->em_nameobj = PyUnicode_FromString(full_name); -#else - client->em_nameobj = PyString_FromString(full_name); -#endif if (client->em_nameobj == NULL) return -1; @@ -1825,7 +1789,7 @@ static PyObject *buildObject(PyObject *obj, const char *fmt, va_list va) if (s != NULL) { - el = SIPBytes_FromStringAndSize(s, l); + el = PyBytes_FromStringAndSize(s, l); } else { @@ -1868,7 +1832,7 @@ static PyObject *buildObject(PyObject *obj, const char *fmt, va_list va) { char c = va_arg(va, int); - el = SIPBytes_FromStringAndSize(&c, 1); + el = PyBytes_FromStringAndSize(&c, 1); } break; @@ -1876,12 +1840,7 @@ static PyObject *buildObject(PyObject *obj, const char *fmt, va_list va) case 'a': { char c = va_arg(va, int); - -#if PY_MAJOR_VERSION >= 3 el = PyUnicode_FromStringAndSize(&c, 1); -#else - el = PyString_FromStringAndSize(&c, 1); -#endif } break; @@ -1931,11 +1890,7 @@ static PyObject *buildObject(PyObject *obj, const char *fmt, va_list va) case 'e': case 'h': case 'i': -#if PY_MAJOR_VERSION >= 3 el = PyLong_FromLong(va_arg(va, int)); -#else - el = PyInt_FromLong(va_arg(va, int)); -#endif break; case 'l': @@ -1968,7 +1923,7 @@ static PyObject *buildObject(PyObject *obj, const char *fmt, va_list va) if (s != NULL) { - el = SIPBytes_FromString(s); + el = PyBytes_FromString(s); } else { @@ -1984,11 +1939,7 @@ static PyObject *buildObject(PyObject *obj, const char *fmt, va_list va) char *s = va_arg(va, char *); if (s != NULL) -#if PY_MAJOR_VERSION >= 3 el = PyUnicode_FromString(s); -#else - el = PyString_FromString(s); -#endif else { Py_INCREF(Py_None); @@ -2221,7 +2172,7 @@ static int sip_api_parse_result(int *isErr, PyObject *method, PyObject *res, case 'b': { - int v = SIPLong_AsLong(arg); + int v = PyLong_AsLong(arg); if (PyErr_Occurred()) invalid = TRUE; @@ -2305,7 +2256,7 @@ static int sip_api_parse_result(int *isErr, PyObject *method, PyObject *res, int *p = va_arg(va, int *); if (sip_api_can_convert_to_enum(arg, ((sipEnumTypeObject *)et)->type)) - *p = SIPLong_AsLong(arg); + *p = PyLong_AsLong(arg); else invalid = TRUE; } @@ -2318,7 +2269,7 @@ static int sip_api_parse_result(int *isErr, PyObject *method, PyObject *res, int *p = va_arg(va, int *); if (sip_api_can_convert_to_enum(arg, td)) - *p = SIPLong_AsLong(arg); + *p = PyLong_AsLong(arg); else invalid = TRUE; } @@ -2339,7 +2290,7 @@ static int sip_api_parse_result(int *isErr, PyObject *method, PyObject *res, case 'h': { - short v = SIPLong_AsLong(arg); + short v = PyLong_AsLong(arg); if (PyErr_Occurred()) invalid = TRUE; @@ -2364,7 +2315,7 @@ static int sip_api_parse_result(int *isErr, PyObject *method, PyObject *res, case 'e': case 'i': { - int v = SIPLong_AsLong(arg); + int v = PyLong_AsLong(arg); if (PyErr_Occurred()) invalid = TRUE; @@ -2717,23 +2668,6 @@ static int sip_api_parse_result(int *isErr, PyObject *method, PyObject *res, */ static unsigned long sip_api_long_as_unsigned_long(PyObject *o) { -#if PY_VERSION_HEX < 0x02040000 - if (o != NULL && !PyLong_Check(o) && PyInt_Check(o)) - { - long v = PyInt_AsLong(o); - - if (v < 0) - { - PyErr_SetString(PyExc_OverflowError, - "can't convert negative value to unsigned long"); - - return (unsigned long)-1; - } - - return v; - } -#endif - return PyLong_AsUnsignedLong(o); } @@ -2881,13 +2815,8 @@ static int parseKwdArgs(PyObject **parseErrp, PyObject *sipArgs, */ static PyObject *bad_type_str(int arg_nr, PyObject *arg) { -#if PY_MAJOR_VERSION >= 3 return PyUnicode_FromFormat("argument %d has unexpected type '%s'", arg_nr, Py_TYPE(arg)->tp_name); -#else - return PyString_FromFormat("argument %d has unexpected type '%s'", arg_nr, - Py_TYPE(arg)->tp_name); -#endif } @@ -2950,7 +2879,6 @@ static void sip_api_add_exception(sipErrorState es, PyObject **parseErrp) /* * The dtor for parse failure wrapped in a Python object. */ -#if defined(SIP_USE_PYCAPSULE) static void failure_dtor(PyObject *capsule) { sipParseFailure *failure = (sipParseFailure *)PyCapsule_GetPointer(capsule, NULL); @@ -2959,16 +2887,6 @@ static void failure_dtor(PyObject *capsule) sip_api_free(failure); } -#else -static void failure_dtor(void *ptr) -{ - sipParseFailure *failure = (sipParseFailure *)ptr; - - Py_XDECREF(failure->detail_obj); - - sip_api_free(failure); -} -#endif /* @@ -2998,11 +2916,7 @@ static void add_failure(PyObject **parseErrp, sipParseFailure *failure) *failure_copy = *failure; -#if defined(SIP_USE_PYCAPSULE) failure_obj = PyCapsule_New(failure_copy, NULL, failure_dtor); -#else - failure_obj = PyCObject_FromVoidPtr(failure_copy, failure_dtor); -#endif if (failure_obj == NULL) { @@ -3218,11 +3132,7 @@ static int parsePass1(PyObject **parseErrp, sipSimpleWrapper **selfp, { int a; -#if PY_MAJOR_VERSION >= 3 if (!PyUnicode_Check(key)) -#else - if (!PyString_Check(key)) -#endif { failure.reason = KeywordNotString; failure.detail_obj = key; @@ -3240,11 +3150,7 @@ static int parsePass1(PyObject **parseErrp, sipSimpleWrapper **selfp, if (name == NULL) continue; -#if PY_MAJOR_VERSION >= 3 if (PyUnicode_CompareWithASCIIString(key, name) == 0) -#else - if (strcmp(PyString_AS_STRING(key), name) == 0) -#endif break; } } @@ -3368,11 +3274,7 @@ static int parsePass1(PyObject **parseErrp, sipSimpleWrapper **selfp, { int a; -#if PY_MAJOR_VERSION >= 3 if (!PyUnicode_Check(key)) -#else - if (!PyString_Check(key)) -#endif { failure.reason = KeywordNotString; failure.detail_obj = key; @@ -3390,11 +3292,7 @@ static int parsePass1(PyObject **parseErrp, sipSimpleWrapper **selfp, if (name == NULL) continue; -#if PY_MAJOR_VERSION >= 3 if (PyUnicode_CompareWithASCIIString(key, name) == 0) -#else - if (strcmp(PyString_AS_STRING(key), name) == 0) -#endif break; } } @@ -3535,9 +3433,9 @@ static int parsePass1(PyObject **parseErrp, sipSimpleWrapper **selfp, *sname = NULL; *scall = NULL; - if (SIPBytes_Check(arg)) + if (PyBytes_Check(arg)) { - char *s = SIPBytes_AS_STRING(arg); + char *s = PyBytes_AS_STRING(arg); if (*s == '1' || *s == '2' || *s == '9') { @@ -3573,9 +3471,9 @@ static int parsePass1(PyObject **parseErrp, sipSimpleWrapper **selfp, if (arg != NULL) { - if (SIPBytes_Check(arg)) + if (PyBytes_Check(arg)) { - char *s = SIPBytes_AS_STRING(arg); + char *s = PyBytes_AS_STRING(arg); if (*s == '1' || *s == '2' || *s == '9') { @@ -3607,9 +3505,9 @@ static int parsePass1(PyObject **parseErrp, sipSimpleWrapper **selfp, if (arg != NULL) { - if (SIPBytes_Check(arg)) + if (PyBytes_Check(arg)) { - char *s = SIPBytes_AS_STRING(arg); + char *s = PyBytes_AS_STRING(arg); if (*s == '2' || *s == '9') { @@ -4011,7 +3909,7 @@ static int parsePass1(PyObject **parseErrp, sipSimpleWrapper **selfp, if (arg != NULL) { - int v = SIPLong_AsLong(arg); + int v = PyLong_AsLong(arg); if (PyErr_Occurred()) { @@ -4055,7 +3953,7 @@ static int parsePass1(PyObject **parseErrp, sipSimpleWrapper **selfp, if (arg != NULL) { - int v = SIPLong_AsLong(arg); + int v = PyLong_AsLong(arg); if (PyErr_Occurred()) { @@ -4105,7 +4003,7 @@ static int parsePass1(PyObject **parseErrp, sipSimpleWrapper **selfp, if (arg != NULL) { - short v = SIPLong_AsLong(arg); + short v = PyLong_AsLong(arg); if (PyErr_Occurred()) { @@ -4375,17 +4273,10 @@ static int parsePass1(PyObject **parseErrp, sipSimpleWrapper **selfp, { /* Integer. */ -#if PY_MAJOR_VERSION >= 3 if (PyLong_Check(arg)) { *(int *)p = PyLong_AS_LONG(arg); } -#else - if (PyInt_Check(arg)) - { - *(int *)p = PyInt_AS_LONG(arg); - } -#endif else { failure.reason = WrongType; @@ -4788,7 +4679,7 @@ static int parsePass2(sipSimpleWrapper *self, int selfarg, PyObject *sipArgs, int *p = va_arg(va, int *); if (arg != NULL) - *p = SIPLong_AsLong(arg); + *p = PyLong_AsLong(arg); } break; @@ -4804,7 +4695,7 @@ static int parsePass2(sipSimpleWrapper *self, int selfarg, PyObject *sipArgs, p = va_arg(va, int *); if (arg != NULL) - *p = SIPLong_AsLong(arg); + *p = PyLong_AsLong(arg); break; } @@ -5161,12 +5052,7 @@ static PyObject *getDefaultBases(void) /* Only do this once. */ if (default_bases == NULL) { -#if PY_VERSION_HEX >= 0x02040000 default_bases = PyTuple_Pack(1, (PyObject *)&sipWrapper_Type); -#else - default_bases = Py_BuildValue("(O)", &sipWrapper_Type); -#endif - if (default_bases == NULL) return NULL; } @@ -5227,21 +5113,13 @@ static PyObject *createContainerType(sipContainerDef *cod, sipTypeDef *td, goto reterr; /* Create an object corresponding to the type name. */ -#if PY_MAJOR_VERSION >= 3 name = PyUnicode_FromString(sipPyNameOfContainer(cod, td)); -#else - name = PyString_FromString(sipPyNameOfContainer(cod, td)); -#endif if (name == NULL) goto reldict; /* Create the type by calling the metatype. */ -#if PY_VERSION_HEX >= 0x02040000 args = PyTuple_Pack(3, name, bases, typedict); -#else - args = Py_BuildValue("OOO", name, bases, typedict); -#endif if (args == NULL) goto relname; @@ -5314,11 +5192,7 @@ static int createClassType(sipExportedModuleDef *client, sipClassTypeDef *ctd, if ((supertype = findPyType(supertype_name)) == NULL) goto reterr; -#if PY_VERSION_HEX >= 0x02040000 bases = PyTuple_Pack(1, supertype); -#else - bases = Py_BuildValue("(O)", supertype); -#endif } if (bases == NULL) @@ -5453,24 +5327,15 @@ static sipExportedModuleDef *getModule(PyObject *mname_obj) /* Find the module definition. */ for (em = moduleList; em != NULL; em = em->em_next) -#if PY_MAJOR_VERSION >= 3 if (PyUnicode_Compare(mname_obj, em->em_nameobj) == 0) -#else - if (strcmp(PyString_AS_STRING(mname_obj), sipNameOfModule(em)) == 0) -#endif break; Py_DECREF(mod); if (em == NULL) { -#if PY_MAJOR_VERSION >= 3 PyErr_Format(PyExc_SystemError, "unable to find to find module: %U", mname_obj); -#else - PyErr_Format(PyExc_SystemError, "unable to find to find module: %s", - PyString_AS_STRING(mname_obj)); -#endif } return em; @@ -5488,11 +5353,7 @@ static PyObject *unpickle_type(PyObject *ignore, PyObject *args) int i; if (!PyArg_ParseTuple(args, -#if PY_MAJOR_VERSION >= 3 "UsO!:_unpickle_type", -#else - "SsO!:_unpickle_type", -#endif &mname_obj, &tname, &PyTuple_Type, &init_args)) return NULL; @@ -5584,11 +5445,7 @@ static PyObject *unpickle_enum(PyObject *ignore, PyObject *args) int i; if (!PyArg_ParseTuple(args, -#if PY_MAJOR_VERSION >= 3 "UsO:_unpickle_enum", -#else - "SsO:_unpickle_enum", -#endif &mname_obj, &ename, &evalue_obj)) return NULL; @@ -5621,12 +5478,7 @@ static PyObject *pickle_enum(PyObject *obj, PyObject *ignore) return Py_BuildValue("O(Osi)", enum_unpickler, td->td_module->em_nameobj, sipPyNameOfEnum((sipEnumTypeDef *)td), -#if PY_MAJOR_VERSION >= 3 - (int)PyLong_AS_LONG(obj) -#else - (int)PyInt_AS_LONG(obj) -#endif - ); + (int)PyLong_AS_LONG(obj)); } @@ -5679,24 +5531,14 @@ static int createEnumType(sipExportedModuleDef *client, sipEnumTypeDef *etd, /* Create the base type tuple if it hasn't already been done. */ if (bases == NULL) { -#if PY_MAJOR_VERSION >= 3 bases = PyTuple_Pack(1, (PyObject *)&PyLong_Type); -#elif PY_VERSION_HEX >= 0x02040000 - bases = PyTuple_Pack(1, (PyObject *)&PyInt_Type); -#else - bases = Py_BuildValue("(O)", &PyInt_Type); -#endif if (bases == NULL) goto reterr; } /* Create an object corresponding to the type name. */ -#if PY_MAJOR_VERSION >= 3 name = PyUnicode_FromString(sipPyNameOfEnum(etd)); -#else - name = PyString_FromString(sipPyNameOfEnum(etd)); -#endif if (name == NULL) goto reterr; @@ -5706,11 +5548,7 @@ static int createEnumType(sipExportedModuleDef *client, sipEnumTypeDef *etd, goto relname; /* Create the type by calling the metatype. */ -#if PY_VERSION_HEX >= 0x02040000 args = PyTuple_Pack(3, name, bases, typedict); -#else - args = Py_BuildValue("OOO", name, bases, typedict); -#endif Py_DECREF(typedict); @@ -5784,11 +5622,7 @@ static int objectify(const char *s, PyObject **objp) { if (*objp == NULL) { -#if PY_MAJOR_VERSION >= 3 *objp = PyUnicode_FromString(s); -#else - *objp = PyString_FromString(s); -#endif if (*objp == NULL) return -1; @@ -6074,11 +5908,7 @@ static int sip_api_can_convert_to_enum(PyObject *obj, const sipTypeDef *td) if (PyObject_TypeCheck((PyObject *)Py_TYPE(obj), &sipEnumType_Type)) return (PyObject_TypeCheck(obj, sipTypeAsPyTypeObject(td))); -#if PY_MAJOR_VERSION >= 3 return PyLong_Check(obj); -#else - return PyInt_Check(obj); -#endif } @@ -6088,11 +5918,7 @@ static int sip_api_can_convert_to_enum(PyObject *obj, const sipTypeDef *td) static PyObject *createEnumMember(sipTypeDef *td, sipEnumMemberDef *enm) { if (enm->em_enum < 0) -#if PY_MAJOR_VERSION >= 3 return PyLong_FromLong(enm->em_val); -#else - return PyInt_FromLong(enm->em_val); -#endif return sip_api_convert_from_enum(enm->em_val, td->td_module->em_types[enm->em_enum]); @@ -6180,13 +6006,7 @@ static void sip_api_no_method(PyObject *parseErr, const char *scope, if (doc_obj != NULL) { -#if PY_MAJOR_VERSION >= 3 exc = PyUnicode_FromFormat("%U: %U", doc_obj, detail); -#else - exc = PyString_FromFormat("%s: %s", - PyString_AS_STRING(doc_obj), - PyString_AS_STRING(detail)); -#endif Py_DECREF(doc_obj); } @@ -6197,13 +6017,8 @@ static void sip_api_no_method(PyObject *parseErr, const char *scope, } else { -#if PY_MAJOR_VERSION >= 3 exc = PyUnicode_FromFormat("%s%s%s(): %U", scope, sep, method, detail); -#else - exc = PyString_FromFormat("%s%s%s(): %s", scope, sep, - method, PyString_AS_STRING(detail)); -#endif } Py_DECREF(detail); @@ -6221,21 +6036,12 @@ static void sip_api_no_method(PyObject *parseErr, const char *scope, if (doc != NULL) { -#if PY_MAJOR_VERSION >= 3 exc = PyUnicode_FromString(summary); -#else - exc = PyString_FromString(summary); -#endif } else { -#if PY_MAJOR_VERSION >= 3 exc = PyUnicode_FromFormat("%s%s%s(): %s", scope, sep, method, summary); -#else - exc = PyString_FromFormat("%s%s%s(): %s", scope, sep, method, - summary); -#endif } for (i = 0; i < PyList_GET_SIZE(parseErr); ++i) @@ -6252,14 +6058,8 @@ static void sip_api_no_method(PyObject *parseErr, const char *scope, if (doc_obj != NULL) { -#if PY_MAJOR_VERSION >= 3 failure = PyUnicode_FromFormat("\n %U: %U", doc_obj, detail); -#else - failure = PyString_FromFormat("\n %s: %s", - PyString_AS_STRING(doc_obj), - PyString_AS_STRING(detail)); -#endif Py_DECREF(doc_obj); } @@ -6272,25 +6072,13 @@ static void sip_api_no_method(PyObject *parseErr, const char *scope, } else { -#if PY_MAJOR_VERSION >= 3 failure = PyUnicode_FromFormat("\n overload %zd: %U", i + 1, detail); -#elif PY_VERSION_HEX >= 0x02050000 - failure = PyString_FromFormat("\n overload %zd: %s", - i + 1, PyString_AS_STRING(detail)); -#else - failure = PyString_FromFormat("\n overload %d: %s", - i + 1, PyString_AS_STRING(detail)); -#endif } Py_DECREF(detail); -#if PY_MAJOR_VERSION >= 3 PyUnicode_AppendAndDel(&exc, failure); -#else - PyString_ConcatAndDel(&exc, failure); -#endif } else { @@ -6351,11 +6139,7 @@ static PyObject *signature_FromDocstring(const char *doc, SIP_SSIZE_T line) if (*eol == ')') size = eol - doc + 1; -#if PY_MAJOR_VERSION >= 3 return PyUnicode_FromStringAndSize(doc, size); -#else - return PyString_FromStringAndSize(doc, size); -#endif } @@ -6367,87 +6151,39 @@ static PyObject *detail_FromFailure(PyObject *failure_obj) sipParseFailure *failure; PyObject *detail; -#if defined(SIP_USE_PYCAPSULE) failure = (sipParseFailure *)PyCapsule_GetPointer(failure_obj, NULL); -#else - failure = (sipParseFailure *)PyCObject_AsVoidPtr(failure_obj); -#endif switch (failure->reason) { case Unbound: -#if PY_MAJOR_VERSION >= 3 detail = PyUnicode_FromFormat( "first argument of unbound method must have type '%s'", failure->detail_str); -#else - detail = PyString_FromFormat( - "first argument of unbound method must have type '%s'", - failure->detail_str); -#endif break; case TooFew: -#if PY_MAJOR_VERSION >= 3 detail = PyUnicode_FromString("not enough arguments"); -#else - detail = PyString_FromString("not enough arguments"); -#endif break; case TooMany: -#if PY_MAJOR_VERSION >= 3 detail = PyUnicode_FromString("too many arguments"); -#else - detail = PyString_FromString("too many arguments"); -#endif break; case KeywordNotString: -#if PY_MAJOR_VERSION >= 3 detail = PyUnicode_FromFormat( "%S keyword argument name is not a string", failure->detail_obj); -#else - { - PyObject *str = PyObject_Str(failure->detail_obj); - - if (str != NULL) - { - detail = PyString_FromFormat( - "%s keyword argument name is not a string", - PyString_AsString(str)); - - Py_DECREF(str); - } - else - { - detail = NULL; - } - } -#endif break; case UnknownKeyword: -#if PY_MAJOR_VERSION >= 3 detail = PyUnicode_FromFormat("'%U' is not a valid keyword argument", failure->detail_obj); -#else - detail = PyString_FromFormat("'%s' is not a valid keyword argument", - PyString_AS_STRING(failure->detail_obj)); -#endif break; case Duplicate: -#if PY_MAJOR_VERSION >= 3 detail = PyUnicode_FromFormat( "'%U' has already been given as a positional argument", failure->detail_obj); -#else - detail = PyString_FromFormat( - "'%s' has already been given as a positional argument", - PyString_AS_STRING(failure->detail_obj)); -#endif break; case WrongType: @@ -6457,15 +6193,9 @@ static PyObject *detail_FromFailure(PyObject *failure_obj) } else { -#if PY_MAJOR_VERSION >= 3 detail = PyUnicode_FromFormat( "keyword argument '%s' has unexpected type '%s'", failure->arg_name, Py_TYPE(failure->detail_obj)->tp_name); -#else - detail = PyString_FromFormat( - "keyword argument '%s' has unexpected type '%s'", - failure->arg_name, Py_TYPE(failure->detail_obj)->tp_name); -#endif } break; @@ -6482,11 +6212,7 @@ static PyObject *detail_FromFailure(PyObject *failure_obj) /* Drop through. */ default: -#if PY_MAJOR_VERSION >= 3 detail = PyUnicode_FromString("unknown reason"); -#else - detail = PyString_FromString("unknown reason"); -#endif } return detail; @@ -6520,11 +6246,7 @@ static int sip_api_deprecated(const char *classname, const char *method) PyOS_snprintf(buf, sizeof (buf), "%s.%s() is deprecated", classname, method); -#if PY_VERSION_HEX >= 0x02050000 return PyErr_WarnEx(PyExc_DeprecationWarning, buf, 1); -#else - return PyErr_Warn(PyExc_DeprecationWarning, buf); -#endif } @@ -6574,11 +6296,7 @@ static void sip_api_bad_length_for_slice(SIP_SSIZE_T seqlen, SIP_SSIZE_T slicelen) { PyErr_Format(PyExc_ValueError, -#if PY_VERSION_HEX >= 0x02050000 "attempt to assign sequence of size %zd to slice of size %zd", -#else - "attempt to assign sequence of size %d to slice of size %d", -#endif seqlen, slicelen); } @@ -6616,14 +6334,8 @@ static void sip_api_bad_catcher_result(PyObject *method) mname = ((PyFunctionObject *)PyMethod_GET_FUNCTION(method))->func_name; -#if PY_MAJOR_VERSION >= 3 PyErr_Format(PyExc_TypeError, "invalid result type from %s.%U()", Py_TYPE(PyMethod_GET_SELF(method))->tp_name, mname); -#else - PyErr_Format(PyExc_TypeError, "invalid result type from %s.%s()", - Py_TYPE(PyMethod_GET_SELF(method))->tp_name, - PyString_AsString(mname)); -#endif } @@ -6746,11 +6458,7 @@ static int addLicense(PyObject *dict,sipLicenseDef *lc) if (lc->lc_type == NULL) goto deldict; -#if PY_MAJOR_VERSION >= 3 o = PyUnicode_FromString(lc->lc_type); -#else - o = PyString_FromString(lc->lc_type); -#endif if (o == NULL) goto deldict; @@ -6763,11 +6471,7 @@ static int addLicense(PyObject *dict,sipLicenseDef *lc) if (lc->lc_licensee != NULL) { -#if PY_MAJOR_VERSION >= 3 o = PyUnicode_FromString(lc->lc_licensee); -#else - o = PyString_FromString(lc->lc_licensee); -#endif if (o == NULL) goto deldict; @@ -6781,11 +6485,7 @@ static int addLicense(PyObject *dict,sipLicenseDef *lc) if (lc->lc_timestamp != NULL) { -#if PY_MAJOR_VERSION >= 3 o = PyUnicode_FromString(lc->lc_timestamp); -#else - o = PyString_FromString(lc->lc_timestamp); -#endif if (o == NULL) goto deldict; @@ -6799,11 +6499,7 @@ static int addLicense(PyObject *dict,sipLicenseDef *lc) if (lc->lc_signature != NULL) { -#if PY_MAJOR_VERSION >= 3 o = PyUnicode_FromString(lc->lc_signature); -#else - o = PyString_FromString(lc->lc_signature); -#endif if (o == NULL) goto deldict; @@ -6880,15 +6576,11 @@ static int addCharInstances(PyObject *dict, sipCharInstanceDef *ci) break; case '8': -#if PY_MAJOR_VERSION >= 3 w = PyUnicode_FromStringAndSize(&ci->ci_val, 1); -#else - w = PyUnicode_DecodeUTF8(&ci->ci_val, 1, NULL); -#endif break; default: - w = SIPBytes_FromStringAndSize(&ci->ci_val, 1); + w = PyBytes_FromStringAndSize(&ci->ci_val, 1); } if (w == NULL) @@ -6928,15 +6620,11 @@ static int addStringInstances(PyObject *dict, sipStringInstanceDef *si) break; case '8': -#if PY_MAJOR_VERSION >= 3 w = PyUnicode_FromString(si->si_val); -#else - w = PyUnicode_DecodeUTF8(si->si_val, strlen(si->si_val), NULL); -#endif break; default: - w = SIPBytes_FromString(si->si_val); + w = PyBytes_FromString(si->si_val); } if (w == NULL) @@ -6965,11 +6653,7 @@ static int addIntInstances(PyObject *dict, sipIntInstanceDef *ii) int rc; PyObject *w; -#if PY_MAJOR_VERSION >= 3 w = PyLong_FromLong(ii->ii_val); -#else - w = PyInt_FromLong(ii->ii_val); -#endif if (w == NULL) return -1; @@ -7237,11 +6921,7 @@ static PyObject *sip_api_is_py_method(sip_gilstate_t *gil, char *pymc, *gil = PyGILState_Ensure(); #endif -#if PY_MAJOR_VERSION >= 3 mname_obj = PyUnicode_FromString(mname); -#else - mname_obj = PyString_FromString(mname); -#endif if (mname_obj == NULL) { @@ -7280,16 +6960,7 @@ static PyObject *sip_api_is_py_method(sip_gilstate_t *gil, char *pymc, PyObject *cls_dict; cls = PyTuple_GET_ITEM(mro, i); - -#if PY_MAJOR_VERSION >= 3 cls_dict = ((PyTypeObject *)cls)->tp_dict; -#else - // Allow for classic classes as mixins. - if (PyClass_Check(cls)) - cls_dict = ((PyClassObject *)cls)->cl_dict; - else - cls_dict = ((PyTypeObject *)cls)->tp_dict; -#endif if (cls_dict != NULL && (reimp = PyDict_GetItem(cls_dict, mname_obj)) != NULL) { @@ -7306,13 +6977,8 @@ static PyObject *sip_api_is_py_method(sip_gilstate_t *gil, char *pymc, } else { -#if PY_MAJOR_VERSION >= 3 reimp = PyMethod_New(PyMethod_GET_FUNCTION(reimp), (PyObject *)sipSelf); -#else - reimp = PyMethod_New(PyMethod_GET_FUNCTION(reimp), - (PyObject *)sipSelf, PyMethod_GET_CLASS(reimp)); -#endif } break; @@ -7320,12 +6986,7 @@ static PyObject *sip_api_is_py_method(sip_gilstate_t *gil, char *pymc, if (PyFunction_Check(reimp)) { -#if PY_MAJOR_VERSION >= 3 reimp = PyMethod_New(reimp, (PyObject *)sipSelf); -#else - reimp = PyMethod_New(reimp, (PyObject *)sipSelf, cls); -#endif - break; } @@ -7498,11 +7159,7 @@ static void sip_api_keep_reference(PyObject *self, int key, PyObject *obj) ((sipSimpleWrapper *)self)->extra_refs = dict; } -#if PY_MAJOR_VERSION >= 3 key_obj = PyLong_FromLong(key); -#else - key_obj = PyInt_FromLong(key); -#endif if (key_obj != NULL) { @@ -7949,9 +7606,6 @@ void sipSaveMethod(sipPyMethod *pm, PyObject *meth) { pm->mfunc = PyMethod_GET_FUNCTION(meth); pm->mself = PyMethod_GET_SELF(meth); -#if PY_MAJOR_VERSION < 3 - pm->mclass = PyMethod_GET_CLASS(meth); -#endif } @@ -8299,11 +7953,7 @@ static int objobjargprocSlot(PyObject *self, PyObject *arg1, PyObject *arg2, } else { -#if PY_VERSION_HEX >= 0x02040000 args = PyTuple_Pack(2, arg1, arg2); -#else - args = Py_BuildValue("(OO)", arg1, arg2); -#endif if (args == NULL) return -1; @@ -8342,19 +7992,9 @@ static int ssizeobjargprocSlot(PyObject *self, SIP_SSIZE_T arg1, * optional. */ if (arg2 == NULL) -#if PY_MAJOR_VERSION >= 3 args = PyLong_FromSsize_t(arg1); -#elif PY_VERSION_HEX >= 0x02050000 - args = PyInt_FromSsize_t(arg1); -#else - args = PyInt_FromLong(arg1); -#endif - else -#if PY_VERSION_HEX >= 0x02050000 + else args = Py_BuildValue("(nO)", arg1, arg2); -#else - args = Py_BuildValue("(iO)", arg1, arg2); -#endif if (args == NULL) return -1; @@ -8819,7 +8459,6 @@ static int sipSimpleWrapper_clear(sipSimpleWrapper *self) } -#if PY_MAJOR_VERSION >= 3 /* * The instance get buffer slot for Python v3. */ @@ -8834,10 +8473,8 @@ static int sipSimpleWrapper_getbuffer(sipSimpleWrapper *self, Py_buffer *buf, return ctd->ctd_getbuffer((PyObject *)self, ptr, buf, flags); } -#endif -#if PY_MAJOR_VERSION >= 3 /* * The instance release buffer slot for Python v3. */ @@ -8852,79 +8489,6 @@ static void sipSimpleWrapper_releasebuffer(sipSimpleWrapper *self, return ctd->ctd_releasebuffer((PyObject *)self, ptr, buf); } -#endif - - -#if PY_MAJOR_VERSION < 3 -/* - * The instance read buffer slot for Python v2. - */ -static SIP_SSIZE_T sipSimpleWrapper_getreadbuffer(sipSimpleWrapper *self, - SIP_SSIZE_T segment, void **ptrptr) -{ - void *ptr; - const sipClassTypeDef *ctd; - - if ((ptr = getPtrTypeDef(self, &ctd)) == NULL) - return -1; - - return ctd->ctd_readbuffer((PyObject *)self, ptr, segment, ptrptr); -} -#endif - - -#if PY_MAJOR_VERSION < 3 -/* - * The instance write buffer slot for Python v2. - */ -static SIP_SSIZE_T sipSimpleWrapper_getwritebuffer(sipSimpleWrapper *self, - SIP_SSIZE_T segment, void **ptrptr) -{ - void *ptr; - const sipClassTypeDef *ctd; - - if ((ptr = getPtrTypeDef(self, &ctd)) == NULL) - return -1; - - return ctd->ctd_writebuffer((PyObject *)self, ptr, segment, ptrptr); -} -#endif - - -#if PY_MAJOR_VERSION < 3 -/* - * The instance segment count slot for Python v2. - */ -static SIP_SSIZE_T sipSimpleWrapper_getsegcount(sipSimpleWrapper *self, - SIP_SSIZE_T *lenp) -{ - void *ptr; - const sipClassTypeDef *ctd; - - if ((ptr = getPtrTypeDef(self, &ctd)) == NULL) - return 0; - - return ctd->ctd_segcount((PyObject *)self, ptr, lenp); -} -#endif - - -#if PY_MAJOR_VERSION < 3 -/* - * The instance char buffer slot for Python v2. - */ -static SIP_SSIZE_T sipSimpleWrapper_getcharbuffer(sipSimpleWrapper *self, - SIP_SSIZE_T segment, void **ptrptr) -{ - void *ptr; - const sipClassTypeDef *ctd; - - if ((ptr = getPtrTypeDef(self, &ctd)) == NULL) - return -1; - - return ctd->ctd_charbuffer((PyObject *)self, ptr, segment, ptrptr); -} -#endif /* @@ -8969,14 +8533,7 @@ static PyObject *slot_sq_item(PyObject *self, SIP_SSIZE_T n) PyObject *(*f)(PyObject *,PyObject *); PyObject *arg, *res; -#if PY_MAJOR_VERSION >= 3 arg = PyLong_FromSsize_t(n); -#elif PY_VERSION_HEX >= 0x02050000 - arg = PyInt_FromSsize_t(n); -#else - arg = PyInt_FromLong(n); -#endif - if (arg == NULL) return NULL; @@ -9323,41 +8880,11 @@ static int sipWrapper_traverse(sipWrapper *self, visitproc visit, void *arg) static void addClassSlots(sipWrapperType *wt, sipClassTypeDef *ctd) { /* Add the buffer interface. */ -#if PY_MAJOR_VERSION >= 3 if (ctd->ctd_getbuffer != NULL) wt->super.as_buffer.bf_getbuffer = (getbufferproc)sipSimpleWrapper_getbuffer; if (ctd->ctd_releasebuffer != NULL) wt->super.as_buffer.bf_releasebuffer = (releasebufferproc)sipSimpleWrapper_releasebuffer; -#else - if (ctd->ctd_readbuffer != NULL) -#if PY_VERSION_HEX >= 0x02050000 - wt->super.as_buffer.bf_getreadbuffer = (readbufferproc)sipSimpleWrapper_getreadbuffer; -#else - wt->super.as_buffer.bf_getreadbuffer = (getreadbufferproc)sipSimpleWrapper_getreadbuffer; -#endif - - if (ctd->ctd_writebuffer != NULL) -#if PY_VERSION_HEX >= 0x02050000 - wt->super.as_buffer.bf_getwritebuffer = (writebufferproc)sipSimpleWrapper_getwritebuffer; -#else - wt->super.as_buffer.bf_getwritebuffer = (getwritebufferproc)sipSimpleWrapper_getwritebuffer; -#endif - - if (ctd->ctd_segcount != NULL) -#if PY_VERSION_HEX >= 0x02050000 - wt->super.as_buffer.bf_getsegcount = (segcountproc)sipSimpleWrapper_getsegcount; -#else - wt->super.as_buffer.bf_getsegcount = (getsegcountproc)sipSimpleWrapper_getsegcount; -#endif - - if (ctd->ctd_charbuffer != NULL) -#if PY_VERSION_HEX >= 0x02050000 - wt->super.as_buffer.bf_getcharbuffer = (charbufferproc)sipSimpleWrapper_getcharbuffer; -#else - wt->super.as_buffer.bf_getcharbuffer = (getcharbufferproc)sipSimpleWrapper_getcharbuffer; -#endif -#endif /* Add the slots for this type. */ if (ctd->ctd_pyslots != NULL) @@ -9393,13 +8920,6 @@ static void addTypeSlots(PyHeapTypeObject *heap_to, sipPySlotDef *slots) nb->nb_int = (unaryfunc)f; break; -#if PY_MAJOR_VERSION < 3 - case long_slot: - if (nb != NULL) - nb->nb_long = (unaryfunc)f; - break; -#endif - case float_slot: if (nb != NULL) nb->nb_float = (unaryfunc)f; @@ -9407,17 +8927,9 @@ static void addTypeSlots(PyHeapTypeObject *heap_to, sipPySlotDef *slots) case len_slot: if (mp != NULL) -#if PY_VERSION_HEX >= 0x02050000 mp->mp_length = (lenfunc)f; -#else - mp->mp_length = (inquiry)f; -#endif if (sq != NULL) -#if PY_VERSION_HEX >= 0x02050000 sq->sq_length = (lenfunc)f; -#else - sq->sq_length = (inquiry)f; -#endif break; case contains_slot: @@ -9447,20 +8959,13 @@ static void addTypeSlots(PyHeapTypeObject *heap_to, sipPySlotDef *slots) case repeat_slot: if (sq != NULL) -#if PY_VERSION_HEX >= 0x02050000 sq->sq_repeat = (ssizeargfunc)f; -#else - sq->sq_repeat = (intargfunc)f; -#endif break; case div_slot: if (nb != NULL) { nb->nb_true_divide = (binaryfunc)f; -#if PY_MAJOR_VERSION < 3 - nb->nb_divide = (binaryfunc)f; -#endif } break; @@ -9526,20 +9031,13 @@ static void addTypeSlots(PyHeapTypeObject *heap_to, sipPySlotDef *slots) case irepeat_slot: if (sq != NULL) -#if PY_VERSION_HEX >= 0x02050000 sq->sq_inplace_repeat = (ssizeargfunc)f; -#else - sq->sq_inplace_repeat = (intargfunc)f; -#endif break; case idiv_slot: if (nb != NULL) { nb->nb_inplace_true_divide = (binaryfunc)f; -#if PY_MAJOR_VERSION < 3 - nb->nb_inplace_divide = (binaryfunc)f; -#endif } break; @@ -9616,19 +9114,9 @@ static void addTypeSlots(PyHeapTypeObject *heap_to, sipPySlotDef *slots) to->tp_richcompare = slot_richcompare; break; -#if PY_MAJOR_VERSION < 3 - case cmp_slot: - to->tp_compare = (cmpfunc)f; - break; -#endif - case bool_slot: if (nb != NULL) -#if PY_MAJOR_VERSION >= 3 nb->nb_bool = (inquiry)f; -#else - nb->nb_nonzero = (inquiry)f; -#endif break; case neg_slot: @@ -9654,12 +9142,10 @@ static void addTypeSlots(PyHeapTypeObject *heap_to, sipPySlotDef *slots) nb->nb_absolute = (unaryfunc)f; break; -#if PY_VERSION_HEX >= 0x02050000 case index_slot: if (nb != NULL) nb->nb_index = (unaryfunc)f; break; -#endif case iter_slot: to->tp_iter = (getiterfunc)f; @@ -9856,11 +9342,7 @@ static char sip_api_bytes_as_char(PyObject *obj) if (parseBytes_AsChar(obj, &ch) < 0) { PyErr_Format(PyExc_TypeError, -#if PY_MAJOR_VERSION >= 3 "bytes of length 1 expected not '%s'", -#else - "string of length 1 expected not '%s'", -#endif Py_TYPE(obj)->tp_name); return '\0'; @@ -9881,11 +9363,7 @@ static const char *sip_api_bytes_as_string(PyObject *obj) if (parseBytes_AsString(obj, &a) < 0) { PyErr_Format(PyExc_TypeError, -#if PY_MAJOR_VERSION >= 3 "bytes expected not '%s'", -#else - "string expected not '%s'", -#endif Py_TYPE(obj)->tp_name); return NULL; @@ -9908,11 +9386,7 @@ static char sip_api_string_as_ascii_char(PyObject *obj) /* Use the exception set if it was an encoding error. */ if (!PyUnicode_Check(obj) || PyUnicode_GET_SIZE(obj) != 1) PyErr_Format(PyExc_TypeError, -#if PY_MAJOR_VERSION >= 3 "bytes or ASCII string of length 1 expected not '%s'", -#else - "string or ASCII unicode of length 1 expected not '%s'", -#endif Py_TYPE(obj)->tp_name); return '\0'; @@ -9944,11 +9418,7 @@ static char sip_api_string_as_latin1_char(PyObject *obj) /* Use the exception set if it was an encoding error. */ if (!PyUnicode_Check(obj) || PyUnicode_GET_SIZE(obj) != 1) PyErr_Format(PyExc_TypeError, -#if PY_MAJOR_VERSION >= 3 "bytes or Latin-1 string of length 1 expected not '%s'", -#else - "string or Latin-1 unicode of length 1 expected not '%s'", -#endif Py_TYPE(obj)->tp_name); return '\0'; @@ -9980,11 +9450,7 @@ static char sip_api_string_as_utf8_char(PyObject *obj) /* Use the exception set if it was an encoding error. */ if (!PyUnicode_Check(obj) || PyUnicode_GET_SIZE(obj) != 1) PyErr_Format(PyExc_TypeError, -#if PY_MAJOR_VERSION >= 3 "bytes or UTF-8 string of length 1 expected not '%s'", -#else - "string or UTF-8 unicode of length 1 expected not '%s'", -#endif Py_TYPE(obj)->tp_name); return '\0'; @@ -10017,7 +9483,7 @@ static int parseString_AsEncodedChar(PyObject *bytes, PyObject *obj, char *ap) return parseBytes_AsChar(obj, ap); } - size = SIPBytes_GET_SIZE(bytes); + size = PyBytes_GET_SIZE(bytes); if (size != 1) { @@ -10025,7 +9491,7 @@ static int parseString_AsEncodedChar(PyObject *bytes, PyObject *obj, char *ap) return -1; } - *ap = *SIPBytes_AS_STRING(bytes); + *ap = *PyBytes_AS_STRING(bytes); Py_DECREF(bytes); @@ -10048,11 +9514,7 @@ static const char *sip_api_string_as_ascii_string(PyObject **obj) /* Use the exception set if it was an encoding error. */ if (!PyUnicode_Check(s)) PyErr_Format(PyExc_TypeError, -#if PY_MAJOR_VERSION >= 3 "bytes or ASCII string expected not '%s'", -#else - "string or ASCII unicode expected not '%s'", -#endif Py_TYPE(s)->tp_name); return NULL; @@ -10087,11 +9549,7 @@ static const char *sip_api_string_as_latin1_string(PyObject **obj) /* Use the exception set if it was an encoding error. */ if (!PyUnicode_Check(s)) PyErr_Format(PyExc_TypeError, -#if PY_MAJOR_VERSION >= 3 "bytes or Latin-1 string expected not '%s'", -#else - "string or Latin-1 unicode expected not '%s'", -#endif Py_TYPE(s)->tp_name); return NULL; @@ -10126,11 +9584,7 @@ static const char *sip_api_string_as_utf8_string(PyObject **obj) /* Use the exception set if it was an encoding error. */ if (!PyUnicode_Check(s)) PyErr_Format(PyExc_TypeError, -#if PY_MAJOR_VERSION >= 3 "bytes or UTF-8 string expected not '%s'", -#else - "string or UTF-8 unicode expected not '%s'", -#endif Py_TYPE(s)->tp_name); return NULL; @@ -10159,7 +9613,7 @@ static PyObject *parseString_AsEncodedString(PyObject *bytes, PyObject *obj, { if (bytes != NULL) { - *ap = SIPBytes_AS_STRING(bytes); + *ap = PyBytes_AS_STRING(bytes); return bytes; } @@ -10186,10 +9640,10 @@ static int parseBytes_AsCharArray(PyObject *obj, const char **ap, *ap = NULL; *aszp = 0; } - else if (SIPBytes_Check(obj)) + else if (PyBytes_Check(obj)) { - *ap = SIPBytes_AS_STRING(obj); - *aszp = SIPBytes_GET_SIZE(obj); + *ap = PyBytes_AS_STRING(obj); + *aszp = PyBytes_GET_SIZE(obj); } else if (PyObject_AsCharBuffer(obj, ap, aszp) < 0) return -1; @@ -10206,10 +9660,10 @@ static int parseBytes_AsChar(PyObject *obj, char *ap) const char *chp; SIP_SSIZE_T sz; - if (SIPBytes_Check(obj)) + if (PyBytes_Check(obj)) { - chp = SIPBytes_AS_STRING(obj); - sz = SIPBytes_GET_SIZE(obj); + chp = PyBytes_AS_STRING(obj); + sz = PyBytes_GET_SIZE(obj); } else if (PyObject_AsCharBuffer(obj, &chp, &sz) < 0) return -1; @@ -10245,11 +9699,7 @@ static wchar_t sip_api_unicode_as_wchar(PyObject *obj) if (parseWChar(obj, &ch) < 0) { PyErr_Format(PyExc_ValueError, -#if PY_MAJOR_VERSION >= 3 "string" -#else - "unicode string" -#endif " of length 1 expected, not %s", Py_TYPE(obj)->tp_name); return L'\0'; @@ -10269,12 +9719,7 @@ static wchar_t *sip_api_unicode_as_wstring(PyObject *obj) if (parseWCharString(obj, &p) < 0) { PyErr_Format(PyExc_ValueError, -#if PY_MAJOR_VERSION >= 3 - "string" -#else - "unicode string" -#endif - " expected, not %s", Py_TYPE(obj)->tp_name); + "string expected, not %s", Py_TYPE(obj)->tp_name); return NULL; } @@ -10299,22 +9744,6 @@ static int parseWCharArray(PyObject *obj, wchar_t **ap, SIP_SSIZE_T *aszp) if (PyUnicode_Check(obj)) return convertToWCharArray(obj, ap, aszp); -#if PY_MAJOR_VERSION < 3 - if (PyString_Check(obj)) - { - int rc; - PyObject *uobj; - - if ((uobj = PyUnicode_FromObject(obj)) == NULL) - return -1; - - rc = convertToWCharArray(uobj, ap, aszp); - Py_DECREF(uobj); - - return rc; - } -#endif - return -1; } @@ -10356,22 +9785,6 @@ static int parseWChar(PyObject *obj, wchar_t *ap) if (PyUnicode_Check(obj)) return convertToWChar(obj, ap); -#if PY_MAJOR_VERSION < 3 - if (PyString_Check(obj)) - { - int rc; - PyObject *uobj; - - if ((uobj = PyUnicode_FromObject(obj)) == NULL) - return -1; - - rc = convertToWChar(uobj, ap); - Py_DECREF(uobj); - - return rc; - } -#endif - return -1; } @@ -10406,22 +9819,6 @@ static int parseWCharString(PyObject *obj, wchar_t **ap) if (PyUnicode_Check(obj)) return convertToWCharString(obj, ap); -#if PY_MAJOR_VERSION < 3 - if (PyString_Check(obj)) - { - int rc; - PyObject *uobj; - - if ((uobj = PyUnicode_FromObject(obj)) == NULL) - return -1; - - rc = convertToWCharString(uobj, ap); - Py_DECREF(uobj); - - return rc; - } -#endif - return -1; } diff --git a/siplib/tqtlib.c b/siplib/tqtlib.c index 1628c83..702b679 100644 --- a/siplib/tqtlib.c +++ b/siplib/tqtlib.c @@ -151,11 +151,7 @@ PyObject *sip_api_invoke_slot(const sipSlot *slot, PyObject *sigargs) return Py_None; } -#if PY_MAJOR_VERSION >= 3 sfunc = PyMethod_New(slot->meth.mfunc, self); -#else - sfunc = PyMethod_New(slot->meth.mfunc, self, slot->meth.mclass); -#endif if (sfunc == NULL) { @@ -324,9 +320,6 @@ int sip_api_same_slot(const sipSlot *sp, PyObject *rxObj, const char *slot) return (sp->meth.mfunc == PyMethod_GET_FUNCTION(rxObj) && sp->meth.mself == PyMethod_GET_SELF(rxObj) -#if PY_MAJOR_VERSION < 3 - && sp->meth.mclass == PyMethod_GET_CLASS(rxObj) -#endif ); } diff --git a/siplib/voidptr.c b/siplib/voidptr.c index 50cafb2..ef19f31 100644 --- a/siplib/voidptr.c +++ b/siplib/voidptr.c @@ -60,11 +60,7 @@ static PyObject *sipVoidPtr_new(PyTypeObject *subtype, PyObject *args, PyObject *obj; if (!PyArg_ParseTupleAndKeywords(args, kw, -#if PY_VERSION_HEX >= 0x02050000 "O&|ni:voidptr", -#else - "O&|ii:voidptr", -#endif kwlist, vp_convertor, &vp_conversion, &size, &rw)) return NULL; @@ -89,7 +85,6 @@ static PyObject *sipVoidPtr_new(PyTypeObject *subtype, PyObject *args, } -#if PY_MAJOR_VERSION >= 3 /* * The read buffer implementation for Python v3. */ @@ -99,64 +94,6 @@ static int sipVoidPtr_getbuffer(PyObject *self, Py_buffer *buf, int flags) return PyBuffer_FillInfo(buf, self, v->voidptr, v->size, !v->rw, flags); } -#endif - - -#if PY_MAJOR_VERSION < 3 -/* - * The read buffer implementation for Python v2. - */ -static SIP_SSIZE_T sipVoidPtr_getbuffer(PyObject *self, SIP_SSIZE_T seg, - void **ptr) -{ - SIP_SSIZE_T size = ((sipVoidPtrObject *)self)->size; - - if (size < 0 || seg != 0) - { - PyErr_SetString(PyExc_SystemError, "invalid buffer segment"); - return -1; - } - - *ptr = ((sipVoidPtrObject *)self)->voidptr; - - return size; -} -#endif - - -#if PY_MAJOR_VERSION < 3 -/* - * The write buffer implementation for Python v2. - */ -static SIP_SSIZE_T sipVoidPtr_getwritebuffer(PyObject *self, SIP_SSIZE_T seg, - void **ptr) -{ - if (((sipVoidPtrObject *)self)->rw) - return sipVoidPtr_getbuffer(self, seg, ptr); - - PyErr_SetString(PyExc_TypeError, "the sip_tqt.voidptr is not writeable"); - return -1; -} -#endif - - -#if PY_MAJOR_VERSION < 3 -/* - * The segment count implementation for Python v2. - */ -static SIP_SSIZE_T sipVoidPtr_getsegcount(PyObject *self, SIP_SSIZE_T *lenp) -{ - SIP_SSIZE_T segs, len; - - len = ((sipVoidPtrObject *)self)->size; - segs = (len < 0 ? 0 : 1); - - if (lenp != NULL) - *lenp = len; - - return segs; -} -#endif /* @@ -168,23 +105,6 @@ static PyObject *sipVoidPtr_int(sipVoidPtrObject *v) } -#if PY_MAJOR_VERSION < 3 -/* - * Implement hex() for the type. - */ -static PyObject *sipVoidPtr_hex(sipVoidPtrObject *v) -{ - char buf[2 + 16 + 1]; - - PyOS_snprintf(buf, sizeof (buf), "0x%.*lx", (int)(sizeof (void *) * 2), - (unsigned long)v->voidptr); - - return PyString_FromString(buf); -} -#endif - - -#if defined(SIP_USE_PYCAPSULE) /* * Implement ascapsule() for the type. */ @@ -192,18 +112,6 @@ static PyObject *sipVoidPtr_ascapsule(sipVoidPtrObject *v, PyObject *arg) { return PyCapsule_New(v->voidptr, NULL, NULL); } -#endif - - -#if defined(SIP_SUPPORT_PYCOBJECT) -/* - * Implement ascobject() for the type. - */ -static PyObject *sipVoidPtr_ascobject(sipVoidPtrObject *v, PyObject *arg) -{ - return PyCObject_FromVoidPtr(v->voidptr, NULL); -} -#endif /* @@ -217,11 +125,7 @@ static PyObject *sipVoidPtr_asstring(sipVoidPtrObject *v, PyObject *args, SIP_SSIZE_T size = -1; if (!PyArg_ParseTupleAndKeywords(args, kw, -#if PY_VERSION_HEX >= 0x02050000 "|n:asstring", -#else - "|i:asstring", -#endif kwlist, &size)) return NULL; @@ -236,7 +140,7 @@ static PyObject *sipVoidPtr_asstring(sipVoidPtrObject *v, PyObject *args, return NULL; } - return SIPBytes_FromStringAndSize(v->voidptr, size); + return PyBytes_FromStringAndSize(v->voidptr, size); } @@ -245,13 +149,7 @@ static PyObject *sipVoidPtr_asstring(sipVoidPtrObject *v, PyObject *args, */ static PyObject *sipVoidPtr_getsize(sipVoidPtrObject *v, PyObject *arg) { -#if PY_MAJOR_VERSION >= 3 return PyLong_FromSsize_t(v->size); -#elif PY_VERSION_HEX >= 0x02050000 - return PyInt_FromSsize_t(v->size); -#else - return PyInt_FromLong(v->size); -#endif } @@ -262,13 +160,7 @@ static PyObject *sipVoidPtr_setsize(sipVoidPtrObject *v, PyObject *arg) { SIP_SSIZE_T size; -#if PY_MAJOR_VERSION >= 3 size = PyLong_AsSsize_t(arg); -#elif PY_VERSION_HEX >= 0x02050000 - size = PyInt_AsSsize_t(arg); -#else - size = (int)PyInt_AsLong(arg); -#endif if (PyErr_Occurred()) return NULL; @@ -296,7 +188,7 @@ static PyObject *sipVoidPtr_setwriteable(sipVoidPtrObject *v, PyObject *arg) { int rw; - rw = (int)SIPLong_AsLong(arg); + rw = (int)PyLong_AsLong(arg); if (PyErr_Occurred()) return NULL; @@ -310,12 +202,7 @@ static PyObject *sipVoidPtr_setwriteable(sipVoidPtrObject *v, PyObject *arg) /* The methods data structure. */ static PyMethodDef sipVoidPtr_Methods[] = { -#if defined(SIP_USE_PYCAPSULE) {"ascapsule", (PyCFunction)sipVoidPtr_ascapsule, METH_NOARGS, NULL}, -#endif -#if defined(SIP_SUPPORT_PYCOBJECT) - {"ascobject", (PyCFunction)sipVoidPtr_ascobject, METH_NOARGS, NULL}, -#endif {"asstring", (PyCFunction)sipVoidPtr_asstring, METH_VARARGS|METH_KEYWORDS, NULL}, {"getsize", (PyCFunction)sipVoidPtr_getsize, METH_NOARGS, NULL}, {"setsize", (PyCFunction)sipVoidPtr_setsize, METH_O, NULL}, @@ -330,9 +217,6 @@ static PyNumberMethods sipVoidPtr_NumberMethods = { 0, /* nb_add */ 0, /* nb_subtract */ 0, /* nb_multiply */ -#if PY_MAJOR_VERSION < 3 - 0, /* nb_divide */ -#endif 0, /* nb_remainder */ 0, /* nb_divmod */ 0, /* nb_power */ @@ -346,22 +230,12 @@ static PyNumberMethods sipVoidPtr_NumberMethods = { 0, /* nb_and */ 0, /* nb_xor */ 0, /* nb_or */ -#if PY_MAJOR_VERSION < 3 - 0, /* nb_coerce */ -#endif (unaryfunc)sipVoidPtr_int, /* nb_int */ - 0, /* nb_reserved (Python v3), nb_long (Python v2) */ + 0, /* nb_reserved */ 0, /* nb_float */ -#if PY_MAJOR_VERSION < 3 - 0, /* nb_oct */ - (unaryfunc)sipVoidPtr_hex, /* nb_hex */ -#endif 0, /* nb_inplace_add */ 0, /* nb_inplace_subtract */ 0, /* nb_inplace_multiply */ -#if PY_MAJOR_VERSION < 3 - 0, /* nb_inplace_divide */ -#endif 0, /* nb_inplace_remainder */ 0, /* nb_inplace_power */ 0, /* nb_inplace_lshift */ @@ -373,26 +247,14 @@ static PyNumberMethods sipVoidPtr_NumberMethods = { 0, /* nb_true_divide */ 0, /* nb_inplace_floor_divide */ 0, /* nb_inplace_true_divide */ -#if PY_VERSION_HEX >= 0x02050000 0 /* nb_index */ -#endif }; /* The buffer methods data structure. */ static PyBufferProcs sipVoidPtr_BufferProcs = { sipVoidPtr_getbuffer, -#if PY_MAJOR_VERSION >= 3 NULL, -#else - sipVoidPtr_getwritebuffer, - sipVoidPtr_getsegcount, -#if PY_VERSION_HEX >= 0x02050000 - (charbufferproc)sipVoidPtr_getbuffer -#else - (getcharbufferproc)sipVoidPtr_getbuffer -#endif -#endif }; @@ -456,21 +318,10 @@ void *sip_api_convert_to_void_ptr(PyObject *obj) if (PyObject_TypeCheck(obj, &sipVoidPtr_Type)) return ((sipVoidPtrObject *)obj)->voidptr; -#if defined(SIP_USE_PYCAPSULE) if (PyCapsule_CheckExact(obj)) return PyCapsule_GetPointer(obj, NULL); -#endif -#if defined(SIP_SUPPORT_PYCOBJECT) - if (PyCObject_Check(obj)) - return PyCObject_AsVoidPtr(obj); -#endif - -#if PY_MAJOR_VERSION >= 3 return PyLong_AsVoidPtr(obj); -#else - return (void *)PyInt_AsLong(obj); -#endif } @@ -546,14 +397,8 @@ static int vp_convertor(PyObject *arg, struct vp_values *vp) if (arg == Py_None) ptr = NULL; -#if defined(SIP_USE_PYCAPSULE) else if (PyCapsule_CheckExact(arg)) ptr = PyCapsule_GetPointer(arg, NULL); -#endif -#if defined(SIP_SUPPORT_PYCOBJECT) - else if (PyCObject_Check(arg)) - ptr = PyCObject_AsVoidPtr(arg); -#endif else if (PyObject_TypeCheck(arg, &sipVoidPtr_Type)) { ptr = ((sipVoidPtrObject *)arg)->voidptr; @@ -562,19 +407,11 @@ static int vp_convertor(PyObject *arg, struct vp_values *vp) } else { -#if PY_MAJOR_VERSION >= 3 ptr = PyLong_AsVoidPtr(arg); -#else - ptr = (void *)PyInt_AsLong(arg); -#endif if (PyErr_Occurred()) { -#if PY_VERSION_HEX >= 0x03010000 PyErr_SetString(PyExc_TypeError, "a single integer, CObject, None or another voidptr is required"); -#else - PyErr_SetString(PyExc_TypeError, "a single integer, Capsule, CObject, None or another voidptr is required"); -#endif return 0; } } |