]> granicus.if.org Git - python/commitdiff
First step in porting MacPython modules to OSX/unix: break all references between...
authorJack Jansen <jack.jansen@cwi.nl>
Thu, 17 May 2001 21:58:34 +0000 (21:58 +0000)
committerJack Jansen <jack.jansen@cwi.nl>
Thu, 17 May 2001 21:58:34 +0000 (21:58 +0000)
And these can now be vectored through glue routines (by defining USE_TOOLBOX_OBJECT_GLUE) which will do the necessary imports, whereupon the module's init routine will tell the glue routine about the real conversion routine address and everything is fine again.

26 files changed:
Mac/Modules/ae/AEmodule.c
Mac/Modules/ae/aesupport.py
Mac/Modules/cm/Cmmodule.c
Mac/Modules/cm/cmsupport.py
Mac/Modules/ctl/Ctlmodule.c
Mac/Modules/ctl/ctlsupport.py
Mac/Modules/dlg/Dlgmodule.c
Mac/Modules/dlg/dlgsupport.py
Mac/Modules/drag/Dragmodule.c
Mac/Modules/drag/dragsupport.py
Mac/Modules/list/Listmodule.c
Mac/Modules/list/listsupport.py
Mac/Modules/menu/Menumodule.c
Mac/Modules/menu/menusupport.py
Mac/Modules/qd/Qdmodule.c
Mac/Modules/qd/qdsupport.py
Mac/Modules/qdoffs/Qdoffsmodule.c
Mac/Modules/qdoffs/qdoffssupport.py
Mac/Modules/qt/Qtmodule.c
Mac/Modules/qt/qtsupport.py
Mac/Modules/res/Resmodule.c
Mac/Modules/res/ressupport.py
Mac/Modules/te/TEmodule.c
Mac/Modules/te/tesupport.py
Mac/Modules/win/Winmodule.c
Mac/Modules/win/winsupport.py

index e0ce470508cf366b987b5054b34cfb3a9f8961d7..d4aab79be7e0a612de50e772bc663602ff234816 100644 (file)
 #include <AppleEvents.h>
 #include <AEObjects.h>
 
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_AEDesc_New(AEDesc *);
+extern int _AEDesc_Convert(PyObject *, AEDesc *);
+
+#define AEDesc_New _AEDesc_New
+#define AEDesc_Convert _AEDesc_Convert
+#endif
+
 static pascal OSErr GenericEventHandler(); /* Forward */
 
 AEEventHandlerUPP upp_GenericEventHandler;
@@ -1331,6 +1339,8 @@ void initAE()
 
                upp_AEIdleProc = NewAEIdleProc(AEIdleProc);
                upp_GenericEventHandler = NewAEEventHandlerProc(GenericEventHandler);
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(AEDesc_New);
+               PyMac_INIT_TOOLBOX_OBJECT_CONVERT(AEDesc_Convert);
 
 
        m = Py_InitModule("AE", AE_methods);
