From ca3cff30ec98754e2be3887cdd3b478ceb87c0ba Mon Sep 17 00:00:00 2001 From: Just van Rossum Date: Wed, 2 Jan 2002 14:48:36 +0000 Subject: - Added support for optional MenuObj arguments - Added a bunch of calls as functions with an optional MenuObj first argument. The same calls already exist as methods, but then the first arg isn't optional... The method versions could go as far as I'm concerned. Jack? --- Mac/Modules/menu/_Menumodule.c | 304 ++++++++++++++++++++++++++++++++++++++++ Mac/Modules/menu/menuedit.py | 78 +++++++++++ Mac/Modules/menu/menusupport.py | 23 +++ 3 files changed, 405 insertions(+) diff --git a/Mac/Modules/menu/_Menumodule.c b/Mac/Modules/menu/_Menumodule.c index 398f6fa..54b6b2b 100644 --- a/Mac/Modules/menu/_Menumodule.c +++ b/Mac/Modules/menu/_Menumodule.c @@ -50,6 +50,28 @@ extern int _MenuObj_Convert(PyObject *, MenuHandle *); #define as_Menu(h) ((MenuHandle)h) #define as_Resource(h) ((Handle)h) + +/* Alternative version of ResObj_New, which returns None for null argument */ +PyObject *OptMenuObj_New(MenuRef itself) +{ + if (itself == NULL) { + Py_INCREF(Py_None); + return Py_None; + } + return MenuObj_New(itself); +} + +int OptMenuObj_Convert(PyObject *v, MenuRef *p_itself) +{ + PyObject *tmp; + + if ( v == Py_None ) { + *p_itself = NULL; + return 1; + } + return MenuObj_Convert(v, p_itself); +} + static PyObject *Menu_Error; /* ------------------------ Object type Menu ------------------------ */ @@ -3678,6 +3700,243 @@ static PyObject *Menu_DrawMenuBar(PyObject *_self, PyObject *_args) return _res; } +#if TARGET_API_MAC_CARBON + +static PyObject *Menu_CountMenuItemsWithCommandID(PyObject *_self, PyObject *_args) +{ + PyObject *_res = NULL; + ItemCount _rv; + MenuHandle inMenu; + MenuCommand inCommandID; +#ifndef CountMenuItemsWithCommandID + PyMac_PRECHECK(CountMenuItemsWithCommandID); +#endif + if (!PyArg_ParseTuple(_args, "O&l", + OptMenuObj_Convert, &inMenu, + &inCommandID)) + return NULL; + _rv = CountMenuItemsWithCommandID(inMenu, + inCommandID); + _res = Py_BuildValue("l", + _rv); + return _res; +} +#endif + +#if TARGET_API_MAC_CARBON + +static PyObject *Menu_GetIndMenuItemWithCommandID(PyObject *_self, PyObject *_args) +{ + PyObject *_res = NULL; + OSStatus _err; + MenuHandle inMenu; + MenuCommand inCommandID; + UInt32 inItemIndex; + MenuHandle outMenu; + MenuItemIndex outIndex; +#ifndef GetIndMenuItemWithCommandID + PyMac_PRECHECK(GetIndMenuItemWithCommandID); +#endif + if (!PyArg_ParseTuple(_args, "O&ll", + OptMenuObj_Convert, &inMenu, + &inCommandID, + &inItemIndex)) + return NULL; + _err = GetIndMenuItemWithCommandID(inMenu, + inCommandID, + inItemIndex, + &outMenu, + &outIndex); + if (_err != noErr) return PyMac_Error(_err); + _res = Py_BuildValue("O&h", + MenuObj_New, outMenu, + outIndex); + return _res; +} +#endif + +#if TARGET_API_MAC_CARBON + +static PyObject *Menu_EnableMenuCommand(PyObject *_self, PyObject *_args) +{ + PyObject *_res = NULL; + MenuHandle inMenu; + MenuCommand inCommandID; +#ifndef EnableMenuCommand + PyMac_PRECHECK(EnableMenuCommand); +#endif + if (!PyArg_ParseTuple(_args, "O&l", + OptMenuObj_Convert, &inMenu, + &inCommandID)) + return NULL; + EnableMenuCommand(inMenu, + inCommandID); + Py_INCREF(Py_None); + _res = Py_None; + return _res; +} +#endif + +#if TARGET_API_MAC_CARBON + +static PyObject *Menu_DisableMenuCommand(PyObject *_self, PyObject *_args) +{ + PyObject *_res = NULL; + MenuHandle inMenu; + MenuCommand inCommandID; +#ifndef DisableMenuCommand + PyMac_PRECHECK(DisableMenuCommand); +#endif + if (!PyArg_ParseTuple(_args, "O&l", + OptMenuObj_Convert, &inMenu, + &inCommandID)) + return NULL; + DisableMenuCommand(inMenu, + inCommandID); + Py_INCREF(Py_None); + _res = Py_None; + return _res; +} +#endif + +#if TARGET_API_MAC_CARBON + +static PyObject *Menu_IsMenuCommandEnabled(PyObject *_self, PyObject *_args) +{ + PyObject *_res = NULL; + Boolean _rv; + MenuHandle inMenu; + MenuCommand inCommandID; +#ifndef IsMenuCommandEnabled + PyMac_PRECHECK(IsMenuCommandEnabled); +#endif + if (!PyArg_ParseTuple(_args, "O&l", + OptMenuObj_Convert, &inMenu, + &inCommandID)) + return NULL; + _rv = IsMenuCommandEnabled(inMenu, + inCommandID); + _res = Py_BuildValue("b", + _rv); + return _res; +} +#endif + +#if TARGET_API_MAC_CARBON + +static PyObject *Menu_SetMenuCommandMark(PyObject *_self, PyObject *_args) +{ + PyObject *_res = NULL; + OSStatus _err; + MenuHandle inMenu; + MenuCommand inCommandID; + UniChar inMark; +#ifndef SetMenuCommandMark + PyMac_PRECHECK(SetMenuCommandMark); +#endif + if (!PyArg_ParseTuple(_args, "O&lh", + OptMenuObj_Convert, &inMenu, + &inCommandID, + &inMark)) + return NULL; + _err = SetMenuCommandMark(inMenu, + inCommandID, + inMark); + if (_err != noErr) return PyMac_Error(_err); + Py_INCREF(Py_None); + _res = Py_None; + return _res; +} +#endif + +#if TARGET_API_MAC_CARBON + +static PyObject *Menu_GetMenuCommandMark(PyObject *_self, PyObject *_args) +{ + PyObject *_res = NULL; + OSStatus _err; + MenuHandle inMenu; + MenuCommand inCommandID; + UniChar outMark; +#ifndef GetMenuCommandMark + PyMac_PRECHECK(GetMenuCommandMark); +#endif + if (!PyArg_ParseTuple(_args, "O&l", + OptMenuObj_Convert, &inMenu, + &inCommandID)) + return NULL; + _err = GetMenuCommandMark(inMenu, + inCommandID, + &outMark); + if (_err != noErr) return PyMac_Error(_err); + _res = Py_BuildValue("h", + outMark); + return _res; +} +#endif + +#if TARGET_API_MAC_CARBON + +static PyObject *Menu_GetMenuCommandPropertySize(PyObject *_self, PyObject *_args) +{ + PyObject *_res = NULL; + OSStatus _err; + MenuHandle inMenu; + MenuCommand inCommandID; + OSType inPropertyCreator; + OSType inPropertyTag; + ByteCount outSize; +#ifndef GetMenuCommandPropertySize + PyMac_PRECHECK(GetMenuCommandPropertySize); +#endif + if (!PyArg_ParseTuple(_args, "O&lO&O&", + OptMenuObj_Convert, &inMenu, + &inCommandID, + PyMac_GetOSType, &inPropertyCreator, + PyMac_GetOSType, &inPropertyTag)) + return NULL; + _err = GetMenuCommandPropertySize(inMenu, + inCommandID, + inPropertyCreator, + inPropertyTag, + &outSize); + if (_err != noErr) return PyMac_Error(_err); + _res = Py_BuildValue("l", + outSize); + return _res; +} +#endif + +#if TARGET_API_MAC_CARBON + +static PyObject *Menu_RemoveMenuCommandProperty(PyObject *_self, PyObject *_args) +{ + PyObject *_res = NULL; + OSStatus _err; + MenuHandle inMenu; + MenuCommand inCommandID; + OSType inPropertyCreator; + OSType inPropertyTag; +#ifndef RemoveMenuCommandProperty + PyMac_PRECHECK(RemoveMenuCommandProperty); +#endif + if (!PyArg_ParseTuple(_args, "O&lO&O&", + OptMenuObj_Convert, &inMenu, + &inCommandID, + PyMac_GetOSType, &inPropertyCreator, + PyMac_GetOSType, &inPropertyTag)) + return NULL; + _err = RemoveMenuCommandProperty(inMenu, + inCommandID, + inPropertyCreator, + inPropertyTag); + if (_err != noErr) return PyMac_Error(_err); + Py_INCREF(Py_None); + _res = Py_None; + return _res; +} +#endif + static PyMethodDef Menu_methods[] = { #if !TARGET_API_MAC_CARBON @@ -3787,6 +4046,51 @@ static PyMethodDef Menu_methods[] = { "(short menuID) -> None"}, {"DrawMenuBar", (PyCFunction)Menu_DrawMenuBar, 1, "() -> None"}, + +#if TARGET_API_MAC_CARBON + {"CountMenuItemsWithCommandID", (PyCFunction)Menu_CountMenuItemsWithCommandID, 1, + "(MenuHandle inMenu, MenuCommand inCommandID) -> (ItemCount _rv)"}, +#endif + +#if TARGET_API_MAC_CARBON + {"GetIndMenuItemWithCommandID", (PyCFunction)Menu_GetIndMenuItemWithCommandID, 1, + "(MenuHandle inMenu, MenuCommand inCommandID, UInt32 inItemIndex) -> (MenuHandle outMenu, MenuItemIndex outIndex)"}, +#endif + +#if TARGET_API_MAC_CARBON + {"EnableMenuCommand", (PyCFunction)Menu_EnableMenuCommand, 1, + "(MenuHandle inMenu, MenuCommand inCommandID) -> None"}, +#endif + +#if TARGET_API_MAC_CARBON + {"DisableMenuCommand", (PyCFunction)Menu_DisableMenuCommand, 1, + "(MenuHandle inMenu, MenuCommand inCommandID) -> None"}, +#endif + +#if TARGET_API_MAC_CARBON + {"IsMenuCommandEnabled", (PyCFunction)Menu_IsMenuCommandEnabled, 1, + "(MenuHandle inMenu, MenuCommand inCommandID) -> (Boolean _rv)"}, +#endif + +#if TARGET_API_MAC_CARBON + {"SetMenuCommandMark", (PyCFunction)Menu_SetMenuCommandMark, 1, + "(MenuHandle inMenu, MenuCommand inCommandID, UniChar inMark) -> None"}, +#endif + +#if TARGET_API_MAC_CARBON + {"GetMenuCommandMark", (PyCFunction)Menu_GetMenuCommandMark, 1, + "(MenuHandle inMenu, MenuCommand inCommandID) -> (UniChar outMark)"}, +#endif + +#if TARGET_API_MAC_CARBON + {"GetMenuCommandPropertySize", (PyCFunction)Menu_GetMenuCommandPropertySize, 1, + "(MenuHandle inMenu, MenuCommand inCommandID, OSType inPropertyCreator, OSType inPropertyTag) -> (ByteCount outSize)"}, +#endif + +#if TARGET_API_MAC_CARBON + {"RemoveMenuCommandProperty", (PyCFunction)Menu_RemoveMenuCommandProperty, 1, + "(MenuHandle inMenu, MenuCommand inCommandID, OSType inPropertyCreator, OSType inPropertyTag) -> None"}, +#endif {NULL, NULL, 0} }; diff --git a/Mac/Modules/menu/menuedit.py b/Mac/Modules/menu/menuedit.py index 4a9cf2a..d1f1f24 100644 --- a/Mac/Modules/menu/menuedit.py +++ b/Mac/Modules/menu/menuedit.py @@ -59,3 +59,81 @@ f = Function(void, 'DrawMenuBar', ) functions.append(f) + +# +# The following functions take an *optional* MenuRef as their first argument +# + +f = Function(ItemCount, 'CountMenuItemsWithCommandID', + (OptMenuRef, 'inMenu', InMode), + (MenuCommand, 'inCommandID', InMode), + condition='#if TARGET_API_MAC_CARBON', +) +functions.append(f) + +f = Function(OSStatus, 'GetIndMenuItemWithCommandID', + (OptMenuRef, 'inMenu', InMode), + (MenuCommand, 'inCommandID', InMode), + (UInt32, 'inItemIndex', InMode), + (MenuRef, 'outMenu', OutMode), + (MenuItemIndex, 'outIndex', OutMode), + condition='#if TARGET_API_MAC_CARBON', +) +functions.append(f) + +f = Function(void, 'EnableMenuCommand', + (OptMenuRef, 'inMenu', InMode), + (MenuCommand, 'inCommandID', InMode), + condition='#if TARGET_API_MAC_CARBON', +) +functions.append(f) + +f = Function(void, 'DisableMenuCommand', + (OptMenuRef, 'inMenu', InMode), + (MenuCommand, 'inCommandID', InMode), + condition='#if TARGET_API_MAC_CARBON', +) +functions.append(f) + +f = Function(Boolean, 'IsMenuCommandEnabled', + (OptMenuRef, 'inMenu', InMode), + (MenuCommand, 'inCommandID', InMode), + condition='#if TARGET_API_MAC_CARBON', +) +functions.append(f) + +f = Function(OSStatus, 'SetMenuCommandMark', + (OptMenuRef, 'inMenu', InMode), + (MenuCommand, 'inCommandID', InMode), + (UniChar, 'inMark', InMode), + condition='#if TARGET_API_MAC_CARBON', +) +functions.append(f) + +f = Function(OSStatus, 'GetMenuCommandMark', + (OptMenuRef, 'inMenu', InMode), + (MenuCommand, 'inCommandID', InMode), + (UniChar, 'outMark', OutMode), + condition='#if TARGET_API_MAC_CARBON', +) +functions.append(f) + +f = Function(OSStatus, 'GetMenuCommandPropertySize', + (OptMenuRef, 'inMenu', InMode), + (MenuCommand, 'inCommandID', InMode), + (OSType, 'inPropertyCreator', InMode), + (OSType, 'inPropertyTag', InMode), + (ByteCount, 'outSize', OutMode), + condition='#if TARGET_API_MAC_CARBON', +) +functions.append(f) + +f = Function(OSStatus, 'RemoveMenuCommandProperty', + (OptMenuRef, 'inMenu', InMode), + (MenuCommand, 'inCommandID', InMode), + (OSType, 'inPropertyCreator', InMode), + (OSType, 'inPropertyTag', InMode), + condition='#if TARGET_API_MAC_CARBON', +) +functions.append(f) + diff --git a/Mac/Modules/menu/menusupport.py b/Mac/Modules/menu/menusupport.py index 210a6b3..05a4412 100644 --- a/Mac/Modules/menu/menusupport.py +++ b/Mac/Modules/menu/menusupport.py @@ -24,6 +24,7 @@ from macsupport import * MenuHandle = OpaqueByValueType(OBJECTTYPE, OBJECTPREFIX) MenuRef = MenuHandle +OptMenuRef = OpaqueByValueType(OBJECTTYPE, "Opt" + OBJECTPREFIX) Handle = OpaqueByValueType("Handle", "ResObj") MenuBarHandle = OpaqueByValueType("MenuBarHandle", "ResObj") MenuID = Type("MenuID", "h") @@ -68,6 +69,28 @@ extern int _MenuObj_Convert(PyObject *, MenuHandle *); #define as_Menu(h) ((MenuHandle)h) #define as_Resource(h) ((Handle)h) + + +/* Alternative version of ResObj_New, which returns None for null argument */ +PyObject *OptMenuObj_New(MenuRef itself) +{ + if (itself == NULL) { + Py_INCREF(Py_None); + return Py_None; + } + return MenuObj_New(itself); +} + +int OptMenuObj_Convert(PyObject *v, MenuRef *p_itself) +{ + PyObject *tmp; + + if ( v == Py_None ) { + *p_itself = NULL; + return 1; + } + return MenuObj_Convert(v, p_itself); +} """ initstuff = initstuff + """ -- cgit v0.12