Home | History | Annotate | Download | only in cf
      1 # This script generates a Python interface for an Apple Macintosh Manager.
      2 # It uses the "bgen" package to generate C code.
      3 # The function specifications are generated by scanning the mamager's header file,
      4 # using the "scantools" package (customized for this particular manager).
      5 
      6 #error missing SetActionFilter
      7 
      8 import string
      9 
     10 # Declarations that change for each manager
     11 MODNAME = '_CF'                         # The name of the module
     12 
     13 # The following is *usually* unchanged but may still require tuning
     14 MODPREFIX = 'CF'                        # The prefix for module-wide routines
     15 INPUTFILE = string.lower(MODPREFIX) + 'gen.py' # The file generated by the scanner
     16 OUTPUTFILE = MODNAME + "module.c"       # The file generated by this program
     17 
     18 from macsupport import *
     19 
     20 # Special case generator for the functions that have an AllocatorRef first argument,
     21 # which we skip anyway, and the object as the second arg.
     22 class MethodSkipArg1(MethodGenerator):
     23     """Similar to MethodGenerator, but has self as last argument"""
     24 
     25     def parseArgumentList(self, args):
     26         if len(args) < 2:
     27             raise ValueError, "MethodSkipArg1 expects at least 2 args"
     28         a0, a1, args = args[0], args[1], args[2:]
     29         t0, n0, m0 = a0
     30         if t0 != "CFAllocatorRef" and m0 != InMode:
     31             raise ValueError, "MethodSkipArg1 should have dummy AllocatorRef first arg"
     32         t1, n1, m1 = a1
     33         if m1 != InMode:
     34             raise ValueError, "method's 'self' must be 'InMode'"
     35         dummy = Variable(t0, n0, m0)
     36         self.argumentList.append(dummy)
     37         self.itself = Variable(t1, "_self->ob_itself", SelfMode)
     38         self.argumentList.append(self.itself)
     39         FunctionGenerator.parseArgumentList(self, args)
     40 
     41 
     42 # Create the type objects
     43 
     44 includestuff = includestuff + """
     45 #include <CoreServices/CoreServices.h>
     46 
     47 #include "pycfbridge.h"
     48 
     49 #ifdef USE_TOOLBOX_OBJECT_GLUE
     50 extern PyObject *_CFObj_New(CFTypeRef);
     51 extern int _CFObj_Convert(PyObject *, CFTypeRef *);
     52 #define CFObj_New _CFObj_New
     53 #define CFObj_Convert _CFObj_Convert
     54 
     55 extern PyObject *_CFTypeRefObj_New(CFTypeRef);
     56 extern int _CFTypeRefObj_Convert(PyObject *, CFTypeRef *);
     57 #define CFTypeRefObj_New _CFTypeRefObj_New
     58 #define CFTypeRefObj_Convert _CFTypeRefObj_Convert
     59 
     60 extern PyObject *_CFStringRefObj_New(CFStringRef);
     61 extern int _CFStringRefObj_Convert(PyObject *, CFStringRef *);
     62 #define CFStringRefObj_New _CFStringRefObj_New
     63 #define CFStringRefObj_Convert _CFStringRefObj_Convert
     64 
     65 extern PyObject *_CFMutableStringRefObj_New(CFMutableStringRef);
     66 extern int _CFMutableStringRefObj_Convert(PyObject *, CFMutableStringRef *);
     67 #define CFMutableStringRefObj_New _CFMutableStringRefObj_New
     68 #define CFMutableStringRefObj_Convert _CFMutableStringRefObj_Convert
     69 
     70 extern PyObject *_CFArrayRefObj_New(CFArrayRef);
     71 extern int _CFArrayRefObj_Convert(PyObject *, CFArrayRef *);
     72 #define CFArrayRefObj_New _CFArrayRefObj_New
     73 #define CFArrayRefObj_Convert _CFArrayRefObj_Convert
     74 
     75 extern PyObject *_CFMutableArrayRefObj_New(CFMutableArrayRef);
     76 extern int _CFMutableArrayRefObj_Convert(PyObject *, CFMutableArrayRef *);
     77 #define CFMutableArrayRefObj_New _CFMutableArrayRefObj_New
     78 #define CFMutableArrayRefObj_Convert _CFMutableArrayRefObj_Convert
     79 
     80 extern PyObject *_CFDataRefObj_New(CFDataRef);
     81 extern int _CFDataRefObj_Convert(PyObject *, CFDataRef *);
     82 #define CFDataRefObj_New _CFDataRefObj_New
     83 #define CFDataRefObj_Convert _CFDataRefObj_Convert
     84 
     85 extern PyObject *_CFMutableDataRefObj_New(CFMutableDataRef);
     86 extern int _CFMutableDataRefObj_Convert(PyObject *, CFMutableDataRef *);
     87 #define CFMutableDataRefObj_New _CFMutableDataRefObj_New
     88 #define CFMutableDataRefObj_Convert _CFMutableDataRefObj_Convert
     89 
     90 extern PyObject *_CFDictionaryRefObj_New(CFDictionaryRef);
     91 extern int _CFDictionaryRefObj_Convert(PyObject *, CFDictionaryRef *);
     92 #define CFDictionaryRefObj_New _CFDictionaryRefObj_New
     93 #define CFDictionaryRefObj_Convert _CFDictionaryRefObj_Convert
     94 
     95 extern PyObject *_CFMutableDictionaryRefObj_New(CFMutableDictionaryRef);
     96 extern int _CFMutableDictionaryRefObj_Convert(PyObject *, CFMutableDictionaryRef *);
     97 #define CFMutableDictionaryRefObj_New _CFMutableDictionaryRefObj_New
     98 #define CFMutableDictionaryRefObj_Convert _CFMutableDictionaryRefObj_Convert
     99 
    100 extern PyObject *_CFURLRefObj_New(CFURLRef);
    101 extern int _CFURLRefObj_Convert(PyObject *, CFURLRef *);
    102 extern int _OptionalCFURLRefObj_Convert(PyObject *, CFURLRef *);
    103 #define CFURLRefObj_New _CFURLRefObj_New
    104 #define CFURLRefObj_Convert _CFURLRefObj_Convert
    105 #define OptionalCFURLRefObj_Convert _OptionalCFURLRefObj_Convert
    106 #endif
    107 
    108 /*
    109 ** Parse/generate CFRange records
    110 */
    111 PyObject *CFRange_New(CFRange *itself)
    112 {
    113 
    114         return Py_BuildValue("ll", (long)itself->location, (long)itself->length);
    115 }
    116 
    117 int
    118 CFRange_Convert(PyObject *v, CFRange *p_itself)
    119 {
    120         long location, length;
    121 
    122         if( !PyArg_ParseTuple(v, "ll", &location, &length) )
    123                 return 0;
    124         p_itself->location = (CFIndex)location;
    125         p_itself->length = (CFIndex)length;
    126         return 1;
    127 }
    128 
    129 /* Optional CFURL argument or None (passed as NULL) */
    130 int
    131 OptionalCFURLRefObj_Convert(PyObject *v, CFURLRef *p_itself)
    132 {
    133     if ( v == Py_None ) {
    134         p_itself = NULL;
    135         return 1;
    136     }
    137     return CFURLRefObj_Convert(v, p_itself);
    138 }
    139 """
    140 
    141 finalstuff = finalstuff + """
    142 
    143 /* Routines to convert any CF type to/from the corresponding CFxxxObj */
    144 PyObject *CFObj_New(CFTypeRef itself)
    145 {
    146         if (itself == NULL)
    147         {
    148                 PyErr_SetString(PyExc_RuntimeError, "cannot wrap NULL");
    149                 return NULL;
    150         }
    151         if (CFGetTypeID(itself) == CFArrayGetTypeID()) return CFArrayRefObj_New((CFArrayRef)itself);
    152         if (CFGetTypeID(itself) == CFDictionaryGetTypeID()) return CFDictionaryRefObj_New((CFDictionaryRef)itself);
    153         if (CFGetTypeID(itself) == CFDataGetTypeID()) return CFDataRefObj_New((CFDataRef)itself);
    154         if (CFGetTypeID(itself) == CFStringGetTypeID()) return CFStringRefObj_New((CFStringRef)itself);
    155         if (CFGetTypeID(itself) == CFURLGetTypeID()) return CFURLRefObj_New((CFURLRef)itself);
    156         /* XXXX Or should we use PyCF_CF2Python here?? */
    157         return CFTypeRefObj_New(itself);
    158 }
    159 int CFObj_Convert(PyObject *v, CFTypeRef *p_itself)
    160 {
    161 
    162         if (v == Py_None) { *p_itself = NULL; return 1; }
    163         /* Check for other CF objects here */
    164 
    165         if (!CFTypeRefObj_Check(v) &&
    166                 !CFArrayRefObj_Check(v) &&
    167                 !CFMutableArrayRefObj_Check(v) &&
    168                 !CFDictionaryRefObj_Check(v) &&
    169                 !CFMutableDictionaryRefObj_Check(v) &&
    170                 !CFDataRefObj_Check(v) &&
    171                 !CFMutableDataRefObj_Check(v) &&
    172                 !CFStringRefObj_Check(v) &&
    173                 !CFMutableStringRefObj_Check(v) &&
    174                 !CFURLRefObj_Check(v) )
    175         {
    176                 /* XXXX Or should we use PyCF_Python2CF here?? */
    177                 PyErr_SetString(PyExc_TypeError, "CF object required");
    178                 return 0;
    179         }
    180         *p_itself = ((CFTypeRefObject *)v)->ob_itself;
    181         return 1;
    182 }
    183 """
    184 
    185 initstuff = initstuff + """
    186 PyMac_INIT_TOOLBOX_OBJECT_NEW(CFTypeRef, CFObj_New);
    187 PyMac_INIT_TOOLBOX_OBJECT_CONVERT(CFTypeRef, CFObj_Convert);
    188 PyMac_INIT_TOOLBOX_OBJECT_NEW(CFTypeRef, CFTypeRefObj_New);
    189 PyMac_INIT_TOOLBOX_OBJECT_CONVERT(CFTypeRef, CFTypeRefObj_Convert);
    190 PyMac_INIT_TOOLBOX_OBJECT_NEW(CFStringRef, CFStringRefObj_New);
    191 PyMac_INIT_TOOLBOX_OBJECT_CONVERT(CFStringRef, CFStringRefObj_Convert);
    192 PyMac_INIT_TOOLBOX_OBJECT_NEW(CFMutableStringRef, CFMutableStringRefObj_New);
    193 PyMac_INIT_TOOLBOX_OBJECT_CONVERT(CFMutableStringRef, CFMutableStringRefObj_Convert);
    194 PyMac_INIT_TOOLBOX_OBJECT_NEW(CFArrayRef, CFArrayRefObj_New);
    195 PyMac_INIT_TOOLBOX_OBJECT_CONVERT(CFArrayRef, CFArrayRefObj_Convert);
    196 PyMac_INIT_TOOLBOX_OBJECT_NEW(CFMutableArrayRef, CFMutableArrayRefObj_New);
    197 PyMac_INIT_TOOLBOX_OBJECT_CONVERT(CFMutableArrayRef, CFMutableArrayRefObj_Convert);
    198 PyMac_INIT_TOOLBOX_OBJECT_NEW(CFDictionaryRef, CFDictionaryRefObj_New);
    199 PyMac_INIT_TOOLBOX_OBJECT_CONVERT(CFDictionaryRef, CFDictionaryRefObj_Convert);
    200 PyMac_INIT_TOOLBOX_OBJECT_NEW(CFMutableDictionaryRef, CFMutableDictionaryRefObj_New);
    201 PyMac_INIT_TOOLBOX_OBJECT_CONVERT(CFMutableDictionaryRef, CFMutableDictionaryRefObj_Convert);
    202 PyMac_INIT_TOOLBOX_OBJECT_NEW(CFURLRef, CFURLRefObj_New);
    203 PyMac_INIT_TOOLBOX_OBJECT_CONVERT(CFURLRef, CFURLRefObj_Convert);
    204 """
    205 
    206 variablestuff="""
    207 #define _STRINGCONST(name) PyModule_AddObject(m, #name, CFStringRefObj_New(name))
    208 _STRINGCONST(kCFPreferencesAnyApplication);
    209 _STRINGCONST(kCFPreferencesCurrentApplication);
    210 _STRINGCONST(kCFPreferencesAnyHost);
    211 _STRINGCONST(kCFPreferencesCurrentHost);
    212 _STRINGCONST(kCFPreferencesAnyUser);
    213 _STRINGCONST(kCFPreferencesCurrentUser);
    214 
    215 """
    216 
    217 Boolean = Type("Boolean", "l")
    218 CFTypeID = Type("CFTypeID", "l") # XXXX a guess, seems better than OSTypeType.
    219 CFHashCode = Type("CFHashCode", "l")
    220 CFIndex = Type("CFIndex", "l")
    221 CFRange = OpaqueByValueType('CFRange', 'CFRange')
    222 CFOptionFlags = Type("CFOptionFlags", "l")
    223 CFStringEncoding = Type("CFStringEncoding", "l")
    224 CFComparisonResult = Type("CFComparisonResult", "l")  # a bit dangerous, it's an enum
    225 CFURLPathStyle = Type("CFURLPathStyle", "l") #  a bit dangerous, it's an enum
    226 
    227 char_ptr = stringptr
    228 return_stringptr = Type("char *", "s")  # ONLY FOR RETURN VALUES!!
    229 
    230 CFAllocatorRef = FakeType("(CFAllocatorRef)NULL")
    231 CFArrayCallBacks_ptr = FakeType("&kCFTypeArrayCallBacks")
    232 CFDictionaryKeyCallBacks_ptr = FakeType("&kCFTypeDictionaryKeyCallBacks")
    233 CFDictionaryValueCallBacks_ptr = FakeType("&kCFTypeDictionaryValueCallBacks")
    234 # The real objects
    235 CFTypeRef = OpaqueByValueType("CFTypeRef", "CFTypeRefObj")
    236 CFArrayRef = OpaqueByValueType("CFArrayRef", "CFArrayRefObj")
    237 CFMutableArrayRef = OpaqueByValueType("CFMutableArrayRef", "CFMutableArrayRefObj")
    238 CFArrayRef = OpaqueByValueType("CFArrayRef", "CFArrayRefObj")
    239 CFMutableArrayRef = OpaqueByValueType("CFMutableArrayRef", "CFMutableArrayRefObj")
    240 CFDataRef = OpaqueByValueType("CFDataRef", "CFDataRefObj")
    241 CFMutableDataRef = OpaqueByValueType("CFMutableDataRef", "CFMutableDataRefObj")
    242 CFDictionaryRef = OpaqueByValueType("CFDictionaryRef", "CFDictionaryRefObj")
    243 CFMutableDictionaryRef = OpaqueByValueType("CFMutableDictionaryRef", "CFMutableDictionaryRefObj")
    244 CFStringRef = OpaqueByValueType("CFStringRef", "CFStringRefObj")
    245 CFMutableStringRef = OpaqueByValueType("CFMutableStringRef", "CFMutableStringRefObj")
    246 CFURLRef = OpaqueByValueType("CFURLRef", "CFURLRefObj")
    247 OptionalCFURLRef  = OpaqueByValueType("CFURLRef", "OptionalCFURLRefObj")
    248 ##CFPropertyListRef = OpaqueByValueType("CFPropertyListRef", "CFTypeRefObj")
    249 # ADD object type here
    250 
    251 # Our (opaque) objects
    252 
    253 class MyGlobalObjectDefinition(PEP253Mixin, GlobalObjectDefinition):
    254     def outputCheckNewArg(self):
    255         Output('if (itself == NULL)')
    256         OutLbrace()
    257         Output('PyErr_SetString(PyExc_RuntimeError, "cannot wrap NULL");')
    258         Output('return NULL;')
    259         OutRbrace()
    260     def outputStructMembers(self):
    261         GlobalObjectDefinition.outputStructMembers(self)
    262         Output("void (*ob_freeit)(CFTypeRef ptr);")
    263     def outputInitStructMembers(self):
    264         GlobalObjectDefinition.outputInitStructMembers(self)
    265 ##              Output("it->ob_freeit = NULL;")
    266         Output("it->ob_freeit = CFRelease;")
    267     def outputCheckConvertArg(self):
    268         Out("""
    269         if (v == Py_None) { *p_itself = NULL; return 1; }
    270         /* Check for other CF objects here */
    271         """)
    272     def outputCleanupStructMembers(self):
    273         Output("if (self->ob_freeit && self->ob_itself)")
    274         OutLbrace()
    275         Output("self->ob_freeit((CFTypeRef)self->ob_itself);")
    276         Output("self->ob_itself = NULL;")
    277         OutRbrace()
    278 
    279     def outputCompare(self):
    280         Output()
    281         Output("static int %s_compare(%s *self, %s *other)", self.prefix, self.objecttype, self.objecttype)
    282         OutLbrace()
    283         Output("/* XXXX Or should we use CFEqual?? */")
    284         Output("if ( self->ob_itself > other->ob_itself ) return 1;")
    285         Output("if ( self->ob_itself < other->ob_itself ) return -1;")
    286         Output("return 0;")
    287         OutRbrace()
    288 
    289     def outputHash(self):
    290         Output()
    291         Output("static int %s_hash(%s *self)", self.prefix, self.objecttype)
    292         OutLbrace()
    293         Output("/* XXXX Or should we use CFHash?? */")
    294         Output("return (int)self->ob_itself;")
    295         OutRbrace()
    296 
    297     def outputRepr(self):
    298         Output()
    299         Output("static PyObject * %s_repr(%s *self)", self.prefix, self.objecttype)
    300         OutLbrace()
    301         Output("char buf[100];")
    302         Output("""sprintf(buf, "<CFTypeRef type-%%d object at 0x%%8.8x for 0x%%8.8x>", (int)CFGetTypeID(self->ob_itself), (unsigned)self, (unsigned)self->ob_itself);""")
    303         Output("return PyString_FromString(buf);")
    304         OutRbrace()
    305 
    306     def output_tp_newBody(self):
    307         Output("PyObject *self;")
    308         Output
    309         Output("if ((self = type->tp_alloc(type, 0)) == NULL) return NULL;")
    310         Output("((%s *)self)->ob_itself = NULL;", self.objecttype)
    311         Output("((%s *)self)->ob_freeit = CFRelease;", self.objecttype)
    312         Output("return self;")
    313 
    314     def output_tp_initBody(self):
    315         Output("%s itself;", self.itselftype)
    316         Output("char *kw[] = {\"itself\", 0};")
    317         Output()
    318         Output("if (PyArg_ParseTupleAndKeywords(_args, _kwds, \"O&\", kw, %s_Convert, &itself))",
    319                 self.prefix)
    320         OutLbrace()
    321         Output("((%s *)_self)->ob_itself = itself;", self.objecttype)
    322         Output("return 0;")
    323         OutRbrace()
    324         if self.prefix != 'CFTypeRefObj':
    325             Output()
    326             Output("/* Any CFTypeRef descendent is allowed as initializer too */")
    327             Output("if (PyArg_ParseTupleAndKeywords(_args, _kwds, \"O&\", kw, CFTypeRefObj_Convert, &itself))")
    328             OutLbrace()
    329             Output("((%s *)_self)->ob_itself = itself;", self.objecttype)
    330             Output("return 0;")
    331             OutRbrace()
    332         Output("return -1;")
    333 
    334 class CFTypeRefObjectDefinition(MyGlobalObjectDefinition):
    335     pass
    336 
    337 class CFArrayRefObjectDefinition(MyGlobalObjectDefinition):
    338     basetype = "CFTypeRef_Type"
    339 
    340     def outputRepr(self):
    341         Output()
    342         Output("static PyObject * %s_repr(%s *self)", self.prefix, self.objecttype)
    343         OutLbrace()
    344         Output("char buf[100];")
    345         Output("""sprintf(buf, "<CFArrayRef object at 0x%%8.8x for 0x%%8.8x>", (unsigned)self, (unsigned)self->ob_itself);""")
    346         Output("return PyString_FromString(buf);")
    347         OutRbrace()
    348 
    349 class CFMutableArrayRefObjectDefinition(MyGlobalObjectDefinition):
    350     basetype = "CFArrayRef_Type"
    351 
    352     def outputRepr(self):
    353         Output()
    354         Output("static PyObject * %s_repr(%s *self)", self.prefix, self.objecttype)
    355         OutLbrace()
    356         Output("char buf[100];")
    357         Output("""sprintf(buf, "<CFMutableArrayRef object at 0x%%8.8x for 0x%%8.8x>", (unsigned)self, (unsigned)self->ob_itself);""")
    358         Output("return PyString_FromString(buf);")
    359         OutRbrace()
    360 
    361 class CFDictionaryRefObjectDefinition(MyGlobalObjectDefinition):
    362     basetype = "CFTypeRef_Type"
    363 
    364     def outputRepr(self):
    365         Output()
    366         Output("static PyObject * %s_repr(%s *self)", self.prefix, self.objecttype)
    367         OutLbrace()
    368         Output("char buf[100];")
    369         Output("""sprintf(buf, "<CFDictionaryRef object at 0x%%8.8x for 0x%%8.8x>", (unsigned)self, (unsigned)self->ob_itself);""")
    370         Output("return PyString_FromString(buf);")
    371         OutRbrace()
    372 
    373 class CFMutableDictionaryRefObjectDefinition(MyGlobalObjectDefinition):
    374     basetype = "CFDictionaryRef_Type"
    375 
    376     def outputRepr(self):
    377         Output()
    378         Output("static PyObject * %s_repr(%s *self)", self.prefix, self.objecttype)
    379         OutLbrace()
    380         Output("char buf[100];")
    381         Output("""sprintf(buf, "<CFMutableDictionaryRef object at 0x%%8.8x for 0x%%8.8x>", (unsigned)self, (unsigned)self->ob_itself);""")
    382         Output("return PyString_FromString(buf);")
    383         OutRbrace()
    384 
    385 class CFDataRefObjectDefinition(MyGlobalObjectDefinition):
    386     basetype = "CFTypeRef_Type"
    387 
    388     def outputCheckConvertArg(self):
    389         Out("""
    390         if (v == Py_None) { *p_itself = NULL; return 1; }
    391         if (PyString_Check(v)) {
    392             char *cStr;
    393             int cLen;
    394             if( PyString_AsStringAndSize(v, &cStr, &cLen) < 0 ) return 0;
    395             *p_itself = CFDataCreate((CFAllocatorRef)NULL, (unsigned char *)cStr, cLen);
    396             return 1;
    397         }
    398         """)
    399 
    400     def outputRepr(self):
    401         Output()
    402         Output("static PyObject * %s_repr(%s *self)", self.prefix, self.objecttype)
    403         OutLbrace()
    404         Output("char buf[100];")
    405         Output("""sprintf(buf, "<CFDataRef object at 0x%%8.8x for 0x%%8.8x>", (unsigned)self, (unsigned)self->ob_itself);""")
    406         Output("return PyString_FromString(buf);")
    407         OutRbrace()
    408 
    409 class CFMutableDataRefObjectDefinition(MyGlobalObjectDefinition):
    410     basetype = "CFDataRef_Type"
    411 
    412     def outputRepr(self):
    413         Output()
    414         Output("static PyObject * %s_repr(%s *self)", self.prefix, self.objecttype)
    415         OutLbrace()
    416         Output("char buf[100];")
    417         Output("""sprintf(buf, "<CFMutableDataRef object at 0x%%8.8x for 0x%%8.8x>", (unsigned)self, (unsigned)self->ob_itself);""")
    418         Output("return PyString_FromString(buf);")
    419         OutRbrace()
    420 
    421 class CFStringRefObjectDefinition(MyGlobalObjectDefinition):
    422     basetype = "CFTypeRef_Type"
    423 
    424     def outputCheckConvertArg(self):
    425         Out("""
    426         if (v == Py_None) { *p_itself = NULL; return 1; }
    427         if (PyString_Check(v)) {
    428             char *cStr;
    429             if (!PyArg_Parse(v, "es", "ascii", &cStr))
    430                 return NULL;
    431                 *p_itself = CFStringCreateWithCString((CFAllocatorRef)NULL, cStr, kCFStringEncodingASCII);
    432                 PyMem_Free(cStr);
    433                 return 1;
    434         }
    435         if (PyUnicode_Check(v)) {
    436                 /* We use the CF types here, if Python was configured differently that will give an error */
    437                 CFIndex size = PyUnicode_GetSize(v);
    438                 UniChar *unichars = PyUnicode_AsUnicode(v);
    439                 if (!unichars) return 0;
    440                 *p_itself = CFStringCreateWithCharacters((CFAllocatorRef)NULL, unichars, size);
    441                 return 1;
    442         }
    443 
    444         """)
    445 
    446     def outputRepr(self):
    447         Output()
    448         Output("static PyObject * %s_repr(%s *self)", self.prefix, self.objecttype)
    449         OutLbrace()
    450         Output("char buf[100];")
    451         Output("""sprintf(buf, "<CFStringRef object at 0x%%8.8x for 0x%%8.8x>", (unsigned)self, (unsigned)self->ob_itself);""")
    452         Output("return PyString_FromString(buf);")
    453         OutRbrace()
    454 
    455 class CFMutableStringRefObjectDefinition(CFStringRefObjectDefinition):
    456     basetype = "CFStringRef_Type"
    457 
    458     def outputCheckConvertArg(self):
    459         # Mutable, don't allow Python strings
    460         return MyGlobalObjectDefinition.outputCheckConvertArg(self)
    461 
    462     def outputRepr(self):
    463         Output()
    464         Output("static PyObject * %s_repr(%s *self)", self.prefix, self.objecttype)
    465         OutLbrace()
    466         Output("char buf[100];")
    467         Output("""sprintf(buf, "<CFMutableStringRef object at 0x%%8.8x for 0x%%8.8x>", (unsigned)self, (unsigned)self->ob_itself);""")
    468         Output("return PyString_FromString(buf);")
    469         OutRbrace()
    470 
    471 class CFURLRefObjectDefinition(MyGlobalObjectDefinition):
    472     basetype = "CFTypeRef_Type"
    473 
    474     def outputRepr(self):
    475         Output()
    476         Output("static PyObject * %s_repr(%s *self)", self.prefix, self.objecttype)
    477         OutLbrace()
    478         Output("char buf[100];")
    479         Output("""sprintf(buf, "<CFURL object at 0x%%8.8x for 0x%%8.8x>", (unsigned)self, (unsigned)self->ob_itself);""")
    480         Output("return PyString_FromString(buf);")
    481         OutRbrace()
    482 
    483 
    484 # ADD object class here
    485 
    486 # From here on it's basically all boiler plate...
    487 
    488 # Create the generator groups and link them
    489 module = MacModule(MODNAME, MODPREFIX, includestuff, finalstuff, initstuff, variablestuff)
    490 CFTypeRef_object = CFTypeRefObjectDefinition('CFTypeRef', 'CFTypeRefObj', 'CFTypeRef')
    491 CFArrayRef_object = CFArrayRefObjectDefinition('CFArrayRef', 'CFArrayRefObj', 'CFArrayRef')
    492 CFMutableArrayRef_object = CFMutableArrayRefObjectDefinition('CFMutableArrayRef', 'CFMutableArrayRefObj', 'CFMutableArrayRef')
    493 CFDictionaryRef_object = CFDictionaryRefObjectDefinition('CFDictionaryRef', 'CFDictionaryRefObj', 'CFDictionaryRef')
    494 CFMutableDictionaryRef_object = CFMutableDictionaryRefObjectDefinition('CFMutableDictionaryRef', 'CFMutableDictionaryRefObj', 'CFMutableDictionaryRef')
    495 CFDataRef_object = CFDataRefObjectDefinition('CFDataRef', 'CFDataRefObj', 'CFDataRef')
    496 CFMutableDataRef_object = CFMutableDataRefObjectDefinition('CFMutableDataRef', 'CFMutableDataRefObj', 'CFMutableDataRef')
    497 CFStringRef_object = CFStringRefObjectDefinition('CFStringRef', 'CFStringRefObj', 'CFStringRef')
    498 CFMutableStringRef_object = CFMutableStringRefObjectDefinition('CFMutableStringRef', 'CFMutableStringRefObj', 'CFMutableStringRef')
    499 CFURLRef_object = CFURLRefObjectDefinition('CFURLRef', 'CFURLRefObj', 'CFURLRef')
    500 
    501 # ADD object here
    502 
    503 module.addobject(CFTypeRef_object)
    504 module.addobject(CFArrayRef_object)
    505 module.addobject(CFMutableArrayRef_object)
    506 module.addobject(CFDictionaryRef_object)
    507 module.addobject(CFMutableDictionaryRef_object)
    508 module.addobject(CFDataRef_object)
    509 module.addobject(CFMutableDataRef_object)
    510 module.addobject(CFStringRef_object)
    511 module.addobject(CFMutableStringRef_object)
    512 module.addobject(CFURLRef_object)
    513 # ADD addobject call here
    514 
    515 # Create the generator classes used to populate the lists
    516 Function = OSErrWeakLinkFunctionGenerator
    517 Method = OSErrWeakLinkMethodGenerator
    518 
    519 # Create and populate the lists
    520 functions = []
    521 CFTypeRef_methods = []
    522 CFArrayRef_methods = []
    523 CFMutableArrayRef_methods = []
    524 CFDictionaryRef_methods = []
    525 CFMutableDictionaryRef_methods = []
    526 CFDataRef_methods = []
    527 CFMutableDataRef_methods = []
    528 CFStringRef_methods = []
    529 CFMutableStringRef_methods = []
    530 CFURLRef_methods = []
    531 
    532 # ADD _methods initializer here
    533 execfile(INPUTFILE)
    534 
    535 
    536 # add the populated lists to the generator groups
    537 # (in a different wordl the scan program would generate this)
    538 for f in functions: module.add(f)
    539 for f in CFTypeRef_methods: CFTypeRef_object.add(f)
    540 for f in CFArrayRef_methods: CFArrayRef_object.add(f)
    541 for f in CFMutableArrayRef_methods: CFMutableArrayRef_object.add(f)
    542 for f in CFDictionaryRef_methods: CFDictionaryRef_object.add(f)
    543 for f in CFMutableDictionaryRef_methods: CFMutableDictionaryRef_object.add(f)
    544 for f in CFDataRef_methods: CFDataRef_object.add(f)
    545 for f in CFMutableDataRef_methods: CFMutableDataRef_object.add(f)
    546 for f in CFStringRef_methods: CFStringRef_object.add(f)
    547 for f in CFMutableStringRef_methods: CFMutableStringRef_object.add(f)
    548 for f in CFURLRef_methods: CFURLRef_object.add(f)
    549 
    550 # Manual generators for getting data out of strings
    551 
    552 getasstring_body = """
    553 int size = CFStringGetLength(_self->ob_itself)+1;
    554 char *data = malloc(size);
    555 
    556 if( data == NULL ) return PyErr_NoMemory();
    557 if ( CFStringGetCString(_self->ob_itself, data, size, 0) ) {
    558         _res = (PyObject *)PyString_FromString(data);
    559 } else {
    560         PyErr_SetString(PyExc_RuntimeError, "CFStringGetCString could not fit the string");
    561         _res = NULL;
    562 }
    563 free(data);
    564 return _res;
    565 """
    566 
    567 f = ManualGenerator("CFStringGetString", getasstring_body);
    568 f.docstring = lambda: "() -> (string _rv)"
    569 CFStringRef_object.add(f)
    570 
    571 getasunicode_body = """
    572 int size = CFStringGetLength(_self->ob_itself)+1;
    573 Py_UNICODE *data = malloc(size*sizeof(Py_UNICODE));
    574 CFRange range;
    575 
    576 range.location = 0;
    577 range.length = size;
    578 if( data == NULL ) return PyErr_NoMemory();
    579 CFStringGetCharacters(_self->ob_itself, range, data);
    580 _res = (PyObject *)PyUnicode_FromUnicode(data, size-1);
    581 free(data);
    582 return _res;
    583 """
    584 
    585 f = ManualGenerator("CFStringGetUnicode", getasunicode_body);
    586 f.docstring = lambda: "() -> (unicode _rv)"
    587 CFStringRef_object.add(f)
    588 
    589 # Get data from CFDataRef
    590 getasdata_body = """
    591 int size = CFDataGetLength(_self->ob_itself);
    592 char *data = (char *)CFDataGetBytePtr(_self->ob_itself);
    593 
    594 _res = (PyObject *)PyString_FromStringAndSize(data, size);
    595 return _res;
    596 """
    597 
    598 f = ManualGenerator("CFDataGetData", getasdata_body);
    599 f.docstring = lambda: "() -> (string _rv)"
    600 CFDataRef_object.add(f)
    601 
    602 # Manual generator for CFPropertyListCreateFromXMLData because of funny error return
    603 fromxml_body = """
    604 CFTypeRef _rv;
    605 CFOptionFlags mutabilityOption;
    606 CFStringRef errorString;
    607 if (!PyArg_ParseTuple(_args, "l",
    608                       &mutabilityOption))
    609         return NULL;
    610 _rv = CFPropertyListCreateFromXMLData((CFAllocatorRef)NULL,
    611                                       _self->ob_itself,
    612                                       mutabilityOption,
    613                                       &errorString);
    614 if (errorString)
    615         CFRelease(errorString);
    616 if (_rv == NULL) {
    617         PyErr_SetString(PyExc_RuntimeError, "Parse error in XML data");
    618         return NULL;
    619 }
    620 _res = Py_BuildValue("O&",
    621                      CFTypeRefObj_New, _rv);
    622 return _res;
    623 """
    624 f = ManualGenerator("CFPropertyListCreateFromXMLData", fromxml_body)
    625 f.docstring = lambda: "(CFOptionFlags mutabilityOption) -> (CFTypeRefObj)"
    626 CFTypeRef_object.add(f)
    627 
    628 # Convert CF objects to Python objects
    629 toPython_body = """
    630 _res = PyCF_CF2Python(_self->ob_itself);
    631 return _res;
    632 """
    633 
    634 f = ManualGenerator("toPython", toPython_body);
    635 f.docstring = lambda: "() -> (python_object)"
    636 CFTypeRef_object.add(f)
    637 
    638 toCF_body = """
    639 CFTypeRef rv;
    640 CFTypeID typeid;
    641 
    642 if (!PyArg_ParseTuple(_args, "O&", PyCF_Python2CF, &rv))
    643         return NULL;
    644 typeid = CFGetTypeID(rv);
    645 
    646 if (typeid == CFStringGetTypeID())
    647         return Py_BuildValue("O&", CFStringRefObj_New, rv);
    648 if (typeid == CFArrayGetTypeID())
    649         return Py_BuildValue("O&", CFArrayRefObj_New, rv);
    650 if (typeid == CFDictionaryGetTypeID())
    651         return Py_BuildValue("O&", CFDictionaryRefObj_New, rv);
    652 if (typeid == CFURLGetTypeID())
    653         return Py_BuildValue("O&", CFURLRefObj_New, rv);
    654 
    655 _res = Py_BuildValue("O&", CFTypeRefObj_New, rv);
    656 return _res;
    657 """
    658 f = ManualGenerator("toCF", toCF_body);
    659 f.docstring = lambda: "(python_object) -> (CF_object)"
    660 module.add(f)
    661 
    662 # ADD add forloop here
    663 
    664 # generate output (open the output file as late as possible)
    665 SetOutputFileName(OUTPUTFILE)
    666 module.generate()
    667