index 86f20949ae908ceea1d40963499904b249fca196..094a30966983d259ae5e763770535c39968d48c2 100644 (file)
@@ -85,6 +85,14 @@ includestuff = includestuff + """
 #include <AppleEvents.h>
 #include <AEObjects.h>
 
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_AEDesc_New(AEDesc *);
+extern int _AEDesc_Convert(PyObject *, AEDesc *);
+
+#define AEDesc_New _AEDesc_New
+#define AEDesc_Convert _AEDesc_Convert
+#endif
+
 static pascal OSErr GenericEventHandler(); /* Forward */
 
 AEEventHandlerUPP upp_GenericEventHandler;
@@ -138,6 +146,8 @@ GenericEventHandler(const AppleEvent *request, AppleEvent *reply, unsigned long
 initstuff = initstuff + """
        upp_AEIdleProc = NewAEIdleProc(AEIdleProc);
        upp_GenericEventHandler = NewAEEventHandlerProc(GenericEventHandler);
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(AEDesc_New);
+       PyMac_INIT_TOOLBOX_OBJECT_CONVERT(AEDesc_Convert);
 """
 
 module = MacModule('AE', 'AE', includestuff, finalstuff, initstuff)
index 93a3e09841c167f7a4b8923fdce827b1ad5c8d52..5e8a17c443a00263e9cab2f12df07cd8ce81136e 100644 (file)
@@ -9,6 +9,17 @@
 #include "pymactoolbox.h"
 
 #include <Components.h>
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_CmpObj_New(Component);
+extern int _CmpObj_Convert(PyObject *, Component *);
+extern PyObject *_CmpInstObj_New(ComponentInstance);
+extern int _CmpInstObj_Convert(PyObject *, ComponentInstance *);
+
+#define CmpObj_New _CmpObj_New
+#define CmpObj_Convert _CmpObj_Convert
+#define CmpInstObj_New _CmpInstObj_New
+#define CmpInstObj_Convert _CmpInstObj_Convert
+#endif
 
 /*
 ** Parse/generate ComponentDescriptor records
@@ -825,6 +836,11 @@ void initCm()
 
 
 
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(CmpObj_New);
+               PyMac_INIT_TOOLBOX_OBJECT_CONVERT(CmpObj_Convert);
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(CmpInstObj_New);
+               PyMac_INIT_TOOLBOX_OBJECT_CONVERT(CmpInstObj_Convert);
+
 
        m = Py_InitModule("Cm", Cm_methods);
        d = PyModule_GetDict(m);
index 598b51de2facce33d5f6bf0fba93db154fc9cbf7..5681c8130a133c7e768217f0d451e049c25420dd 100644 (file)
@@ -22,6 +22,17 @@ from macsupport import *
 
 includestuff = includestuff + """
 #include <%s>""" % MACHEADERFILE + """
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_CmpObj_New(Component);
+extern int _CmpObj_Convert(PyObject *, Component *);
+extern PyObject *_CmpInstObj_New(ComponentInstance);
+extern int _CmpInstObj_Convert(PyObject *, ComponentInstance *);
+
+#define CmpObj_New _CmpObj_New
+#define CmpObj_Convert _CmpObj_Convert
+#define CmpInstObj_New _CmpInstObj_New
+#define CmpInstObj_Convert _CmpInstObj_Convert
+#endif
 
 /*
 ** Parse/generate ComponentDescriptor records
@@ -52,6 +63,13 @@ CmpDesc_Convert(v, p_itself)
 
 """
 
+initstuff = initstuff + """
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(CmpObj_New);
+       PyMac_INIT_TOOLBOX_OBJECT_CONVERT(CmpObj_Convert);
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(CmpInstObj_New);
+       PyMac_INIT_TOOLBOX_OBJECT_CONVERT(CmpInstObj_Convert);
+"""
+
 ComponentDescription = OpaqueType('ComponentDescription', 'CmpDesc')
 Component = OpaqueByValueType('Component', C_OBJECTPREFIX)
 ComponentInstance = OpaqueByValueType('ComponentInstance', CI_OBJECTPREFIX)
index 91df945178f7658d9a2e67477ec92cb6f6c359a4..083929deb4301ab64d320b9403a4c18ab5c11313 100644 (file)
 #include <ControlDefinitions.h>
 #endif
 
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_CtlObj_New(ControlHandle);
+extern int _CtlObj_Convert(PyObject *, ControlHandle *);
+
+#define CtlObj_New _CtlObj_New
+#define CtlObj_Convert _CtlObj_Convert
+#endif
+
 staticforward PyObject *CtlObj_WhichControl(ControlHandle);
 
 #define as_Control(h) ((ControlHandle)h)
@@ -2925,6 +2933,8 @@ void initCtl()
        myidleproc_upp = NewControlUserPaneIdleProc(myidleproc);
        myhittestproc_upp = NewControlUserPaneHitTestProc(myhittestproc);
        mytrackingproc_upp = NewControlUserPaneTrackingProc(mytrackingproc);
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(CtlObj_New);
+       PyMac_INIT_TOOLBOX_OBJECT_CONVERT(CtlObj_Convert);
 
 
        m = Py_InitModule("Ctl", Ctl_methods);
index 557ff48c6fe4578d73cb2b40a2ffc63369c114e3..da28d041d32fbf12d0f8a48d1497a683b781a474 100644 (file)
@@ -54,6 +54,14 @@ includestuff = includestuff + """
 #include <ControlDefinitions.h>
 #endif
 
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_CtlObj_New(ControlHandle);
+extern int _CtlObj_Convert(PyObject *, ControlHandle *);
+
+#define CtlObj_New _CtlObj_New
+#define CtlObj_Convert _CtlObj_Convert
+#endif
+
 staticforward PyObject *CtlObj_WhichControl(ControlHandle);
 
 #define as_Control(h) ((ControlHandle)h)
@@ -316,6 +324,8 @@ mydrawproc_upp = NewControlUserPaneDrawProc(mydrawproc);
 myidleproc_upp = NewControlUserPaneIdleProc(myidleproc);
 myhittestproc_upp = NewControlUserPaneHitTestProc(myhittestproc);
 mytrackingproc_upp = NewControlUserPaneTrackingProc(mytrackingproc);
+PyMac_INIT_TOOLBOX_OBJECT_NEW(CtlObj_New);
+PyMac_INIT_TOOLBOX_OBJECT_CONVERT(CtlObj_Convert);
 """
 
 class MyObjectDefinition(ObjectIdentityMixin, GlobalObjectDefinition):
index 2262b544e678b70fbf63434e8ba89bfbc752f545..be68b75c107fc8d5c57ed3bb63d6fa1cb067d21b 100644 (file)
@@ -9,6 +9,15 @@
 #include "pymactoolbox.h"
 
 #include <Dialogs.h>
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_DlgObj_New(DialogRef);
+extern PyObject *_DlgObj_WhichDialog(DialogRef);
+extern int _DlgObj_Convert(PyObject *, DialogRef *);
+
+#define DlgObj_New _DlgObj_New
+#define DlgObj_WhichDialog _DlgObj_WhichDialog
+#define DlgObj_Convert _DlgObj_Convert
+#endif
 
 #if !ACCESSOR_CALLS_ARE_FUNCTIONS
 #define GetDialogTextEditHandle(dlg) (((DialogPeek)(dlg))->textH)
@@ -1468,7 +1477,7 @@ static PyMethodDef Dlg_methods[] = {
 
 
 /* Return the WindowPtr corresponding to a DialogObject */
-
+#if 0
 WindowPtr
 DlgObj_ConvertToWindow(self)
        PyObject *self;
