1999-03-04 23:54:29 +01:00
|
|
|
# Scan an Apple header file, generating a Python file of generator calls.
|
|
|
|
|
|
|
|
import sys
|
|
|
|
import os
|
2002-08-05 17:39:30 +02:00
|
|
|
from bgenlocations import TOOLBOXDIR, BGENDIR
|
1999-03-04 23:54:29 +01:00
|
|
|
sys.path.append(BGENDIR)
|
|
|
|
from scantools import Scanner
|
|
|
|
|
|
|
|
LONG = "Appearance"
|
|
|
|
SHORT = "app"
|
2002-01-06 00:37:19 +01:00
|
|
|
OBJECT = "ThemeDrawingState"
|
1999-03-04 23:54:29 +01:00
|
|
|
|
|
|
|
def main():
|
|
|
|
input = LONG + ".h"
|
|
|
|
output = SHORT + "gen.py"
|
|
|
|
defsoutput = TOOLBOXDIR + LONG + ".py"
|
|
|
|
scanner = MyScanner(input, output, defsoutput)
|
|
|
|
scanner.scan()
|
|
|
|
scanner.close()
|
2002-08-15 23:48:16 +02:00
|
|
|
print "=== Testing definitions output code ==="
|
|
|
|
execfile(defsoutput, {}, {})
|
1999-03-04 23:54:29 +01:00
|
|
|
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):
|
|
|
|
|
|
|
|
def destination(self, type, name, arglist):
|
|
|
|
classname = "Function"
|
|
|
|
listname = "functions"
|
|
|
|
if arglist:
|
|
|
|
t, n, m = arglist[0]
|
|
|
|
# This is non-functional today
|
|
|
|
if t == OBJECT and m == "InMode":
|
|
|
|
classname = "Method"
|
|
|
|
listname = "methods"
|
|
|
|
return classname, listname
|
|
|
|
|
|
|
|
def writeinitialdefs(self):
|
|
|
|
self.defsfile.write("def FOUR_CHAR_CODE(x): return x\n")
|
|
|
|
|
|
|
|
def makeblacklistnames(self):
|
|
|
|
return [
|
1999-12-10 17:16:19 +01:00
|
|
|
"GetThemeFont", # Funny stringbuffer in/out parameter, I think...
|
2000-12-19 22:33:51 +01:00
|
|
|
# Constants with funny definitions
|
|
|
|
"appearanceBadBrushIndexErr",
|
|
|
|
"appearanceProcessRegisteredErr",
|
|
|
|
"appearanceProcessNotRegisteredErr",
|
|
|
|
"appearanceBadTextColorIndexErr",
|
|
|
|
"appearanceThemeHasNoAccents",
|
|
|
|
"appearanceBadCursorIndexErr",
|
1999-03-04 23:54:29 +01:00
|
|
|
]
|
|
|
|
|
2000-12-11 00:43:49 +01:00
|
|
|
def makegreylist(self):
|
|
|
|
return [
|
|
|
|
('#if TARGET_API_MAC_CARBON', [
|
|
|
|
'GetThemeMetric',
|
2001-12-16 21:18:40 +01:00
|
|
|
'GetThemeTextShadowOutset',
|
|
|
|
'GetThemeTextDimensions',
|
|
|
|
'TruncateThemeText',
|
2002-01-02 16:11:44 +01:00
|
|
|
'DrawThemeTextBox',
|
2000-12-11 00:43:49 +01:00
|
|
|
])]
|
|
|
|
|
1999-03-04 23:54:29 +01:00
|
|
|
def makeblacklisttypes(self):
|
|
|
|
return [
|
|
|
|
"MenuTitleDrawingUPP",
|
|
|
|
"MenuItemDrawingUPP",
|
1999-12-10 17:16:19 +01:00
|
|
|
"ThemeIteratorUPP",
|
|
|
|
"ThemeTabTitleDrawUPP",
|
2002-01-07 00:03:39 +01:00
|
|
|
# "ThemeEraseUPP",
|
|
|
|
# "ThemeButtonDrawUPP",
|
1999-12-10 17:16:19 +01:00
|
|
|
"WindowTitleDrawingUPP",
|
|
|
|
"ProcessSerialNumber_ptr", # Too much work for now.
|
|
|
|
"ThemeTrackDrawInfo_ptr", # Too much work
|
2002-01-07 00:03:39 +01:00
|
|
|
# "ThemeButtonDrawInfo_ptr", # ditto
|
1999-12-10 17:16:19 +01:00
|
|
|
"ThemeWindowMetrics_ptr", # ditto
|
2002-01-06 00:37:19 +01:00
|
|
|
# "ThemeDrawingState", # This is an opaque pointer, so it should be simple. Later.
|
1999-12-10 17:16:19 +01:00
|
|
|
"Collection", # No interface to collection mgr yet.
|
2001-12-16 21:18:40 +01:00
|
|
|
"BytePtr", # Not yet.
|
1999-03-04 23:54:29 +01:00
|
|
|
]
|
|
|
|
|
|
|
|
def makerepairinstructions(self):
|
|
|
|
return [
|
2002-01-02 16:11:44 +01:00
|
|
|
([("void", 'inContext', "OutMode")],
|
|
|
|
[("NULL", 'inContext', "InMode")]),
|
|
|
|
([("Point", 'ioBounds', "OutMode")],
|
|
|
|
[("Point", 'ioBounds', "InOutMode")]),
|
1999-03-04 23:54:29 +01:00
|
|
|
]
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
main()
|