symbian-qemu-0.9.1-12/python-2.6.1/Mac/Modules/cf/cfsupport.py
changeset 1 2fb8b9db1c86
equal deleted inserted replaced
0:ffa851df0825 1:2fb8b9db1c86
       
     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()