@@ -1477,6 +1486,7 @@ DlgObj_ConvertToWindow(self)
                return GetDialogWindow(((DialogObject *)self)->ob_itself);
        return NULL;
 }
+#endif
 /* Return the object corresponding to the dialog, or None */
 
 PyObject *
@@ -1516,6 +1526,10 @@ void initDlg()
 
 
 
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(DlgObj_New);
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(DlgObj_WhichDialog);
+               PyMac_INIT_TOOLBOX_OBJECT_CONVERT(DlgObj_Convert);
+
 
        m = Py_InitModule("Dlg", Dlg_methods);
        d = PyModule_GetDict(m);
index 594b7a87eb8d5b7c55f5a42f290160849c102553..460d3b95433ede168ad8258eec9d6e533f15c03f 100644 (file)
@@ -32,6 +32,15 @@ EventMask = Type("EventMask", "H")
 
 includestuff = includestuff + """
 #include <Dialogs.h>
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_DlgObj_New(DialogRef);
+extern PyObject *_DlgObj_WhichDialog(DialogRef);
+extern int _DlgObj_Convert(PyObject *, DialogRef *);
+
+#define DlgObj_New _DlgObj_New
+#define DlgObj_WhichDialog _DlgObj_WhichDialog
+#define DlgObj_Convert _DlgObj_Convert
+#endif
 
 #if !ACCESSOR_CALLS_ARE_FUNCTIONS
 #define GetDialogTextEditHandle(dlg) (((DialogPeek)(dlg))->textH)
@@ -139,7 +148,7 @@ extern PyMethodChain WinObj_chain;
 
 finalstuff = finalstuff + """
 /* Return the WindowPtr corresponding to a DialogObject */
-
+#if 0
 WindowPtr
 DlgObj_ConvertToWindow(self)
        PyObject *self;
@@ -148,6 +157,7 @@ DlgObj_ConvertToWindow(self)
                return GetDialogWindow(((DialogObject *)self)->ob_itself);
        return NULL;
 }
+#endif
 /* Return the object corresponding to the dialog, or None */
 
 PyObject *
@@ -180,6 +190,12 @@ DlgObj_WhichDialog(d)
 }
 """
 
+initstuff = initstuff + """
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(DlgObj_New);
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(DlgObj_WhichDialog);
+       PyMac_INIT_TOOLBOX_OBJECT_CONVERT(DlgObj_Convert);
+"""
+
 
 # Define a class which specializes our object definition
 class MyObjectDefinition(GlobalObjectDefinition):
index fa6c2d9dbcdb8b847dd422ceddea3604e436bb2d..3ce19b746329aff29baf6f2c2edf2a438ea2a4b0 100644 (file)
@@ -19,6 +19,14 @@ DragInputUPP dragglue_InputUPP;
 DragDrawingUPP dragglue_DrawingUPP;
 #endif
 
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_DragObj_New(DragRef);
+extern int _DragObj_Convert(PyObject *, DragRef *);
+
+#define DragObj_New _DragObj_New
+#define DragObj_Convert _DragObj_Convert
+#endif
+
 static PyObject *Drag_Error;
 
 /* ---------------------- Object type DragObj ----------------------- */
@@ -1040,6 +1048,9 @@ void initDrag()
 
 
 
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(DragObj_New);
+               PyMac_INIT_TOOLBOX_OBJECT_CONVERT(DragObj_Convert);
+
 
        m = Py_InitModule("Drag", Drag_methods);
        d = PyModule_GetDict(m);
index d90acc998deeeb1a30aa7622948b15922bc64387..79bf00cf88ccdd683ff02e4334e502bd4d798b1c 100644 (file)
@@ -54,6 +54,14 @@ DragSendDataUPP dragglue_SendDataUPP;
 DragInputUPP dragglue_InputUPP;
 DragDrawingUPP dragglue_DrawingUPP;
 #endif
+
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_DragObj_New(DragRef);
+extern int _DragObj_Convert(PyObject *, DragRef *);
+
+#define DragObj_New _DragObj_New
+#define DragObj_Convert _DragObj_Convert
+#endif
 """
 
 finalstuff = finalstuff + """
@@ -153,6 +161,11 @@ dragglue_Drawing(xxxx
 
 """
 
+initstuff = initstuff + """
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(DragObj_New);
+       PyMac_INIT_TOOLBOX_OBJECT_CONVERT(DragObj_Convert);
+"""
+
 variablestuff = """
 dragglue_TrackingHandlerUPP = NewDragTrackingHandlerProc(dragglue_TrackingHandler);
 dragglue_ReceiveHandlerUPP = NewDragReceiveHandlerProc(dragglue_ReceiveHandler);
index 050981224b1824b564a11c62f078b58bfb487d45..53d070f07dd20b96fdbc1547ccb90862e3e9f6e4 100644 (file)
 
 #include <Lists.h>
 
+
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_ListObj_New(ListHandle);
+extern int _ListObj_Convert(PyObject *, ListHandle *);
+
+#define ListObj_New _ListObj_New
+#define ListObj_Convert _ListObj_Convert
+#endif
+
 #if !ACCESSOR_CALLS_ARE_FUNCTIONS
 #define GetListPort(list) ((CGrafPtr)(*(list))->port)
 #define GetListVerticalScrollBar(list) ((*(list))->vScroll)
@@ -1066,6 +1075,9 @@ void initList()
 
 
 
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(ListObj_New);
+               PyMac_INIT_TOOLBOX_OBJECT_CONVERT(ListObj_Convert);
+
 
        m = Py_InitModule("List", List_methods);
        d = PyModule_GetDict(m);
index ecf8392949f769b8a23e84f7c2faa70d0e67edfc..751f16b14847fde63d78490c61cd936956ab1ff1 100644 (file)
@@ -37,6 +37,15 @@ CGrafPtr = OpaqueByValueType("CGrafPtr", "GrafObj")
 includestuff = includestuff + """
 #include <%s>""" % MACHEADERFILE + """
 
