2.5
authorTon Roosendaal <ton@blender.org>
Mon, 15 Dec 2008 11:45:17 +0000 (11:45 +0000)
committerTon Roosendaal <ton@blender.org>
Mon, 15 Dec 2008 11:45:17 +0000 (11:45 +0000)
funtion WM_keymap_add_item() now returns keymap-item, so you can use it
to set default properties for operators with WM_keymap_property_set().

Brecht will fill in this function, requires rna magic!

Example: an operator ED_OB_OT_add_primitive can be configured with
keymap like this:

WM_keymap_property_set(keymapitem, "Primitivetype", "Sphere");

Similar conventions we can use later for button/menu calls.
This will make creating operators easier, allowing a developer to group
tools functionality nicely.

source/blender/windowmanager/WM_api.h
source/blender/windowmanager/intern/wm_event_system.c
source/blender/windowmanager/intern/wm_keymap.c

index 908070d33faf77dc6e247853b6b1489759ea1b0b..fd9e05fa107c09668e2563f2e75c91783353d6e6 100644 (file)
@@ -61,12 +61,13 @@ void                WM_waitcursor           (struct bContext *C, int val);
 void           WM_timecursor           (struct bContext *C, int nr);
 
                        /* keymap and handlers */
-void           WM_keymap_set_item      (ListBase *lb, char *idname, short type, 
+wmKeymapItem *WM_keymap_set_item       (ListBase *lb, char *idname, short type, 
                                                                 short val, int modifier, short keymodifier);
-void           WM_keymap_verify_item(ListBase *lb, char *idname, short type, 
+wmKeymapItem *WM_keymap_verify_item(ListBase *lb, char *idname, short type, 
                                                                 short val, int modifier, short keymodifier);
-void           WM_keymap_add_item      (ListBase *lb, char *idname, short type, 
+wmKeymapItem *WM_keymap_add_item       (ListBase *lb, char *idname, short type, 
                                                                 short val, int modifier, short keymodifier);
+void           WM_keymap_property_set(wmKeymapItem *km, const char *propname, const char *propval);
 ListBase       *WM_keymap_listbase     (wmWindowManager *wm, const char *nameid, 
                                                                 int spaceid, int regionid);
 
index cd66d0b479b622963505905c1b1d6d6ce8afe5bb..100bdbc6d2b26dcb09f3d7ee866de91153ccb68f 100644 (file)
@@ -643,6 +643,7 @@ void wm_event_do_handlers(bContext *C)
                                ARegion *ar;
                                int doit= 0;
                                
+                               /* XXX to solve, here screen handlers? */
                                ED_screen_set_subwinactive(win);        /* state variables in screen */
                                
                                for(sa= win->screen->areabase.first; sa; sa= sa->next) {
index 439f5c304d1dc7aa2ce18325756db79b406b2a04..f01ca55c31999dff203844c4eecd405d0583c3d6 100644 (file)
@@ -72,7 +72,7 @@ static void keymap_set(wmKeymapItem *kmi, short type, short val, int modifier, s
 }
 
 /* if item was added, then bail out */
-void WM_keymap_verify_item(ListBase *lb, char *idname, short type, short val, int modifier, short keymodifier)
+wmKeymapItem *WM_keymap_verify_item(ListBase *lb, char *idname, short type, short val, int modifier, short keymodifier)
 {
        wmKeymapItem *kmi;
        
@@ -87,11 +87,11 @@ void WM_keymap_verify_item(ListBase *lb, char *idname, short type, short val, in
                
                keymap_set(kmi, type, val, modifier, keymodifier);
        }
-       
+       return kmi;
 }
 
 /* if item was added, then replace */
-void WM_keymap_set_item(ListBase *lb, char *idname, short type, short val, int modifier, short keymodifier)
+wmKeymapItem *WM_keymap_set_item(ListBase *lb, char *idname, short type, short val, int modifier, short keymodifier)
 {
        wmKeymapItem *kmi;
        
@@ -105,10 +105,11 @@ void WM_keymap_set_item(ListBase *lb, char *idname, short type, short val, int m
                BLI_strncpy(kmi->idname, idname, OP_MAX_TYPENAME);
        }
        keymap_set(kmi, type, val, modifier, keymodifier);
+       return kmi;
 }
 
 /* always add item */
-void WM_keymap_add_item(ListBase *lb, char *idname, short type, short val, int modifier, short keymodifier)
+wmKeymapItem *WM_keymap_add_item(ListBase *lb, char *idname, short type, short val, int modifier, short keymodifier)
 {
        wmKeymapItem *kmi= MEM_callocN(sizeof(wmKeymapItem), "keymap entry");
        
@@ -116,6 +117,12 @@ void WM_keymap_add_item(ListBase *lb, char *idname, short type, short val, int m
        BLI_strncpy(kmi->idname, idname, OP_MAX_TYPENAME);
 
        keymap_set(kmi, type, val, modifier, keymodifier);
+       return kmi;
+}
+
+void WM_keymap_property_set(wmKeymapItem *km, const char *propname, const char *propval)
+{
+       /* todo */
 }
 
 /* ****************** storage in WM ************ */