[Bf-blender-cvs] SVN commit: /data/svn/bf-blender [19217] branches/blender2.5/blender/source /blender/python/intern: added python api function to register an operator into a keymap

Campbell Barton ideasman42 at gmail.com
Sat Mar 7 10:46:35 CET 2009


Revision: 19217
          http://projects.blender.org/plugins/scmsvn/viewcvs.php?view=rev&root=bf-blender&revision=19217
Author:   campbellbarton
Date:     2009-03-07 10:46:33 +0100 (Sat, 07 Mar 2009)

Log Message:
-----------
added python api function to register an operator into a keymap
example...
bpyui.registerKey( C, bpyui.spaceTypes.SEQ, 0, "Sequencer", "SEQUENCER_OT_view_selected",  bpyui.keyTypes.A, bpyui.keyValTypes.PRESS, 0,0, {})
May want to split this into multiple functions.

Modified Paths:
--------------
    branches/blender2.5/blender/source/blender/python/intern/bpy_compat.h
    branches/blender2.5/blender/source/blender/python/intern/bpy_rna.c
    branches/blender2.5/blender/source/blender/python/intern/bpy_ui.c

Modified: branches/blender2.5/blender/source/blender/python/intern/bpy_compat.h
===================================================================
--- branches/blender2.5/blender/source/blender/python/intern/bpy_compat.h	2009-03-07 08:52:30 UTC (rev 19216)
+++ branches/blender2.5/blender/source/blender/python/intern/bpy_compat.h	2009-03-07 09:46:33 UTC (rev 19217)
@@ -80,5 +80,8 @@
 PyObject *Py_CmpToRich(int op, int cmp);
 #endif
 
+#ifndef Py_CmpToRich
+PyObject *Py_CmpToRich(int op, int cmp); /* bpy_util.c */
+#endif
 
 #endif /* BPY_COMPAT_H__ */

Modified: branches/blender2.5/blender/source/blender/python/intern/bpy_rna.c
===================================================================
--- branches/blender2.5/blender/source/blender/python/intern/bpy_rna.c	2009-03-07 08:52:30 UTC (rev 19216)
+++ branches/blender2.5/blender/source/blender/python/intern/bpy_rna.c	2009-03-07 09:46:33 UTC (rev 19217)
@@ -586,7 +586,7 @@
 		ret = pyrna_prop_to_py(&self->ptr, prop);
 	}
 	else if (strcmp(name, "__dict__")==0) { /* Not quite correct, adding this so dir() gives good feedback */
-		PropertyRNA *prop, *iterprop, *nameprop;
+		PropertyRNA *iterprop, *nameprop;
 		CollectionPropertyIterator iter;
 		char name[256], *nameptr;
 

Modified: branches/blender2.5/blender/source/blender/python/intern/bpy_ui.c
===================================================================
--- branches/blender2.5/blender/source/blender/python/intern/bpy_ui.c	2009-03-07 08:52:30 UTC (rev 19216)
+++ branches/blender2.5/blender/source/blender/python/intern/bpy_ui.c	2009-03-07 09:46:33 UTC (rev 19217)
@@ -317,7 +317,36 @@
 	Py_RETURN_NONE;
 }
 
+static PyObject *Method_registerKey( PyObject * self, PyObject * args )
+{
+	PyObject *py_context;
+	PyObject *py_keywords= NULL;
+	char *keymap_name, *operator_name;
+	int spaceid, regionid;
+	int keyval, evtval, q1, q2;
+	
+	wmWindowManager *wm;
+	ListBase *keymap;
+	wmKeymapItem *km;
+	
+	if( !PyArg_ParseTuple( args, "O!iissiiii|O!:registerKey", &PyCObject_Type, &py_context, &spaceid, &regionid, &keymap_name, &operator_name, &keyval, &evtval, &q1, &q2, &PyDict_Type, &py_keywords) )
+		return NULL;
 
+	wm= CTX_wm_manager(PyCObject_AsVoidPtr(py_context));
+	
+	/* keymap= WM_keymap_listbase(wm, "Image Generic", SPACE_IMAGE, 0); */
+	keymap= WM_keymap_listbase(wm, keymap_name, spaceid, regionid);
+	
+	km= WM_keymap_add_item(keymap, operator_name, keyval, evtval, q1, q2);
+	
+	/* Optional python doctionary used to set python properties, just like how keyword args are used */
+	if (py_keywords && PyDict_Size(py_keywords)) {
+		if (PYOP_props_from_dict(km->ptr, py_keywords) == -1)
+			return NULL;
+	}
+	
+	Py_RETURN_NONE;
+}
 
 /* internal use only */
 static bContext *get_py_context__internal(void)