+
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_ListObj_New(ListHandle);
+extern int _ListObj_Convert(PyObject *, ListHandle *);
+
+#define ListObj_New _ListObj_New
+#define ListObj_Convert _ListObj_Convert
+#endif
+
 #if !ACCESSOR_CALLS_ARE_FUNCTIONS
 #define GetListPort(list) ((CGrafPtr)(*(list))->port)
 #define GetListVerticalScrollBar(list) ((*(list))->vScroll)
@@ -66,6 +75,11 @@ includestuff = includestuff + """
 #define as_Resource(lh) ((Handle)lh)
 """
 
+initstuff = initstuff + """
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(ListObj_New);
+       PyMac_INIT_TOOLBOX_OBJECT_CONVERT(ListObj_Convert);
+"""
+
 class ListMethodGenerator(MethodGenerator):
        """Similar to MethodGenerator, but has self as last argument"""
 
index 782b2706ab6b4bc1a897536fd953c39f316d73c8..f965586252f697acc25c1c0b5dfe4679522a35de 100644 (file)
 #include <Devices.h> /* Defines OpenDeskAcc in universal headers */
 #include <Menus.h>
 
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+
+extern PyObject *_MenuObj_New(MenuHandle);
+extern int _MenuObj_Convert(PyObject *, MenuHandle *);
+
+#define MenuObj_New _MenuObj_New
+#define MenuObj_Convert _MenuObj_Convert 
+#endif
+
 #if !ACCESSOR_CALLS_ARE_FUNCTIONS
 #define GetMenuID(menu) ((*(menu))->menuID)
 #define GetMenuWidth(menu) ((*(menu))->menuWidth)
@@ -2780,6 +2789,9 @@ void initMenu()
 
 
 
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(MenuObj_New);
+               PyMac_INIT_TOOLBOX_OBJECT_CONVERT(MenuObj_Convert);
+
 
        m = Py_InitModule("Menu", Menu_methods);
        d = PyModule_GetDict(m);
index 20b4f3650d9454622517999a6eef4b26b6191a4e..4de26a2f0041e1ec61b5f6b90d0bf54f0a0fd501 100644 (file)
@@ -39,6 +39,15 @@ includestuff = includestuff + """
 #include <Devices.h> /* Defines OpenDeskAcc in universal headers */
 #include <%s>""" % MACHEADERFILE + """
 
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+
+extern PyObject *_MenuObj_New(MenuHandle);
+extern int _MenuObj_Convert(PyObject *, MenuHandle *);
+
+#define MenuObj_New _MenuObj_New
+#define MenuObj_Convert _MenuObj_Convert 
+#endif
+
 #if !ACCESSOR_CALLS_ARE_FUNCTIONS
 #define GetMenuID(menu) ((*(menu))->menuID)
 #define GetMenuWidth(menu) ((*(menu))->menuWidth)
@@ -53,6 +62,11 @@ includestuff = includestuff + """
 #define as_Resource(h) ((Handle)h)
 """
 
+initstuff = initstuff + """
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(MenuObj_New);
+       PyMac_INIT_TOOLBOX_OBJECT_CONVERT(MenuObj_Convert);
+"""
+
 class MyObjectDefinition(GlobalObjectDefinition):
        pass
 
index 12f44f4111fc4b9ffd0f2336fff66bf1df5a168f..9c3280e07158059faa4be0d495a9feaa5f27f20a 100644 (file)
 
 #include <QuickDraw.h>
 
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_GrafObj_New(GrafPtr);
+extern int _GrafObj_Convert(PyObject *, GrafPtr *);
+extern PyObject *_BMObj_New(BitMapPtr);
+extern int _BMObj_Convert(PyObject *, BitMapPtr *);
+extern PyObject *_QdRGB_New(RGBColorPtr);
+extern int _QdRGB_Convert(PyObject *, RGBColorPtr *);
+
+#define GrafObj_New _GrafObj_New
+#define GrafObj_Convert _GrafObj_Convert
+#define BMObj_New _BMObj_New
+#define BMObj_Convert _BMObj_Convert
+#define QdRGB_New _QdRGB_New
+#define QdRGB_Convert _QdRGB_Convert
+#endif
+
 #if !ACCESSOR_CALLS_ARE_FUNCTIONS
 #define GetPortBitMapForCopyBits(port) ((const struct BitMap *)&((GrafPort *)(port))->portBits)
 #define GetPortPixMap(port) (((CGrafPtr)(port))->portPixMap)
@@ -144,6 +160,16 @@ GrafObj_Convert(v, p_itself)
        PyObject *v;
        GrafPtr *p_itself;
 {
+#if 1
+       {
+               WindowRef win;
+               if (WinObj_Convert(v, &win) && v) {
+                       *p_itself = (GrafPtr)GetWindowPort(win);
+                       return 1;
+               }
+               PyErr_Clear();
+       }
+#else
        if (DlgObj_Check(v)) {
                DialogRef dlg = (DialogRef)((GrafPortObject *)v)->ob_itself;
                *p_itself = (GrafPtr)GetWindowPort(GetDialogWindow(dlg));
@@ -154,6 +180,7 @@ GrafObj_Convert(v, p_itself)
                *p_itself = (GrafPtr)GetWindowPort(win);
                return 1;
        }
+#endif
        if (!GrafObj_Check(v))
        {
                PyErr_SetString(PyExc_TypeError, "GrafPort required");
@@ -6194,6 +6221,13 @@ void initQd()
 
 
 
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(BMObj_New);
+               PyMac_INIT_TOOLBOX_OBJECT_CONVERT(BMObj_Convert);
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(GrafObj_New);
+               PyMac_INIT_TOOLBOX_OBJECT_CONVERT(GrafObj_Convert);
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(QdRGB_New);
+               PyMac_INIT_TOOLBOX_OBJECT_CONVERT(QdRGB_Convert);
+
 
        m = Py_InitModule("Qd", Qd_methods);
        d = PyModule_GetDict(m);
index fe606f5a94faff9cbf0cdc725394387fe72e324f..705cc4e9451785c92e9edba31eabc574dd277555 100644 (file)
@@ -63,6 +63,22 @@ PenState_ptr = StructInputBufferType('PenState')
 includestuff = includestuff + """
 #include <%s>""" % MACHEADERFILE + """
 
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_GrafObj_New(GrafPtr);
+extern int _GrafObj_Convert(PyObject *, GrafPtr *);
+extern PyObject *_BMObj_New(BitMapPtr);
+extern int _BMObj_Convert(PyObject *, BitMapPtr *);
+extern PyObject *_QdRGB_New(RGBColorPtr);
+extern int _QdRGB_Convert(PyObject *, RGBColorPtr *);
+
+#define GrafObj_New _GrafObj_New
+#define GrafObj_Convert _GrafObj_Convert
+#define BMObj_New _BMObj_New
+#define BMObj_Convert _BMObj_Convert
+#define QdRGB_New _QdRGB_New
+#define QdRGB_Convert _QdRGB_Convert
+#endif
+
 #if !ACCESSOR_CALLS_ARE_FUNCTIONS
 #define GetPortBitMapForCopyBits(port) ((const struct BitMap *)&((GrafPort *)(port))->portBits)
 #define GetPortPixMap(port) (((CGrafPtr)(port))->portPixMap)
