cfscan.py :  » Language-Interface » ChinesePython » chinesepython2.1.3-0.4 » Mac » Modules » cf » Python Open Source

Home
Python Open Source
1.3.1.2 Python
2.Ajax
3.Aspect Oriented
4.Blog
5.Build
6.Business Application
7.Chart Report
8.Content Management Systems
9.Cryptographic
10.Database
11.Development
12.Editor
13.Email
14.ERP
15.Game 2D 3D
16.GIS
17.GUI
18.IDE
19.Installer
20.IRC
21.Issue Tracker
22.Language Interface
23.Log
24.Math
25.Media Sound Audio
26.Mobile
27.Network
28.Parser
29.PDF
30.Project Management
31.RSS
32.Search
33.Security
34.Template Engines
35.Test
36.UML
37.USB Serial
38.Web Frameworks
39.Web Server
40.Web Services
41.Web Unit
42.Wiki
43.Windows
44.XML
Python Open Source » Language Interface » ChinesePython 
ChinesePython » chinesepython2.1.3 0.4 » Mac » Modules » cf » cfscan.py
# Scan an Apple header file, generating a Python file of generator calls.

import sys
import os
BGENDIR=os.path.join(sys.prefix, ':Tools:bgen:bgen')
sys.path.append(BGENDIR)
from scantools import Scanner_OSX
from bgenlocations import TOOLBOXDIR

LONG = "CoreFoundation"
SHORT = "cf"
OBJECTS = ("CFTypeRef", 
    "CFArrayRef", "CFMutableArrayRef",
    "CFDataRef", "CFMutableDataRef",
    "CFDictionaryRef", "CFMutableDictionaryRef",
    "CFStringRef", "CFMutableStringRef",
    "CFURLRef",
    )
# ADD object typenames here

def main():
  input = [
    "CFBase.h",
    "CFArray.h",
##    "CFBag.h",
##    "CFBundle.h",
##    "CFCharacterSet.h",
    "CFData.h",
##    "CFDate.h",
    "CFDictionary.h",
##    "CFNumber.h",
##    "CFPlugIn.h",
##    "CFPreferences.h",
##    "CFPropertyList.h",
##    "CFSet.h",
    "CFString.h",
##    "CFStringEncodingExt.h",
##    "CFTimeZone.h",
    "CFURL.h",
    ]
  output = SHORT + "gen.py"
  defsoutput = TOOLBOXDIR + LONG + ".py"
  scanner = MyScanner(input, output, defsoutput)
  scanner.scan()
  scanner.gentypetest(SHORT+"typetest.py")
  scanner.close()
  print "=== Done scanning and generating, now importing the generated code... ==="
  exec "import " + SHORT + "support"
  print "=== Done.  It's up to you to compile it now! ==="

class MyScanner(Scanner_OSX):

  def destination(self, type, name, arglist):
    classname = "Function"
    listname = "functions"
    if arglist:
      t, n, m = arglist[0]
      if t in OBJECTS and m == "InMode":
        classname = "Method"
        listname = t + "_methods"
      # Special case for the silly first AllocatorRef argument
      if t == 'CFAllocatorRef' and m == 'InMode' and len(arglist) > 1:
        t, n, m = arglist[1]
        if t in OBJECTS and m == "InMode":
          classname = "MethodSkipArg1"
          listname = t + "_methods"
    return classname, listname

  def writeinitialdefs(self):
    self.defsfile.write("def FOUR_CHAR_CODE(x): return x\n")

  def makeblacklistnames(self):
    return [
      # Memory allocator functions
      "CFAllocatorGetDefault",
      "CFAllocatorSetDefault",
      "CFAllocatorAllocate",
      "CFAllocatorReallocate",
      "CFAllocatorDeallocate",
      "CFGetAllocator",
      # Array functions we skip for now.
      "CFArrayGetValueAtIndex",
      # Data pointer functions. Skip for now.
      "CFDataGetBytePtr",
      "CFDataGetMutableBytePtr",
      "CFDataGetBytes",   # XXXX Should support this one
      # String functions
      "CFStringGetPascalString", # Use the C-string methods.
      "CFStringGetPascalStringPtr", # TBD automatically
      "CFStringGetCStringPtr", 
      "CFStringGetCharactersPtr",
      "CFStringGetCString", 
      "CFStringGetCharacters",
      "CFURLCreateStringWithFileSystemPath", # Gone in later releases
      ]

  def makegreylist(self):
    return []

  def makeblacklisttypes(self):
    return [
      "CFComparatorFunction", # Callback function pointer
      "CFAllocatorContext", # Not interested in providing our own allocator
      "void_ptr_ptr",  # Tricky. This is the initializer for arrays...
      "void_ptr", # Ditto for various array lookup methods
      "CFArrayApplierFunction", # Callback function pointer
      "CFDictionaryApplierFunction", # Callback function pointer
      "UniChar_ptr", # XXXX To be done
      "const_UniChar_ptr", # XXXX To be done
      "UniChar", # XXXX To be done
      "va_list", # For printf-to-a-cfstring. Use Python.
      "const_CFStringEncoding_ptr", # To be done, I guess
      ]

  def makerepairinstructions(self):
    return [
      # Buffers in CF seem to be passed as UInt8 * normally.
      ([("UInt8_ptr", "*", "InMode"), ("CFIndex", "*", "InMode")],
       [("UcharInBuffer", "*", "*")]),
       
      # Some functions return a const char *. Don't worry, we won't modify it.
      ([("const_char_ptr", "*", "ReturnMode")],
       [("return_stringptr", "*", "*")]),
       
      # base URLs are optional (pass None for NULL)
      ([("CFURLRef", "baseURL", "InMode")],
       [("OptionalCFURLRef", "*", "*")]),
       
      ]
      
if __name__ == "__main__":
  main()
www.java2java.com | Contact Us
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.