diff options
Diffstat (limited to 'sipgen/gencode.c')
-rw-r--r-- | sipgen/gencode.c | 250 |
1 files changed, 5 insertions, 245 deletions
diff --git a/sipgen/gencode.c b/sipgen/gencode.c index 7dbe6ad..b0e3eb7 100644 --- a/sipgen/gencode.c +++ b/sipgen/gencode.c @@ -242,8 +242,6 @@ static int generateSubClassConvertors(sipSpec *pt, moduleDef *mod, FILE *fp); static void generateNameCache(sipSpec *pt, FILE *fp); static const char *resultOwner(overDef *od); 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 keepPyReference(argDef *ad); static int isDuplicateProtected(classDef *cd, overDef *target); @@ -497,12 +495,6 @@ static void generateInternalAPIHeader(sipSpec *pt, moduleDef *mod, , mname , mname); - if (pluginPyQt4(pt)) - prcode(fp, -"\n" -"#include <TQMetaType>\n" - ); - /* Define the enabled features. */ noIntro = TRUE; @@ -799,21 +791,6 @@ static void generateInternalAPIHeader(sipSpec *pt, moduleDef *mod, , mname, mld->module->name); } - if (pluginPyQt4(pt)) - prcode(fp, -"\n" -"typedef const TQMetaObject *(*sip_tqt_metaobject_func)(sipSimpleWrapper *,sipTypeDef *);\n" -"extern sip_tqt_metaobject_func sip_%s_tqt_metaobject;\n" -"\n" -"typedef int (*sip_tqt_metacall_func)(sipSimpleWrapper *,sipTypeDef *,TQMetaObject::Call,int,void **);\n" -"extern sip_tqt_metacall_func sip_%s_tqt_metacall;\n" -"\n" -"typedef int (*sip_tqt_metacast_func)(sipSimpleWrapper *,sipTypeDef *,const char *);\n" -"extern sip_tqt_metacast_func sip_%s_tqt_metacast;\n" - , mname - , mname - , mname); - /* * Note that we don't forward declare the virtual handlers. This is * because we would need to #include everything needed for their argument @@ -1803,16 +1780,6 @@ static void generateCpp(sipSpec *pt, moduleDef *mod, const char *codeDir, "const sipExportedModuleDef *sipModuleAPI_%s_%s;\n" , mname, mld->module->name); - if (pluginPyQt4(pt)) - prcode(fp, -"\n" -"sip_tqt_metaobject_func sip_%s_tqt_metaobject;\n" -"sip_tqt_metacall_func sip_%s_tqt_metacall;\n" -"sip_tqt_metacast_func sip_%s_tqt_metacast;\n" - , mname - , mname - , mname); - /* Generate the Python module initialisation function. */ if (mod->container == pt->module) @@ -1902,20 +1869,6 @@ static void generateCpp(sipSpec *pt, moduleDef *mod, const char *codeDir, " }\n" , mname); - if (pluginPyQt4(pt)) - { - /* Import the helpers. */ - prcode(fp, -"\n" -" sip_%s_tqt_metaobject = (sip_tqt_metaobject_func)sipImportSymbol(\"tqtcore_tqt_metaobject\");\n" -" sip_%s_tqt_metacall = (sip_tqt_metacall_func)sipImportSymbol(\"tqtcore_tqt_metacall\");\n" -" sip_%s_tqt_metacast = (sip_tqt_metacast_func)sipImportSymbol(\"tqtcore_tqt_metacast\");\n" -"\n" - , mname - , mname - , mname); - } - prcode(fp, " /* Initialise the module now all its dependencies have been set up. */\n" " if (sipInitModule(&sipModuleAPI_%s,sipModuleDict) < 0)\n" @@ -2037,7 +1990,7 @@ static void generateTypesTable(sipSpec *pt, moduleDef *mod, FILE *fp) argDef *ad; const char *type_suffix; - type_suffix = (pluginPyQt4(pt) || pluginPyTQt(pt)) ? ".super" : ""; + type_suffix = pluginPyTQt(pt) ? ".super" : ""; prcode(fp, "\n" @@ -3623,7 +3576,7 @@ static void generateTypeDefLink(sipSpec *pt, ifaceFileDef *iff, FILE *fp) if (iff->next_alt->type == mappedtype_iface) prcode(fp, ".mtd_base"); - else if (pluginPyTQt(pt) || pluginPyQt4(pt)) + else if (pluginPyTQt(pt)) prcode(fp, ".super.ctd_base"); else prcode(fp, ".ctd_base"); @@ -5695,42 +5648,6 @@ static void generateShadowCode(sipSpec *pt, moduleDef *mod, classDef *cd, ); } - /* The meta methods if required. */ - if (pluginPyQt4(pt) && isTQObjectSubClass(cd)) - { - if (!noPyQt4TQMetaObject(cd)) - prcode(fp, -"\n" -"const TQMetaObject *sip%C::metaObject() const\n" -"{\n" -" return sip_%s_tqt_metaobject(sipPySelf,sipType_%C);\n" -"}\n" - , classFTQCName(cd) - , mod->name, classFTQCName(cd)); - - prcode(fp, -"\n" -"int sip%C::qt_metacall(TQMetaObject::Call _c,int _id,void **_a)\n" -"{\n" -" _id = %S::qt_metacall(_c,_id,_a);\n" -"\n" -" if (_id >= 0)\n" -" _id = sip_%s_tqt_metacall(sipPySelf,sipType_%C,_c,_id,_a);\n" -"\n" -" return _id;\n" -"}\n" -"\n" -"void *sip%C::qt_metacast(const char *_clname)\n" -"{\n" -" return (sip_%s_tqt_metacast && sip_%s_tqt_metacast(sipPySelf,sipType_%C,_clname)) ? this : %S::qt_metacast(_clname);\n" -"}\n" - , classFTQCName(cd) - , classFTQCName(cd) - , mod->name, classFTQCName(cd) - , classFTQCName(cd) - , mod->name, mod->name, classFTQCName(cd), classFTQCName(cd)); - } - /* Generate the virtual catchers. */ virtNr = 0; @@ -7652,9 +7569,7 @@ static void generateClassAPI(classDef *cd, sipSpec *pt, FILE *fp) { const char *type_prefix; - if (pluginPyQt4(pt)) - type_prefix = "pyqt4"; - else if (pluginPyTQt(pt)) + if (pluginPyTQt(pt)) type_prefix = "pytqt"; else type_prefix = "sip"; @@ -7808,21 +7723,6 @@ static void generateShadowClassDeclaration(sipSpec *pt,classDef *cd,FILE *fp) " %s~sip%C()%X;\n" ,(cd->vmembers != NULL ? "virtual " : ""),classFTQCName(cd),cd->dtorexceptions); - /* The metacall methods if required. */ - if (pluginPyQt4(pt) && isTQObjectSubClass(cd)) - { - prcode(fp, -"\n" -" int tqt_metacall(TQMetaObject::Call,int,void **);\n" -" void *tqt_metacast(const char *);\n" - ); - - if (!noPyQt4TQMetaObject(cd)) - prcode(fp, -" const TQMetaObject *metaObject() const;\n" - ); - } - /* The exposure of protected enums. */ generateProtectedEnums(pt,cd,fp); @@ -8530,7 +8430,7 @@ static void generateSimpleFunctionCall(fcallDef *fcd,FILE *fp) static void generateTypeDefinition(sipSpec *pt, classDef *cd, FILE *fp) { const char *mname, *sep, *type_prefix; - int is_slots, is_signals, nr_methods, nr_enums, nr_vars, embedded; + int is_slots, nr_methods, nr_enums, nr_vars, embedded; int is_inst_class, is_inst_voidp, is_inst_char, is_inst_string; int is_inst_int, is_inst_long, is_inst_ulong, is_inst_longlong; int is_inst_ulonglong, is_inst_double, has_docstring; @@ -8602,79 +8502,6 @@ static void generateTypeDefinition(sipSpec *pt, classDef *cd, FILE *fp) nr_methods = generateClassMethodTable(pt, cd, fp); nr_enums = generateEnumMemberTable(pt, mod, cd, NULL, fp); - /* Generate the PyQt4 signals table. */ - is_signals = FALSE; - - if (pluginPyQt4(pt) && isTQObjectSubClass(cd)) - { - /* The signals must be grouped by name. */ - for (md = cd->members; md != NULL; md = md->next) - { - overDef *od; - int membernr = md->membernr; - - for (od = cd->overs; od != NULL; od = od->next) - { - int a, nr_args; - - if (od->common != md || !isSignal(od)) - continue; - - if (membernr >= 0) - { - /* See if there is a non-signal overload. */ - - overDef *nsig; - - for (nsig = cd->overs; nsig != NULL; nsig = nsig->next) - if (nsig != od && nsig->common == md && !isSignal(nsig)) - break; - - if (nsig == NULL) - membernr = -1; - } - - if (!is_signals) - { - is_signals = TRUE; - - prcode(fp, -"\n" -"\n" -"/* Define this type's PyQt4 signals. */\n" -"static const pyqt4QtSignal pyqt4_signals_%C[] = {\n" - , classFTQCName(cd)); - } - - /* - * Default arguments are handled as multiple signals. We make - * sure the largest is first and the smallest last. - */ - generateSignalTableEntry(pt, cd, od, md, membernr, fp); - membernr = -1; - - nr_args = od->cppsig->nrArgs; - - for (a = nr_args - 1; a >= 0; --a) - { - if (od->cppsig->args[a].defval == NULL) - break; - - od->cppsig->nrArgs = a; - generateSignalTableEntry(pt, cd, od, md, -1, fp); - } - - od->cppsig->nrArgs = nr_args; - } - } - - if (is_signals) - prcode(fp, -" {0, 0, 0}\n" -"};\n" - ); - } - /* Generate the variable handlers. */ nr_vars = 0; @@ -8751,12 +8578,7 @@ static void generateTypeDefinition(sipSpec *pt, classDef *cd, FILE *fp) has_docstring = TRUE; } - if (pluginPyQt4(pt)) - { - type_prefix = "pyqt4"; - embedded = TRUE; - } - else if (pluginPyTQt(pt)) + if (pluginPyTQt(pt)) { type_prefix = "pytqt"; embedded = TRUE; @@ -9108,31 +8930,6 @@ static void generateTypeDefinition(sipSpec *pt, classDef *cd, FILE *fp) ); } - if (pluginPyQt4(pt)) - { - if (isTQObjectSubClass(cd) && !noPyQt4TQMetaObject(cd)) - prcode(fp, -" &%U::staticMetaObject,\n" - , cd); - else - prcode(fp, -" 0,\n" - ); - - prcode(fp, -" %u,\n" - , cd->pyqt4_flags); - - if (is_signals) - prcode(fp, -" pyqt4_signals_%C\n" - , classFTQCName(cd)); - else - prcode(fp, -" 0\n" - ); - } - prcode(fp, "};\n" ); @@ -9140,43 +8937,6 @@ static void generateTypeDefinition(sipSpec *pt, classDef *cd, FILE *fp) /* - * Generate an entry in the PyQt4 signal table. - */ -static void generateSignalTableEntry(sipSpec *pt, classDef *cd, overDef *sig, - memberDef *md, int membernr, FILE *fp) -{ - prcode(fp, -" {\"%s(", sig->cppname); - - generateCalledArgs(cd->iff, sig->cppsig, Declaration, TRUE, fp); - - prcode(fp,")\", "); - - if (docstrings) - { - fprintf(fp, "\"\\1"); - prScopedPythonName(fp, cd->ecd, cd->pyname->text); - fprintf(fp, ".%s", md->pyname->text); - prPythonSignature(pt, fp, &sig->pysig, FALSE, FALSE, FALSE, FALSE, - TRUE); - fprintf(fp, "\", "); - } - else - { - prcode(fp, "0, "); - } - - if (membernr >= 0) - prcode(fp, "&methods_%L[%d]", cd->iff, membernr); - else - prcode(fp, "0"); - - prcode(fp,"},\n" - ); -} - - -/* * Return the sip module's string equivalent of a slot. */ static const char *slotName(slotType st) |