@@ -201,6 +217,15 @@ variablestuff = """
 }
 """
 
+initstuff = initstuff + """
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(BMObj_New);
+       PyMac_INIT_TOOLBOX_OBJECT_CONVERT(BMObj_Convert);
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(GrafObj_New);
+       PyMac_INIT_TOOLBOX_OBJECT_CONVERT(GrafObj_Convert);
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(QdRGB_New);
+       PyMac_INIT_TOOLBOX_OBJECT_CONVERT(QdRGB_Convert);
+"""
+
 ## not yet...
 ##
 ##class Region_ObjectDefinition(GlobalObjectDefinition):
@@ -219,6 +244,16 @@ class MyGRObjectDefinition(GlobalObjectDefinition):
        def outputCheckNewArg(self):
                Output("if (itself == NULL) return PyMac_Error(resNotFound);")
        def outputCheckConvertArg(self):
+               Output("#if 1")
+               OutLbrace()
+               Output("WindowRef win;")
+               OutLbrace("if (WinObj_Convert(v, &win) && v)")
+               Output("*p_itself = (GrafPtr)GetWindowPort(win);")
+               Output("return 1;")
+               OutRbrace()
+               Output("PyErr_Clear();")
+               OutRbrace()
+               Output("#else")
                OutLbrace("if (DlgObj_Check(v))")
                Output("DialogRef dlg = (DialogRef)((GrafPortObject *)v)->ob_itself;")
                Output("*p_itself = (GrafPtr)GetWindowPort(GetDialogWindow(dlg));")
@@ -229,6 +264,7 @@ class MyGRObjectDefinition(GlobalObjectDefinition):
                Output("*p_itself = (GrafPtr)GetWindowPort(win);")
                Output("return 1;")
                OutRbrace()
