From: Jack Jansen Date: Sun, 9 Dec 2001 23:25:00 +0000 (+0000) Subject: The module generator now tells its object generators about the module name (through... X-Git-Tag: v2.2.1c1~450 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=5801a2d8e3769a64fc0eac0111c4310d72651d98;p=thirdparty%2FPython%2Fcpython.git The module generator now tells its object generators about the module name (through the new setmodulename() method). If the module name has been set the object generators output it as part of the tp_name field for the object type. --- diff --git a/Tools/bgen/bgen/bgenModule.py b/Tools/bgen/bgen/bgenModule.py index 5f94b9041203..ea1ea230a7e6 100644 --- a/Tools/bgen/bgen/bgenModule.py +++ b/Tools/bgen/bgen/bgenModule.py @@ -19,6 +19,7 @@ class Module(GeneratorGroup): def addobject(self, od): self.generators.append(od) self.typeobjects.append(od) + od.setmodulename(self.name) def generate(self): OutHeader1("Module " + self.name) diff --git a/Tools/bgen/bgen/bgenObjectDefinition.py b/Tools/bgen/bgen/bgenObjectDefinition.py index 1d5cb22795fb..71cf21da8e4c 100644 --- a/Tools/bgen/bgen/bgenObjectDefinition.py +++ b/Tools/bgen/bgen/bgenObjectDefinition.py @@ -22,6 +22,7 @@ class ObjectDefinition(GeneratorGroup): self.typename = name + '_Type' self.argref = "" # set to "*" if arg to _New should be pointer self.static = "static " # set to "" to make _New and _Convert public + self.modulename = None def add(self, g, dupcheck=0): g.setselftype(self.objecttype, self.itselftype) @@ -30,6 +31,9 @@ class ObjectDefinition(GeneratorGroup): def reference(self): # In case we are referenced from a module pass + + def setmodulename(self, name): + self.modulename = name def generate(self): # XXX This should use long strings and %(varname)s substitution! @@ -166,7 +170,10 @@ class ObjectDefinition(GeneratorGroup): IndentLevel() Output("PyObject_HEAD_INIT(NULL)") Output("0, /*ob_size*/") - Output("\"%s\", /*tp_name*/", self.name) + if self.modulename: + Output("\"%s.%s\", /*tp_name*/", self.modulename, self.name) + else: + Output("\"%s\", /*tp_name*/", self.name) Output("sizeof(%s), /*tp_basicsize*/", self.objecttype) Output("0, /*tp_itemsize*/") Output("/* methods */")