Jack Jansen | 9d8b96c | 2000-07-14 22:16:45 +0000 | [diff] [blame] | 1 | /* |
Jack Jansen | 94bebc0 | 2001-08-08 13:17:31 +0000 | [diff] [blame] | 2 | ** pymactoolbox.h - globals defined in mactoolboxglue.c |
Jack Jansen | 9d8b96c | 2000-07-14 22:16:45 +0000 | [diff] [blame] | 3 | */ |
Jack Jansen | 47ec141 | 2002-09-10 12:32:47 +0000 | [diff] [blame] | 4 | #ifndef Py_PYMACTOOLBOX_H |
| 5 | #define Py_PYMACTOOLBOX_H |
Jack Jansen | 9d8b96c | 2000-07-14 22:16:45 +0000 | [diff] [blame] | 6 | #ifdef __cplusplus |
| 7 | extern "C" { |
| 8 | #endif |
| 9 | |
Jack Jansen | 9f66b4a | 2001-05-19 12:32:39 +0000 | [diff] [blame] | 10 | #include <Carbon/Carbon.h> |
| 11 | #include <QuickTime/QuickTime.h> |
Jack Jansen | 9d8b96c | 2000-07-14 22:16:45 +0000 | [diff] [blame] | 12 | |
Jack Jansen | 94bebc0 | 2001-08-08 13:17:31 +0000 | [diff] [blame] | 13 | /* |
| 14 | ** Helper routines for error codes and such. |
| 15 | */ |
Jack Jansen | 94bebc0 | 2001-08-08 13:17:31 +0000 | [diff] [blame] | 16 | char *PyMac_StrError(int); /* strerror with mac errors */ |
Jack Jansen | 3305d24 | 2003-11-20 13:28:19 +0000 | [diff] [blame] | 17 | extern PyObject *PyMac_OSErrException; /* Exception for OSErr */ |
| 18 | PyObject *PyMac_GetOSErrException(void); /* Initialize & return it */ |
Jack Jansen | 94bebc0 | 2001-08-08 13:17:31 +0000 | [diff] [blame] | 19 | PyObject *PyErr_Mac(PyObject *, int); /* Exception with a mac error */ |
| 20 | PyObject *PyMac_Error(OSErr); /* Uses PyMac_GetOSErrException */ |
Jack Jansen | 7b04946 | 2001-09-10 22:09:30 +0000 | [diff] [blame] | 21 | extern OSErr PyMac_GetFullPathname(FSSpec *, char *, int); /* convert fsspec->path */ |
Jack Jansen | 21ed16a | 2002-08-02 14:11:24 +0000 | [diff] [blame] | 22 | #ifdef WITH_NEXT_FRAMEWORK |
| 23 | extern char *PyMac_GetAppletScriptFile(void); /* Return applet script file or NULL */ |
| 24 | #endif |
Jack Jansen | 94bebc0 | 2001-08-08 13:17:31 +0000 | [diff] [blame] | 25 | /* |
| 26 | ** These conversion routines are defined in mactoolboxglue.c itself. |
| 27 | */ |
| 28 | int PyMac_GetOSType(PyObject *, OSType *); /* argument parser for OSType */ |
| 29 | PyObject *PyMac_BuildOSType(OSType); /* Convert OSType to PyObject */ |
| 30 | |
| 31 | PyObject *PyMac_BuildNumVersion(NumVersion);/* Convert NumVersion to PyObject */ |
| 32 | |
| 33 | int PyMac_GetStr255(PyObject *, Str255); /* argument parser for Str255 */ |
| 34 | PyObject *PyMac_BuildStr255(Str255); /* Convert Str255 to PyObject */ |
| 35 | PyObject *PyMac_BuildOptStr255(Str255); /* Convert Str255 to PyObject, NULL to None */ |
| 36 | |
| 37 | int PyMac_GetRect(PyObject *, Rect *); /* argument parser for Rect */ |
| 38 | PyObject *PyMac_BuildRect(Rect *); /* Convert Rect to PyObject */ |
| 39 | |
| 40 | int PyMac_GetPoint(PyObject *, Point *); /* argument parser for Point */ |
| 41 | PyObject *PyMac_BuildPoint(Point); /* Convert Point to PyObject */ |
| 42 | |
| 43 | int PyMac_GetEventRecord(PyObject *, EventRecord *); /* argument parser for EventRecord */ |
| 44 | PyObject *PyMac_BuildEventRecord(EventRecord *); /* Convert EventRecord to PyObject */ |
| 45 | |
| 46 | int PyMac_GetFixed(PyObject *, Fixed *); /* argument parser for Fixed */ |
| 47 | PyObject *PyMac_BuildFixed(Fixed); /* Convert Fixed to PyObject */ |
| 48 | int PyMac_Getwide(PyObject *, wide *); /* argument parser for wide */ |
| 49 | PyObject *PyMac_Buildwide(wide *); /* Convert wide to PyObject */ |
| 50 | |
| 51 | /* |
| 52 | ** The rest of the routines are implemented by extension modules. If they are |
| 53 | ** dynamically loaded mactoolboxglue will contain a stub implementation of the |
| 54 | ** routine, which imports the module, whereupon the module's init routine will |
| 55 | ** communicate the routine pointer back to the stub. |
| 56 | ** If USE_TOOLBOX_OBJECT_GLUE is not defined there is no glue code, and the |
| 57 | ** extension modules simply declare the routine. This is the case for static |
| 58 | ** builds (and could be the case for MacPython CFM builds, because CFM extension |
| 59 | ** modules can reference each other without problems). |
| 60 | */ |
| 61 | |
Jack Jansen | f57a4a2 | 2001-05-17 22:11:44 +0000 | [diff] [blame] | 62 | #ifdef USE_TOOLBOX_OBJECT_GLUE |
| 63 | /* |
| 64 | ** These macros are used in the module init code. If we use toolbox object glue |
| 65 | ** it sets the function pointer to point to the real function. |
| 66 | */ |
Jack Jansen | 0268ac8 | 2001-05-22 22:34:56 +0000 | [diff] [blame] | 67 | #define PyMac_INIT_TOOLBOX_OBJECT_NEW(object, rtn) { \ |
Jack Jansen | f57a4a2 | 2001-05-17 22:11:44 +0000 | [diff] [blame] | 68 | extern PyObject *(*PyMacGluePtr_##rtn)(object); \ |
| 69 | PyMacGluePtr_##rtn = _##rtn; \ |
| 70 | } |
Jack Jansen | 0268ac8 | 2001-05-22 22:34:56 +0000 | [diff] [blame] | 71 | #define PyMac_INIT_TOOLBOX_OBJECT_CONVERT(object, rtn) { \ |
| 72 | extern int (*PyMacGluePtr_##rtn)(PyObject *, object *); \ |
Jack Jansen | f57a4a2 | 2001-05-17 22:11:44 +0000 | [diff] [blame] | 73 | PyMacGluePtr_##rtn = _##rtn; \ |
| 74 | } |
| 75 | #else |
| 76 | /* |
| 77 | ** If we don't use toolbox object glue the init macros are empty. Moreover, we define |
| 78 | ** _xxx_New to be the same as xxx_New, and the code in mactoolboxglue isn't included. |
| 79 | */ |
Jack Jansen | 0268ac8 | 2001-05-22 22:34:56 +0000 | [diff] [blame] | 80 | #define PyMac_INIT_TOOLBOX_OBJECT_NEW(object, rtn) |
| 81 | #define PyMac_INIT_TOOLBOX_OBJECT_CONVERT(object, rtn) |
Jack Jansen | f57a4a2 | 2001-05-17 22:11:44 +0000 | [diff] [blame] | 82 | #endif /* USE_TOOLBOX_OBJECT_GLUE */ |
| 83 | |
Jack Jansen | a5bca57 | 2001-08-03 15:39:27 +0000 | [diff] [blame] | 84 | /* macfs exports */ |
Jack Jansen | fabd00f | 2001-09-01 23:39:58 +0000 | [diff] [blame] | 85 | int PyMac_GetFSSpec(PyObject *, FSSpec *); /* argument parser for FSSpec */ |
| 86 | PyObject *PyMac_BuildFSSpec(FSSpec *); /* Convert FSSpec to PyObject */ |
| 87 | |
| 88 | int PyMac_GetFSRef(PyObject *, FSRef *); /* argument parser for FSRef */ |
| 89 | PyObject *PyMac_BuildFSRef(FSRef *); /* Convert FSRef to PyObject */ |
Jack Jansen | a5bca57 | 2001-08-03 15:39:27 +0000 | [diff] [blame] | 90 | |
Jack Jansen | 9d8b96c | 2000-07-14 22:16:45 +0000 | [diff] [blame] | 91 | /* AE exports */ |
| 92 | extern PyObject *AEDesc_New(AppleEvent *); /* XXXX Why passed by address?? */ |
Jack Jansen | b2a5772 | 2003-01-17 23:11:17 +0000 | [diff] [blame] | 93 | extern PyObject *AEDesc_NewBorrowed(AppleEvent *); |
Jack Jansen | 9d8b96c | 2000-07-14 22:16:45 +0000 | [diff] [blame] | 94 | extern int AEDesc_Convert(PyObject *, AppleEvent *); |
| 95 | |
| 96 | /* Cm exports */ |
| 97 | extern PyObject *CmpObj_New(Component); |
| 98 | extern int CmpObj_Convert(PyObject *, Component *); |
| 99 | extern PyObject *CmpInstObj_New(ComponentInstance); |
| 100 | extern int CmpInstObj_Convert(PyObject *, ComponentInstance *); |
| 101 | |
| 102 | /* Ctl exports */ |
| 103 | extern PyObject *CtlObj_New(ControlHandle); |
| 104 | extern int CtlObj_Convert(PyObject *, ControlHandle *); |
| 105 | |
| 106 | /* Dlg exports */ |
| 107 | extern PyObject *DlgObj_New(DialogPtr); |
| 108 | extern int DlgObj_Convert(PyObject *, DialogPtr *); |
Jack Jansen | add58f9 | 2001-02-09 15:59:18 +0000 | [diff] [blame] | 109 | extern PyObject *DlgObj_WhichDialog(DialogPtr); |
Jack Jansen | 9d8b96c | 2000-07-14 22:16:45 +0000 | [diff] [blame] | 110 | |
| 111 | /* Drag exports */ |
| 112 | extern PyObject *DragObj_New(DragReference); |
| 113 | extern int DragObj_Convert(PyObject *, DragReference *); |
| 114 | |
| 115 | /* List exports */ |
| 116 | extern PyObject *ListObj_New(ListHandle); |
| 117 | extern int ListObj_Convert(PyObject *, ListHandle *); |
| 118 | |
| 119 | /* Menu exports */ |
| 120 | extern PyObject *MenuObj_New(MenuHandle); |
| 121 | extern int MenuObj_Convert(PyObject *, MenuHandle *); |
| 122 | |
| 123 | /* Qd exports */ |
| 124 | extern PyObject *GrafObj_New(GrafPtr); |
| 125 | extern int GrafObj_Convert(PyObject *, GrafPtr *); |
| 126 | extern PyObject *BMObj_New(BitMapPtr); |
| 127 | extern int BMObj_Convert(PyObject *, BitMapPtr *); |
| 128 | extern PyObject *QdRGB_New(RGBColor *); |
| 129 | extern int QdRGB_Convert(PyObject *, RGBColor *); |
| 130 | |
Jack Jansen | 50bf148 | 2000-12-12 22:13:03 +0000 | [diff] [blame] | 131 | /* Qdoffs exports */ |
| 132 | extern PyObject *GWorldObj_New(GWorldPtr); |
| 133 | extern int GWorldObj_Convert(PyObject *, GWorldPtr *); |
| 134 | |
Jack Jansen | 9d8b96c | 2000-07-14 22:16:45 +0000 | [diff] [blame] | 135 | /* Qt exports */ |
| 136 | extern PyObject *TrackObj_New(Track); |
| 137 | extern int TrackObj_Convert(PyObject *, Track *); |
| 138 | extern PyObject *MovieObj_New(Movie); |
| 139 | extern int MovieObj_Convert(PyObject *, Movie *); |
| 140 | extern PyObject *MovieCtlObj_New(MovieController); |
Jack Jansen | f57a4a2 | 2001-05-17 22:11:44 +0000 | [diff] [blame] | 141 | extern int MovieCtlObj_Convert(PyObject *, MovieController *); |
Jack Jansen | 9d8b96c | 2000-07-14 22:16:45 +0000 | [diff] [blame] | 142 | extern PyObject *TimeBaseObj_New(TimeBase); |
| 143 | extern int TimeBaseObj_Convert(PyObject *, TimeBase *); |
| 144 | extern PyObject *UserDataObj_New(UserData); |
| 145 | extern int UserDataObj_Convert(PyObject *, UserData *); |
| 146 | extern PyObject *MediaObj_New(Media); |
| 147 | extern int MediaObj_Convert(PyObject *, Media *); |
| 148 | |
| 149 | /* Res exports */ |
| 150 | extern PyObject *ResObj_New(Handle); |
| 151 | extern int ResObj_Convert(PyObject *, Handle *); |
| 152 | extern PyObject *OptResObj_New(Handle); |
| 153 | extern int OptResObj_Convert(PyObject *, Handle *); |
| 154 | |
| 155 | /* TE exports */ |
| 156 | extern PyObject *TEObj_New(TEHandle); |
| 157 | extern int TEObj_Convert(PyObject *, TEHandle *); |
| 158 | |
| 159 | /* Win exports */ |
| 160 | extern PyObject *WinObj_New(WindowPtr); |
| 161 | extern int WinObj_Convert(PyObject *, WindowPtr *); |
| 162 | extern PyObject *WinObj_WhichWindow(WindowPtr); |
Jack Jansen | 9d8b96c | 2000-07-14 22:16:45 +0000 | [diff] [blame] | 163 | |
Jack Jansen | 537a69f | 2001-11-05 14:39:22 +0000 | [diff] [blame] | 164 | /* CF exports */ |
Jack Jansen | 4eb45e7 | 2003-05-27 21:39:58 +0000 | [diff] [blame] | 165 | extern PyObject *CFObj_New(CFTypeRef); |
| 166 | extern int CFObj_Convert(PyObject *, CFTypeRef *); |
Jack Jansen | 537a69f | 2001-11-05 14:39:22 +0000 | [diff] [blame] | 167 | extern PyObject *CFTypeRefObj_New(CFTypeRef); |
| 168 | extern int CFTypeRefObj_Convert(PyObject *, CFTypeRef *); |
| 169 | extern PyObject *CFStringRefObj_New(CFStringRef); |
| 170 | extern int CFStringRefObj_Convert(PyObject *, CFStringRef *); |
| 171 | extern PyObject *CFMutableStringRefObj_New(CFMutableStringRef); |
| 172 | extern int CFMutableStringRefObj_Convert(PyObject *, CFMutableStringRef *); |
| 173 | extern PyObject *CFArrayRefObj_New(CFArrayRef); |
| 174 | extern int CFArrayRefObj_Convert(PyObject *, CFArrayRef *); |
| 175 | extern PyObject *CFMutableArrayRefObj_New(CFMutableArrayRef); |
| 176 | extern int CFMutableArrayRefObj_Convert(PyObject *, CFMutableArrayRef *); |
| 177 | extern PyObject *CFDictionaryRefObj_New(CFDictionaryRef); |
| 178 | extern int CFDictionaryRefObj_Convert(PyObject *, CFDictionaryRef *); |
| 179 | extern PyObject *CFMutableDictionaryRefObj_New(CFMutableDictionaryRef); |
| 180 | extern int CFMutableDictionaryRefObj_Convert(PyObject *, CFMutableDictionaryRef *); |
| 181 | extern PyObject *CFURLRefObj_New(CFURLRef); |
| 182 | extern int CFURLRefObj_Convert(PyObject *, CFURLRef *); |
| 183 | extern int OptionalCFURLRefObj_Convert(PyObject *, CFURLRef *); |
Jack Jansen | 9d8b96c | 2000-07-14 22:16:45 +0000 | [diff] [blame] | 184 | |
| 185 | #ifdef __cplusplus |
| 186 | } |
| 187 | #endif |
Jack Jansen | 47ec141 | 2002-09-10 12:32:47 +0000 | [diff] [blame] | 188 | #endif |