+"""\r
+C bindings generator\r
+Author: Luke A. Guest\r
+"""\r
+\r
+import os\r
+\r
+from common import *\r
+\r
+class CBuilder:\r
+ def __init__(self, doxyparse, outputdir):\r
+ self.doxyparser = doxyparse\r
+ self.output_dir = outputdir\r
+\r
+ def make_bindings(self):\r
+ output_dir = os.path.abspath(os.path.join(self.output_dir, "c"))\r
+ if not os.path.exists(output_dir):\r
+ os.makedirs(output_dir)\r
+ \r
+ for aclass in self.doxyparser.classes:\r
+ # This bit doesn't work, because the aclass.name is not the same as\r
+ # those listed in common\r
+ if aclass.name in excluded_classes:\r
+ #print "Skipping %s" % aclass.name\r
+ continue\r
+ \r
+ self.make_c_header(output_dir, aclass)\r
+\r
+\r
+ def make_c_header(self, output_dir, aclass):\r
+ filename = os.path.join(output_dir, aclass.name[2:].lower() + ".hh")\r
+ enums_text = make_enums(aclass)\r
+ method_text = self.make_c_methods(aclass)\r
+ class_name = aclass.name[2:].capitalize()\r
+ text = """\r
+// Enums\r
+%s\r
+\r
+%s\r
+""" % (enums_text, method_text)\r
+\r
+ afile = open(filename, "wb")\r
+ afile.write(text)\r
+ afile.close()\r
+\r
+\r
+ def make_c_methods(self, aclass):\r
+ retval = ""\r
+ \r
+ wxc_classname = 'wxC' + aclass.name[2:].capitalize()\r
+\r
+ for amethod in aclass.constructors:\r
+ if amethod.name.startswith('m_'):\r
+ # for some reason, public members are listed as methods\r
+ continue\r
+ retval += """\r
+// %s\r
+%s%s;\n\n\r
+""" % (amethod.brief_description, wxc_classname + '* ' + wxc_classname + '_' + amethod.name, amethod.argsstring)\r
+\r
+ for amethod in aclass.methods:\r
+ args = '(' + wxc_classname + '* obj'\r
+ if amethod.argsstring.find('()') != -1:\r
+ args += ')'\r
+ else: \r
+ args += ', ' + amethod.argsstring[1:].strip()\r
+ \r
+ retval += """\r
+// %s\r
+%s %s%s;\n\r
+""" % (amethod.detailed_description, amethod.return_type, wxc_classname + '_' + amethod.name, args)\r
+\r
+ return retval\r