+               Output("#endif")
        def outputGetattrHook(self):
                Output("#if !ACCESSOR_CALLS_ARE_FUNCTIONS")
                Output("""
index 2caf6f316aeb572fceab564a6178c4197f1a0b52..caa997e180add004484827e11b3dd10f02474e50 100644 (file)
 
 #include <QDOffscreen.h>
 
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_GWorldObj_New(GWorldPtr);
+extern int _GWorldObj_Convert(PyObject *, GWorldPtr *);
+
+#define GWorldObj_New _GWorldObj_New
+#define GWorldObj_Convert _GWorldObj_Convert
+#endif
+
 #define as_GrafPtr(gworld) ((GrafPtr)(gworld))
 
 
@@ -622,6 +630,9 @@ void initQdoffs()
 
 
 
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(GWorldObj_New);
+               PyMac_INIT_TOOLBOX_OBJECT_CONVERT(GWorldObj_Convert);
+
 
        m = Py_InitModule("Qdoffs", Qdoffs_methods);
        d = PyModule_GetDict(m);
index 7f4a043cc03461a5094a68966ae01645560b8ae3..3d96ca4f677cb507f7e64782797ae9fff3d0051d 100644 (file)
@@ -36,10 +36,22 @@ QDErr = OSErrType("QDErr", 'h')
 includestuff = includestuff + """
 #include <%s>""" % MACHEADERFILE + """
 
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_GWorldObj_New(GWorldPtr);
+extern int _GWorldObj_Convert(PyObject *, GWorldPtr *);
+
+#define GWorldObj_New _GWorldObj_New
+#define GWorldObj_Convert _GWorldObj_Convert
+#endif
+
 #define as_GrafPtr(gworld) ((GrafPtr)(gworld))
 
 """
 
+initstuff = initstuff + """
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(GWorldObj_New);
+       PyMac_INIT_TOOLBOX_OBJECT_CONVERT(GWorldObj_Convert);
+"""
 
 class MyObjectDefinition(GlobalObjectDefinition):
        def outputCheckNewArg(self):
index 20f10cc984c4df416484c0dd5ea00089c06441aa..20ba37063bfe68d7275c9e251b08aba81cac3fc6 100644 (file)
 
 #include <Movies.h>
 
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_TrackObj_New(Track);
+extern int _TrackObj_Convert(PyObject *, Track *);
+extern PyObject *_MovieObj_New(Movie);
+extern int _MovieObj_Convert(PyObject *, Movie *);
+extern PyObject *_MovieCtlObj_New(MovieController);
+extern int _MovieCtlObj_Convert(PyObject *, MovieController *);
+extern PyObject *_TimeBaseObj_New(TimeBase);
+extern int _TimeBaseObj_Convert(PyObject *, TimeBase *);
+extern PyObject *_UserDataObj_New(UserData);
+extern int _UserDataObj_Convert(PyObject *, UserData *);
+extern PyObject *_MediaObj_New(Media);
+extern int _MediaObj_Convert(PyObject *, Media *);
+
+#define TrackObj_New _TrackObj_New
+#define TrackObj_Convert _TrackObj_Convert
+#define MovieObj_New _MovieObj_New
+#define MovieObj_Convert _MovieObj_Convert
+#define MovieCtlObj_New _MovieCtlObj_New
+#define MovieCtlObj_Convert _MovieCtlObj_Convert
+#define TimeBaseObj_New _TimeBaseObj_New
+#define TimeBaseObj_Convert _TimeBaseObj_Convert
+#define UserDataObj_New _UserDataObj_New
+#define UserDataObj_Convert _UserDataObj_Convert
+#define MediaObj_New _MediaObj_New
+#define MediaObj_Convert _MediaObj_Convert
+#endif
 
 /* Macro to allow us to GetNextInterestingTime without duration */
 #define GetMediaNextInterestingTimeOnly(media, flags, time, rate, rv)                  GetMediaNextInterestingTime(media, flags, time, rate, rv, NULL)
@@ -9160,6 +9187,19 @@ void initQt()
 
 
 
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(TrackObj_New);
+               PyMac_INIT_TOOLBOX_OBJECT_CONVERT(TrackObj_Convert);
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(MovieObj_New);
+               PyMac_INIT_TOOLBOX_OBJECT_CONVERT(MovieObj_Convert);
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(MovieCtlObj_New);
+               PyMac_INIT_TOOLBOX_OBJECT_CONVERT(MovieCtlObj_Convert);
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(TimeBaseObj_New);
+               PyMac_INIT_TOOLBOX_OBJECT_CONVERT(TimeBaseObj_Convert);
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(UserDataObj_New);
+               PyMac_INIT_TOOLBOX_OBJECT_CONVERT(UserDataObj_Convert);
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(MediaObj_New);
+               PyMac_INIT_TOOLBOX_OBJECT_CONVERT(MediaObj_Convert);
+
 
        m = Py_InitModule("Qt", Qt_methods);
        d = PyModule_GetDict(m);
index 3d266732076cf1c856bc2662d9d880602e1844e4..02ce57eb3485fd708da1983c49fa6fd090901aad 100644 (file)
@@ -26,6 +26,33 @@ from macsupport import *
 includestuff = includestuff + """
 #include <%s>""" % MACHEADERFILE + """
 
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_TrackObj_New(Track);
+extern int _TrackObj_Convert(PyObject *, Track *);
+extern PyObject *_MovieObj_New(Movie);
+extern int _MovieObj_Convert(PyObject *, Movie *);
+extern PyObject *_MovieCtlObj_New(MovieController);
+extern int _MovieCtlObj_Convert(PyObject *, MovieController *);
+extern PyObject *_TimeBaseObj_New(TimeBase);
+extern int _TimeBaseObj_Convert(PyObject *, TimeBase *);
+extern PyObject *_UserDataObj_New(UserData);
+extern int _UserDataObj_Convert(PyObject *, UserData *);
+extern PyObject *_MediaObj_New(Media);
+extern int _MediaObj_Convert(PyObject *, Media *);
+
+#define TrackObj_New _TrackObj_New
+#define TrackObj_Convert _TrackObj_Convert
+#define MovieObj_New _MovieObj_New
+#define MovieObj_Convert _MovieObj_Convert
+#define MovieCtlObj_New _MovieCtlObj_New
+#define MovieCtlObj_Convert _MovieCtlObj_Convert
+#define TimeBaseObj_New _TimeBaseObj_New
+#define TimeBaseObj_Convert _TimeBaseObj_Convert
+#define UserDataObj_New _UserDataObj_New
+#define UserDataObj_Convert _UserDataObj_Convert
+#define MediaObj_New _MediaObj_New
+#define MediaObj_Convert _MediaObj_Convert
+#endif
 
 /* Macro to allow us to GetNextInterestingTime without duration */
 #define GetMediaNextInterestingTimeOnly(media, flags, time, rate, rv) \
@@ -65,6 +92,21 @@ QtTimeRecord_Convert(v, p_itself)
 
 
 
+"""
+
+initstuff = initstuff + """
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(TrackObj_New);
+       PyMac_INIT_TOOLBOX_OBJECT_CONVERT(TrackObj_Convert);
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(MovieObj_New);
+       PyMac_INIT_TOOLBOX_OBJECT_CONVERT(MovieObj_Convert);
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(MovieCtlObj_New);
+       PyMac_INIT_TOOLBOX_OBJECT_CONVERT(MovieCtlObj_Convert);
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(TimeBaseObj_New);
+       PyMac_INIT_TOOLBOX_OBJECT_CONVERT(TimeBaseObj_Convert);
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(UserDataObj_New);
+       PyMac_INIT_TOOLBOX_OBJECT_CONVERT(UserDataObj_Convert);
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(MediaObj_New);
+       PyMac_INIT_TOOLBOX_OBJECT_CONVERT(MediaObj_Convert);
 """
 
 # Our (opaque) objects
index bd6a42dd6fd596d7f69a94249e0fc54d13c1bb6f..26007b42e6ea9f56b1297e1b53ff0901e8d0b992 100644 (file)
 #include <Resources.h>
 #include <string.h>
 
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_ResObj_New(Handle);
+extern int _ResObj_Convert(PyObject *, Handle *);
+extern PyObject *_OptResObj_New(Handle);
+extern int _OptResObj_Convert(PyObject *, Handle *);
+#define ResObj_New _ResObj_New
+#define ResObj_Convert _ResObj_Convert
+#define OptResObj_New _OptResObj_New
+#define OptResObj_Convert _OptResObj_Convert
+#endif
+
 /* Function to dispose a resource, with a "normal" calling sequence */
 static void
 PyMac_AutoDisposeHandle(Handle h)
@@ -1678,6 +1689,10 @@ void initRes()
 
 
 
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(ResObj_New);
+               PyMac_INIT_TOOLBOX_OBJECT_CONVERT(ResObj_Convert);
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(OptResObj_New);
+               PyMac_INIT_TOOLBOX_OBJECT_CONVERT(OptResObj_Convert);
 
 
        m = Py_InitModule("Res", Res_methods);
index fcee62e7e5bb3ab90806ea4cd6d42c1270c2ab64..cdbb7788688ca09a7dd2bad75dbb399b5cc1d589 100644 (file)
@@ -26,6 +26,17 @@ includestuff = includestuff + """
 #include <Resources.h>
 #include <string.h>
 
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_ResObj_New(Handle);
+extern int _ResObj_Convert(PyObject *, Handle *);
+extern PyObject *_OptResObj_New(Handle);
+extern int _OptResObj_Convert(PyObject *, Handle *);
+#define ResObj_New _ResObj_New
+#define ResObj_Convert _ResObj_Convert
+#define OptResObj_New _OptResObj_New
+#define OptResObj_Convert _OptResObj_Convert
+#endif
+
 /* Function to dispose a resource, with a "normal" calling sequence */
 static void
 PyMac_AutoDisposeHandle(Handle h)
@@ -75,6 +86,10 @@ OptResObj_Convert(v, p_itself)
 """
 
 initstuff = initstuff + """
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(ResObj_New);
+       PyMac_INIT_TOOLBOX_OBJECT_CONVERT(ResObj_Convert);
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(OptResObj_New);
+       PyMac_INIT_TOOLBOX_OBJECT_CONVERT(OptResObj_Convert);
 """
 
 module = MacModule('Res', 'Res', includestuff, finalstuff, initstuff)
index 2bb447bd4ea9d43a9b93ed118953790a7aa99c7a..05b9b0c413c2bd87d929a750ffdd703059648da6 100644 (file)
 
 #include <TextEdit.h>
 
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_TEObj_New(TEHandle);
+extern int _TEObj_Convert(PyObject *, TEHandle *);
+
+#define TEObj_New _TEObj_New
+#define TEObj_Convert _TEObj_Convert
+#endif
+
 #define as_TE(h) ((TEHandle)h)
 #define as_Resource(teh) ((Handle)teh)
 
@@ -1105,6 +1113,9 @@ void initTE()
 
 
 
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(TEObj_New);
+               PyMac_INIT_TOOLBOX_OBJECT_CONVERT(TEObj_Convert);
+
 
        m = Py_InitModule("TE", TE_methods);
        d = PyModule_GetDict(m);
index 337ac2ba520bb7be438e719cda158a3792b6fc91..5512be002fc3635091470e2af47efd56cce6a386 100644 (file)
@@ -34,6 +34,14 @@ TextStyle_ptr = TextStyle
 includestuff = includestuff + """
 #include <%s>""" % MACHEADERFILE + """
 
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_TEObj_New(TEHandle);
+extern int _TEObj_Convert(PyObject *, TEHandle *);
+
+#define TEObj_New _TEObj_New
+#define TEObj_Convert _TEObj_Convert
+#endif
+
 #define as_TE(h) ((TEHandle)h)
 #define as_Resource(teh) ((Handle)teh)
 
@@ -65,6 +73,11 @@ TextStyle_Convert(v, p_itself)
 }
 """
 
+initstuff = initstuff + """
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(TEObj_New);
+       PyMac_INIT_TOOLBOX_OBJECT_CONVERT(TEObj_Convert);
+"""
+
 class TEMethodGenerator(OSErrMethodGenerator):
        """Similar to MethodGenerator, but has self as last argument"""
 
index d2672489e488e0f4793a9c324994effdf1fabfc7..6a9ded3626990ab27abb6efbb9031277885816b7 100644 (file)
 
 #include <Windows.h>
 
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_WinObj_New(WindowRef);
+extern PyObject *_WinObj_WhichWindow(WindowRef);
+extern int _WinObj_Convert(PyObject *, WindowRef *);
+
+#define WinObj_New _WinObj_New
+#define WinObj_WhichWindow _WinObj_WhichWindow
+#define WinObj_Convert _WinObj_Convert
+#endif
+
 #if !ACCESSOR_CALLS_ARE_FUNCTIONS
 /* Carbon calls that we emulate in classic mode */
 #define GetWindowSpareFlag(win) (((CWindowPeek)(win))->spareFlag)
@@ -65,10 +75,21 @@ WinObj_Convert(v, p_itself)
        PyObject *v;
        WindowPtr *p_itself;
 {
+#if 1
+       {
+               DialogRef dlg;
+               if (DlgObj_Convert(v, &dlg) && dlg) {
+                       *p_itself = GetDialogWindow(dlg);
+                       return 1;
+               }
+               PyErr_Clear();
+       }
+#else
        if (DlgObj_Check(v)) {
                *p_itself = DlgObj_ConvertToWindow(v);
                return 1;
        }
+#endif
 
        if (v == Py_None) { *p_itself = NULL; return 1; }
        if (PyInt_Check(v)) { *p_itself = (WindowPtr)PyInt_AsLong(v); return 1; }
@@ -3057,6 +3078,10 @@ void initWin()
 
 
 
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(WinObj_New);
+               PyMac_INIT_TOOLBOX_OBJECT_NEW(WinObj_WhichWindow);
+               PyMac_INIT_TOOLBOX_OBJECT_CONVERT(WinObj_Convert);
+
 
        m = Py_InitModule("Win", Win_methods);
        d = PyModule_GetDict(m);
index 0359a91c6fbde5c3966eac7e437da05d879e07ab..e55d273c787ec9cd1459b8eae87ab3cac7da3936 100644 (file)
@@ -56,6 +56,16 @@ PropertyTag = OSTypeType("PropertyTag")
 includestuff = includestuff + """
 #include <%s>""" % MACHEADERFILE + """
 
