/** * $Id$ * * ***** BEGIN GPL LICENSE BLOCK ***** * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 2 * of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software Foundation, * Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * Contributor(s): Campbell Barton * * ***** END GPL LICENSE BLOCK ***** */ #include "bpy_ui.h" #include "bpy_compat.h" #include "BLI_dynstr.h" #include "MEM_guardedalloc.h" #include "BKE_global.h" /* evil G.* */ #include "BKE_context.h" #include "DNA_screen_types.h" #include "UI_interface.h" #include "WM_api.h" static PyObject *Method_pupMenuBegin( PyObject * self, PyObject * args ) { char *title; int icon; if( !PyArg_ParseTuple( args, "si:pupMenuBegin", &title, &icon)) return NULL; return PyCObject_FromVoidPtr( uiPupMenuBegin(title, icon), NULL ); } static PyObject *Method_pupMenuEnd( PyObject * self, PyObject * args ) { PyObject *py_context, *py_head; if( !PyArg_ParseTuple( args, "O!O!:pupMenuEnd", &PyCObject_Type, &py_context, &PyCObject_Type, &py_head)) return NULL; uiPupMenuEnd(PyCObject_AsVoidPtr(py_context), PyCObject_AsVoidPtr(py_head)); Py_RETURN_NONE; } static PyObject *Method_menuItemO( PyObject * self, PyObject * args ) { PyObject *py_head; char *opname; int icon; if( !PyArg_ParseTuple( args, "O!is:menuItemO", &PyCObject_Type, &py_head, &icon, &opname)) return NULL; uiMenuItemO(PyCObject_AsVoidPtr(py_head), icon, opname); Py_RETURN_NONE; } static PyObject *Method_defButO( PyObject * self, PyObject * args ) { PyObject *py_block; char *opname, *butname, *tip; int exec, xco, yco, width, height; if( !PyArg_ParseTuple( args, "O!sisiiiis:defButO", &PyCObject_Type, &py_block, &opname, &exec, &butname, &xco, &yco, &width, &height, &tip)) return NULL; return PyCObject_FromVoidPtr(uiDefButO(PyCObject_AsVoidPtr(py_block), BUT, opname, exec, butname, xco, yco, width, height, tip), NULL ); } static uiBlock *py_internal_uiBlockCreateFunc(struct bContext *C, struct ARegion *ar, void *arg1) { PyObject *ret, *args; args = Py_BuildValue("(NN)", PyCObject_FromVoidPtr(C, NULL), PyCObject_FromVoidPtr(ar, NULL)); ret = PyObject_CallObject( (PyObject *)arg1, args ); Py_DECREF(args); if (ret==NULL) { PyErr_Print(); return NULL; } if (!PyCObject_Check(ret)) { printf("invalid return value, not a PyCObject block\n"); return NULL; } return (uiBlock *)PyCObject_AsVoidPtr(ret); } static PyObject *Method_pupBlock( PyObject * self, PyObject * args ) { PyObject *py_context, *py_func; if( !PyArg_ParseTuple( args, "O!O:pupBlock", &PyCObject_Type, &py_context, &py_func) ) return NULL; if (!PyCallable_Check(py_func)) { PyErr_SetString(PyExc_ValueError, "arg not callable"); return NULL; } uiPupBlock(PyCObject_AsVoidPtr(py_context), py_internal_uiBlockCreateFunc, (void *)py_func); Py_RETURN_NONE; } static PyObject *Method_beginBlock( PyObject * self, PyObject * args ) // XXX missing 2 args - UI_EMBOSS, UI_HELV, do we care? { PyObject *py_context, *py_ar; char *name; if( !PyArg_ParseTuple( args, "O!O!s:beginBlock", &PyCObject_Type, &py_context, &PyCObject_Type, &py_ar, &name) ) return NULL; return PyCObject_FromVoidPtr(uiBeginBlock(PyCObject_AsVoidPtr(py_context), PyCObject_AsVoidPtr(py_ar), name, UI_EMBOSS, UI_HELV), NULL); } static PyObject *Method_endBlock( PyObject * self, PyObject * args ) { PyObject *py_context, *py_block; if( !PyArg_ParseTuple( args, "O!O!:endBlock", &PyCObject_Type, &py_context, &PyCObject_Type, &py_block) ) return NULL; uiEndBlock(PyCObject_AsVoidPtr(py_context), PyCObject_AsVoidPtr(py_block)); Py_RETURN_NONE; } static PyObject *Method_popupBoundsBlock( PyObject * self, PyObject * args ) { PyObject *py_block; int addval, mx, my; if( !PyArg_ParseTuple( args, "O!iii:popupBoundsBlock", &PyCObject_Type, &py_block, &addval, &mx, &my) ) return NULL; uiPopupBoundsBlock(PyCObject_AsVoidPtr(py_block), addval, mx, my); Py_RETURN_NONE; } static PyObject *Method_blockBeginAlign( PyObject * self, PyObject * args ) { PyObject *py_block; if( !PyArg_ParseTuple( args, "O!:blockBeginAlign", &PyCObject_Type, &py_block) ) return NULL; uiBlockBeginAlign(PyCObject_AsVoidPtr(py_block)); Py_RETURN_NONE; } static PyObject *Method_blockEndAlign( PyObject * self, PyObject * args ) { PyObject *py_block; if( !PyArg_ParseTuple( args, "O!:blockEndAlign", &PyCObject_Type, &py_block)) return NULL; uiBlockEndAlign(PyCObject_AsVoidPtr(py_block)); Py_RETURN_NONE; } static PyObject *Method_newPanel( PyObject * self, PyObject * args ) { PyObject *py_context, *py_area, *py_block; char *panelname, *tabname; int ofsx, ofsy, sizex, sizey; if( !PyArg_ParseTuple( args, "O!O!O!ssiiii:newPanel", &PyCObject_Type, &py_context, &PyCObject_Type, &py_area, &PyCObject_Type, &py_block, &panelname, &tabname, &ofsx, &ofsy, &sizex, &sizey)) return NULL; return PyLong_FromSize_t(uiNewPanel(PyCObject_AsVoidPtr(py_context), PyCObject_AsVoidPtr(py_area), PyCObject_AsVoidPtr(py_block), panelname, tabname, ofsx, ofsy, sizex, sizey)); } /* internal use only */ static bContext *get_py_context__internal(void) { PyObject *globals = PyEval_GetGlobals(); PyObject *val= PyDict_GetItemString(globals, "__bpy_context__"); return PyCObject_AsVoidPtr(val); } static PyObject *Method_getRegonPtr( PyObject * self ) { bContext *C= get_py_context__internal(); ARegion *ar = CTX_wm_region(C); return PyCObject_FromVoidPtr(ar, NULL); } static PyObject *Method_getAreaPtr( PyObject * self ) { bContext *C= get_py_context__internal(); ScrArea *area = CTX_wm_area(C); return PyCObject_FromVoidPtr(area, NULL); } static PyObject *Method_getScreenPtr( PyObject * self ) { bContext *C= get_py_context__internal(); bScreen *screen= CTX_wm_screen(C); return PyCObject_FromVoidPtr(screen, NULL); } static PyObject *Method_getWindowPtr( PyObject * self ) { bContext *C= get_py_context__internal(); wmWindow *window= CTX_wm_window(C); return PyCObject_FromVoidPtr(window, NULL); } static struct PyMethodDef ui_methods[] = { {"pupMenuBegin", (PyCFunction)Method_pupMenuBegin, METH_VARARGS, ""}, {"pupMenuEnd", (PyCFunction)Method_pupMenuEnd, METH_VARARGS, ""}, {"menuItemO", (PyCFunction)Method_menuItemO, METH_VARARGS, ""}, {"defButO", (PyCFunction)Method_defButO, METH_VARARGS, ""}, {"pupBlock", (PyCFunction)Method_pupBlock, METH_VARARGS, ""}, {"beginBlock", (PyCFunction)Method_beginBlock, METH_VARARGS, ""}, {"endBlock", (PyCFunction)Method_endBlock, METH_VARARGS, ""}, {"popupBoundsBlock", (PyCFunction)Method_popupBoundsBlock, METH_VARARGS, ""}, {"blockBeginAlign", (PyCFunction)Method_blockBeginAlign, METH_VARARGS, ""}, {"blockEndAlign", (PyCFunction)Method_blockEndAlign, METH_VARARGS, ""}, {"newPanel", (PyCFunction)Method_newPanel, METH_VARARGS, ""}, {"getRegonPtr", (PyCFunction)Method_getRegonPtr, METH_NOARGS, ""}, // XXX Nasty, we really need to improve dealing with context! {"getAreaPtr", (PyCFunction)Method_getAreaPtr, METH_NOARGS, ""}, {"getScreenPtr", (PyCFunction)Method_getScreenPtr, METH_NOARGS, ""}, {"getWindowPtr", (PyCFunction)Method_getWindowPtr, METH_NOARGS, ""}, {NULL, NULL, 0, NULL} }; #if PY_VERSION_HEX >= 0x03000000 static struct PyModuleDef ui_module = { PyModuleDef_HEAD_INIT, "bpyui", "", -1,/* multiple "initialization" just copies the module dict. */ ui_methods, NULL, NULL, NULL, NULL }; PyObject *BPY_ui_module( void ) { return PyModule_Create(&ui_module); } #else /* Py2.x */ PyObject *BPY_ui_module( void ) { return Py_InitModule3( "bpyui", ui_methods, "" ); } #endif