@@ -386,7 +415,10 @@
 	{"matchPanelsView2d", (PyCFunction)Method_matchPanelsView2d, METH_VARARGS, ""},
 	
 	{"register", (PyCFunction)Method_register, METH_VARARGS, ""}, // XXX not sure about this - registers current script with the ScriptSpace, like Draw.Register()
+	{"registerKey", (PyCFunction)Method_registerKey, METH_VARARGS, ""}, // XXX could have this in another place too
 	
+	
+	
 	{"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, ""},
@@ -408,7 +440,7 @@
 
 PyObject *BPY_ui_module( void )
 {
-	PyObject *submodule, *dict;
+	PyObject *submodule, *mod;
 #if PY_VERSION_HEX >= 0x03000000
 	submodule= PyModule_Create(&ui_module);
 #else /* Py2.x */
@@ -416,26 +448,177 @@
 #endif
 	
 	/* uiBlock->flag (controls) */
-	PyModule_AddObject( submodule, "UI_BLOCK_LOOP", PyLong_FromSize_t(UI_BLOCK_LOOP) );
-	PyModule_AddObject( submodule, "UI_BLOCK_RET_1", PyLong_FromSize_t(UI_BLOCK_RET_1) );
-	PyModule_AddObject( submodule, "UI_BLOCK_NUMSELECT", PyLong_FromSize_t(UI_BLOCK_NUMSELECT) );
-	PyModule_AddObject( submodule, "UI_BLOCK_ENTER_OK", PyLong_FromSize_t(UI_BLOCK_ENTER_OK) );
-	PyModule_AddObject( submodule, "UI_BLOCK_NOSHADOW", PyLong_FromSize_t(UI_BLOCK_NOSHADOW) );
-	PyModule_AddObject( submodule, "UI_BLOCK_NO_HILITE", PyLong_FromSize_t(UI_BLOCK_NO_HILITE) );
-	PyModule_AddObject( submodule, "UI_BLOCK_MOVEMOUSE_QUIT", PyLong_FromSize_t(UI_BLOCK_MOVEMOUSE_QUIT) );
-	PyModule_AddObject( submodule, "UI_BLOCK_KEEP_OPEN", PyLong_FromSize_t(UI_BLOCK_KEEP_OPEN) );
-	PyModule_AddObject( submodule, "UI_BLOCK_POPUP", PyLong_FromSize_t(UI_BLOCK_POPUP) );
+	mod = PyModule_New("ui");
+	PyModule_AddObject( submodule, "ui", mod );
+	PyModule_AddObject( mod, "BLOCK_LOOP", PyLong_FromSize_t(UI_BLOCK_LOOP) );
+	PyModule_AddObject( mod, "BLOCK_RET_1", PyLong_FromSize_t(UI_BLOCK_RET_1) );
+	PyModule_AddObject( mod, "BLOCK_NUMSELECT", PyLong_FromSize_t(UI_BLOCK_NUMSELECT) );
+	PyModule_AddObject( mod, "BLOCK_ENTER_OK", PyLong_FromSize_t(UI_BLOCK_ENTER_OK) );
+	PyModule_AddObject( mod, "BLOCK_NOSHADOW", PyLong_FromSize_t(UI_BLOCK_NOSHADOW) );
+	PyModule_AddObject( mod, "BLOCK_NO_HILITE", PyLong_FromSize_t(UI_BLOCK_NO_HILITE) );
+	PyModule_AddObject( mod, "BLOCK_MOVEMOUSE_QUIT", PyLong_FromSize_t(UI_BLOCK_MOVEMOUSE_QUIT) );
+	PyModule_AddObject( mod, "BLOCK_KEEP_OPEN", PyLong_FromSize_t(UI_BLOCK_KEEP_OPEN) );
+	PyModule_AddObject( mod, "BLOCK_POPUP", PyLong_FromSize_t(UI_BLOCK_POPUP) );
 	
 	/* for executing operators (XXX move elsewhere) */
-	PyModule_AddObject( submodule, "WM_OP_INVOKE_DEFAULT", PyLong_FromSize_t(WM_OP_INVOKE_DEFAULT) );
-	PyModule_AddObject( submodule, "WM_OP_INVOKE_REGION_WIN", PyLong_FromSize_t(WM_OP_INVOKE_REGION_WIN) );
-	PyModule_AddObject( submodule, "WM_OP_INVOKE_AREA", PyLong_FromSize_t(WM_OP_INVOKE_AREA) );
-	PyModule_AddObject( submodule, "WM_OP_INVOKE_SCREEN", PyLong_FromSize_t(WM_OP_INVOKE_SCREEN) );
-	PyModule_AddObject( submodule, "WM_OP_EXEC_DEFAULT", PyLong_FromSize_t(WM_OP_EXEC_DEFAULT) );
-	PyModule_AddObject( submodule, "WM_OP_EXEC_REGION_WIN", PyLong_FromSize_t(WM_OP_EXEC_REGION_WIN) );
-	PyModule_AddObject( submodule, "WM_OP_EXEC_AREA", PyLong_FromSize_t(WM_OP_EXEC_AREA) );
-	PyModule_AddObject( submodule, "WM_OP_EXEC_SCREEN", PyLong_FromSize_t(WM_OP_EXEC_SCREEN) );
+	mod = PyModule_New("wmTypes");
+	PyModule_AddObject( submodule, "wmTypes", mod );
+	PyModule_AddObject( mod, "OP_INVOKE_DEFAULT", PyLong_FromSize_t(WM_OP_INVOKE_DEFAULT) );
+	PyModule_AddObject( mod, "OP_INVOKE_REGION_WIN", PyLong_FromSize_t(WM_OP_INVOKE_REGION_WIN) );
+	PyModule_AddObject( mod, "OP_INVOKE_AREA", PyLong_FromSize_t(WM_OP_INVOKE_AREA) );
+	PyModule_AddObject( mod, "OP_INVOKE_SCREEN", PyLong_FromSize_t(WM_OP_INVOKE_SCREEN) );
+	PyModule_AddObject( mod, "OP_EXEC_DEFAULT", PyLong_FromSize_t(WM_OP_EXEC_DEFAULT) );
+	PyModule_AddObject( mod, "OP_EXEC_REGION_WIN", PyLong_FromSize_t(WM_OP_EXEC_REGION_WIN) );
+	PyModule_AddObject( mod, "OP_EXEC_AREA", PyLong_FromSize_t(WM_OP_EXEC_AREA) );
+	PyModule_AddObject( mod, "OP_EXEC_SCREEN", PyLong_FromSize_t(WM_OP_EXEC_SCREEN) );
 	
+	mod = PyModule_New("keyValTypes");
+	PyModule_AddObject( submodule, "keyValTypes", mod );
+	PyModule_AddObject( mod, "ANY", PyLong_FromSize_t(KM_ANY) );
+	PyModule_AddObject( mod, "NOTHING", PyLong_FromSize_t(KM_NOTHING) );
+	PyModule_AddObject( mod, "PRESS", PyLong_FromSize_t(KM_PRESS) );
+	PyModule_AddObject( mod, "RELEASE", PyLong_FromSize_t(KM_RELEASE) );
+	
+	mod = PyModule_New("keyModTypes");
+	PyModule_AddObject( submodule, "keyModTypes", mod );
+	PyModule_AddObject( mod, "SHIFT", PyLong_FromSize_t(KM_SHIFT) );
+	PyModule_AddObject( mod, "CTRL", PyLong_FromSize_t(KM_CTRL) );
+	PyModule_AddObject( mod, "ALT", PyLong_FromSize_t(KM_ALT) );
+	PyModule_AddObject( mod, "OSKEY", PyLong_FromSize_t(KM_OSKEY) );
+	
+	PyModule_AddObject( mod, "SHIFT2", PyLong_FromSize_t(KM_SHIFT2) );
+	PyModule_AddObject( mod, "CTRL2", PyLong_FromSize_t(KM_CTRL2) );
+	PyModule_AddObject( mod, "ALT2", PyLong_FromSize_t(KM_ALT2) );
+	PyModule_AddObject( mod, "OSKEY2", PyLong_FromSize_t(KM_OSKEY2) );
+	
+	mod = PyModule_New("keyTypes");
+	PyModule_AddObject( submodule, "keyTypes", mod );
+	PyModule_AddObject( mod, "A", PyLong_FromSize_t(AKEY) );
+	PyModule_AddObject( mod, "B", PyLong_FromSize_t(BKEY) );
+	PyModule_AddObject( mod, "C", PyLong_FromSize_t(CKEY) );
+	PyModule_AddObject( mod, "D", PyLong_FromSize_t(DKEY) );
+	PyModule_AddObject( mod, "E", PyLong_FromSize_t(EKEY) );
+	PyModule_AddObject( mod, "F", PyLong_FromSize_t(FKEY) );
+	PyModule_AddObject( mod, "G", PyLong_FromSize_t(GKEY) );
+	PyModule_AddObject( mod, "H", PyLong_FromSize_t(HKEY) );
+	PyModule_AddObject( mod, "I", PyLong_FromSize_t(IKEY) );
+	PyModule_AddObject( mod, "J", PyLong_FromSize_t(JKEY) );
+	PyModule_AddObject( mod, "K", PyLong_FromSize_t(KKEY) );
+	PyModule_AddObject( mod, "L", PyLong_FromSize_t(LKEY) );
+	PyModule_AddObject( mod, "M", PyLong_FromSize_t(MKEY) );
+	PyModule_AddObject( mod, "N", PyLong_FromSize_t(NKEY) );
+	PyModule_AddObject( mod, "O", PyLong_FromSize_t(OKEY) );
+	PyModule_AddObject( mod, "P", PyLong_FromSize_t(PKEY) );
+	PyModule_AddObject( mod, "Q", PyLong_FromSize_t(QKEY) );
+	PyModule_AddObject( mod, "R", PyLong_FromSize_t(RKEY) );
+	PyModule_AddObject( mod, "S", PyLong_FromSize_t(SKEY) );
+	PyModule_AddObject( mod, "T", PyLong_FromSize_t(TKEY) );
+	PyModule_AddObject( mod, "U", PyLong_FromSize_t(UKEY) );
+	PyModule_AddObject( mod, "V", PyLong_FromSize_t(VKEY) );
+	PyModule_AddObject( mod, "W", PyLong_FromSize_t(WKEY) );
+	PyModule_AddObject( mod, "X", PyLong_FromSize_t(XKEY) );
+	PyModule_AddObject( mod, "Y", PyLong_FromSize_t(YKEY) );
+	PyModule_AddObject( mod, "Z", PyLong_FromSize_t(ZKEY) );
+	PyModule_AddObject( mod, "ZERO", PyLong_FromSize_t(ZEROKEY) );
+	PyModule_AddObject( mod, "ONE", PyLong_FromSize_t(ONEKEY) );
+	PyModule_AddObject( mod, "TWO", PyLong_FromSize_t(TWOKEY) );
+	PyModule_AddObject( mod, "THREE", PyLong_FromSize_t(THREEKEY) );
+	PyModule_AddObject( mod, "FOUR", PyLong_FromSize_t(FOURKEY) );
+	PyModule_AddObject( mod, "FIVE", PyLong_FromSize_t(FIVEKEY) );
+	PyModule_AddObject( mod, "SIX", PyLong_FromSize_t(SIXKEY) );
+	PyModule_AddObject( mod, "SEVEN", PyLong_FromSize_t(SEVENKEY) );
+	PyModule_AddObject( mod, "EIGHT", PyLong_FromSize_t(EIGHTKEY) );
+	PyModule_AddObject( mod, "NINE", PyLong_FromSize_t(NINEKEY) );
+	PyModule_AddObject( mod, "CAPSLOCK", PyLong_FromSize_t(CAPSLOCKKEY) );
+	PyModule_AddObject( mod, "LEFTCTRL", PyLong_FromSize_t(LEFTCTRLKEY) );

@@ Diff output truncated at 10240 characters. @@




More information about the Bf-blender-cvs mailing list