+#ifdef USE_TOOLBOX_OBJECT_GLUE
+extern PyObject *_WinObj_New(WindowRef);
+extern PyObject *_WinObj_WhichWindow(WindowRef);
+extern int _WinObj_Convert(PyObject *, WindowRef *);
+
+#define WinObj_New _WinObj_New
+#define WinObj_WhichWindow _WinObj_WhichWindow
+#define WinObj_Convert _WinObj_Convert
+#endif
+
 #if !ACCESSOR_CALLS_ARE_FUNCTIONS
 /* Carbon calls that we emulate in classic mode */
 #define GetWindowSpareFlag(win) (((CWindowPeek)(win))->spareFlag)
@@ -103,6 +113,12 @@ WinObj_WhichWindow(w)
 }
 """
 
+initstuff = initstuff + """
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(WinObj_New);
+       PyMac_INIT_TOOLBOX_OBJECT_NEW(WinObj_WhichWindow);
+       PyMac_INIT_TOOLBOX_OBJECT_CONVERT(WinObj_Convert);
+"""
+
 class MyObjectDefinition(GlobalObjectDefinition):
        def outputCheckNewArg(self):
                Output("if (itself == NULL) return PyMac_Error(resNotFound);")
@@ -118,10 +134,21 @@ class MyObjectDefinition(GlobalObjectDefinition):
                Output("it->ob_freeit = PyMac_AutoDisposeWindow;")
                OutRbrace()
        def outputCheckConvertArg(self):
+               Output("#if 1")
+               OutLbrace()
+               Output("DialogRef dlg;")
+               OutLbrace("if (DlgObj_Convert(v, &dlg) && dlg)")
+               Output("*p_itself = GetDialogWindow(dlg);")
+               Output("return 1;")
+               OutRbrace()
+               Output("PyErr_Clear();")
+               OutRbrace()
+               Output("#else")
                OutLbrace("if (DlgObj_Check(v))")
                Output("*p_itself = DlgObj_ConvertToWindow(v);")
                Output("return 1;")
                OutRbrace()
+               Output("#endif")
                Out("""
                if (v == Py_None) { *p_itself = NULL; return 1; }
                if (PyInt_Check(v)) { *p_itself = (WindowPtr)PyInt_AsLong(v); return 1; }