Re: [sugar] [PATCH 1/2] Add is_modifier and is_special_modifier functions to SugarKeyGrabber.

2008-06-20 Thread Marco Pesenti Gritti
On Thu, Jun 19, 2008 at 9:06 PM, Benjamin Berg
<[EMAIL PROTECTED]> wrote:
> +   modmap = XGetModifierMapping (xdisplay);

No space between function name and (

> +gboolean sugar_key_grabber_is_modifier  (SugarKeyGrabber *grabber,
> + guintkeycode);
> +gboolean sugar_key_grabber_is_specific_modifier (SugarKeyGrabber *grabber,
> + guintkeycode,
> + guintmask);
> +

What about collapsing this in a single function and making it look
like this in python:

key_grabber.is_modifier(keycode, mask=-1)

You can do that in the bindings with something like this:

(define-method set
  (of-object "GtkAspectFrame")
  (c-name "gtk_aspect_frame_set")
  (return-type "none")
  (parameters
'("gfloat" "xalign" (default "0.0"))
'("gfloat" "yalign" (default "0.0"))
'("gfloat" "ratio" (default "1.0"))
'("gboolean" "obey_child" (default "1"))
  )
)

r+ with those changes.

Marco
___
Sugar mailing list
Sugar@lists.laptop.org
http://lists.laptop.org/listinfo/sugar


[sugar] [PATCH 1/2] Add is_modifier and is_special_modifier functions to SugarKeyGrabber.

2008-06-19 Thread Benjamin Berg

---

 src/sugar/_sugarext.defs  |   19 +
 src/sugar/sugar-key-grabber.c |   59 +
 src/sugar/sugar-key-grabber.h |6 
 3 files changed, 84 insertions(+), 0 deletions(-)

diff --git a/src/sugar/_sugarext.defs b/src/sugar/_sugarext.defs
index 02b673c..6bc068f 100644
--- a/src/sugar/_sugarext.defs
+++ b/src/sugar/_sugarext.defs
@@ -121,6 +121,25 @@
   )
 )
 
+(define-method is_modifier
+  (of-object "SugarKeyGrabber")
+  (c-name "sugar_key_grabber_is_modifier")
+  (return-type "gboolean")
+  (parameters
+'("guint" "keycode")
+  )
+)
+
+(define-method is_specific_modifier
+  (of-object "SugarKeyGrabber")
+  (c-name "sugar_key_grabber_is_specific_modifier")
+  (return-type "gboolean")
+  (parameters
+'("guint" "keycode")
+'("guint" "mask")
+  )
+)
+
 ;; From sexy-icon-entry.h
 
 (define-function sexy_icon_entry_get_type
diff --git a/src/sugar/sugar-key-grabber.c b/src/sugar/sugar-key-grabber.c
index baddab5..ed0cf9f 100644
--- a/src/sugar/sugar-key-grabber.c
+++ b/src/sugar/sugar-key-grabber.c
@@ -217,3 +217,62 @@ sugar_key_grabber_grab(SugarKeyGrabber *grabber, const 
char *key)
 
grabber->keys = g_list_append(grabber->keys, keyinfo);  
 }
+
+gboolean
+sugar_key_grabber_is_modifier(SugarKeyGrabber *grabber, guint keycode)
+{
+   Display *xdisplay;
+   XModifierKeymap *modmap;
+   gint size, i;
+   gboolean is_modifier = FALSE;
+
+   xdisplay = gdk_x11_drawable_get_xdisplay(GDK_DRAWABLE (grabber->root));
+
+   modmap = XGetModifierMapping (xdisplay);
+   
+   size = 8 * modmap->max_keypermod;
+   for (i = 0; i < size; i++) {
+   if (keycode == modmap->modifiermap[i]) {
+   is_modifier = TRUE;
+   break;
+   }
+   }
+   
+   XFreeModifiermap (modmap);
+   
+   return is_modifier;
+}
+
+
+gboolean
+sugar_key_grabber_is_specific_modifier(SugarKeyGrabber *grabber, guint 
keycode, guint mask)
+{
+   Display *xdisplay;
+   XModifierKeymap *modmap;
+   gint start, end, i, mod_index;
+   gboolean is_modifier = FALSE;
+
+   xdisplay = gdk_x11_drawable_get_xdisplay(GDK_DRAWABLE (grabber->root));
+
+   modmap = XGetModifierMapping (xdisplay);
+   
+   mod_index = 0;
+   mask = mask >> 1;
+   while (mask != 0) {
+   mask = mask >> 1;
+   mod_index += 1;
+   }
+   
+   start = mod_index * modmap->max_keypermod;
+   end = (mod_index + 1) * modmap->max_keypermod;
+   for (i = start; i < end; i++) {
+   if (keycode == modmap->modifiermap[i]) {
+   is_modifier = TRUE;
+   break;
+   }
+   }
+   
+   XFreeModifiermap (modmap);
+   
+   return is_modifier;
+}
diff --git a/src/sugar/sugar-key-grabber.h b/src/sugar/sugar-key-grabber.h
index 5b734e7..cf6efe2 100644
--- a/src/sugar/sugar-key-grabber.h
+++ b/src/sugar/sugar-key-grabber.h
@@ -60,6 +60,12 @@ void sugar_key_grabber_grab  
(SugarKeyGrabber *grabber,
 char*sugar_key_grabber_get_key  (SugarKeyGrabber *grabber,
 guint  
  keycode,
 guint  
  state);
+gboolean sugar_key_grabber_is_modifier  (SugarKeyGrabber *grabber,
+ guintkeycode);
+gboolean sugar_key_grabber_is_specific_modifier (SugarKeyGrabber *grabber,
+ guintkeycode,
+ guintmask);
+
 
 G_END_DECLS
 

___
Sugar mailing list
Sugar@lists.laptop.org
http://lists.laptop.org/listinfo/sugar