diff --git a/externals/footils/knob/knob.c b/externals/footils/knob/knob.c
index bdb953e032ee15222f3ef2b3190c766c9a899c0e..78b8ce140f11e5dc1778bd1fd83ce98d8160e4eb 100644
--- a/externals/footils/knob/knob.c
+++ b/externals/footils/knob/knob.c
@@ -528,7 +528,7 @@ static void knob_click(t_knob *x, t_floatarg xpos, t_floatarg ypos,
     (*x->x_gui.x_draw)(x, x->x_gui.x_glist, IEM_GUI_DRAW_MODE_UPDATE);
     knob_bang(x);
     glist_grab(x->x_gui.x_glist, &x->x_gui.x_obj.te_g, (t_glistmotionfn)knob_motion,
-	       0, xpos, ypos);
+	       0, 0, xpos, ypos);
 }
 
 static int knob_newclick(t_gobj *z, struct _glist *glist,
diff --git a/externals/ggee/gui/w_envgen.h b/externals/ggee/gui/w_envgen.h
index b457ed96c006303081a3bb93bca601559fe30dd1..76cd4aa1f52dbc95b508fd103b8db8cc0930bb5e 100644
--- a/externals/ggee/gui/w_envgen.h
+++ b/externals/ggee/gui/w_envgen.h
@@ -541,7 +541,7 @@ static int envgen_newclick(t_envgen *x, struct _glist *glist,
         envgen_next_doodle(x, glist, xpos, ypos);
 
         glist_grab(x->w.glist, &x->x_obj.te_g, (t_glistmotionfn) envgen_motion,
-            (t_glistkeyfn) envgen_key, xpos, ypos);
+            (t_glistkeyfn) envgen_key, 0, xpos, ypos);
 
         x->resizing = 0;
         if (x->resizeable && (xpos > wxpos + x->w.width) &&
diff --git a/externals/iem/iemgui/src/cube_sphere.c b/externals/iem/iemgui/src/cube_sphere.c
index c1292ef5c7a03b1747dcf5ca61267c0975e56d53..dea32cbcdf5f3efacac048dbcb4b02ce0506a793 100644
--- a/externals/iem/iemgui/src/cube_sphere.c
+++ b/externals/iem/iemgui/src/cube_sphere.c
@@ -366,7 +366,7 @@ static void cube_sphere_click(t_cube_sphere *x, t_floatarg xpos, t_floatarg ypos
         x->x_sel_index = sel;
         x->x_pos_x = x->x_pix_src_x[sel];
         x->x_pos_y = x->x_pix_src_y[sel];
-        glist_grab(x->x_gui.x_glist, &x->x_gui.x_obj.te_g, (t_glistmotionfn)cube_sphere_motion, 0, xpos, ypos);
+        glist_grab(x->x_gui.x_glist, &x->x_gui.x_obj.te_g, (t_glistmotionfn)cube_sphere_motion, 0, 0, xpos, ypos);
       }
     }
   }
diff --git a/externals/iem/iemgui/src/iem_event.c b/externals/iem/iemgui/src/iem_event.c
index e8353775c8ff713a92c9bae97867c161adca99da..d0a82969004a439d112e51376794b7747a376ee5 100644
--- a/externals/iem/iemgui/src/iem_event.c
+++ b/externals/iem/iemgui/src/iem_event.c
@@ -232,7 +232,7 @@ static int iem_event_click(t_gobj *z, struct _glist *glist, int xpix, int ypix,
   if(doit)
   {
     glist_grab(x->x_gui.x_glist, &x->x_gui.x_obj.te_g,
-      (t_glistmotionfn)iem_event_motion, iem_event_key, (t_float)xpix, (t_float)ypix);
+      (t_glistmotionfn)iem_event_motion, iem_event_key, 0, (t_float)xpix, (t_float)ypix);
     
     outlet_anything(x->x_gui.x_obj.ob_outlet, x->x_dragg_x_y, 2, x->x_at_out);
     if(x->x_gui.x_fsf.x_snd_able && x->x_gui.x_snd->s_thing)
diff --git a/externals/iem/iemgui/src/numberbox_matrix.c b/externals/iem/iemgui/src/numberbox_matrix.c
index c71f2f5a29fedd0c72216e6f00e220e9667d5b47..f6e41b9a46965ba535b7ac0cd44c83bc1b07b8ce 100644
--- a/externals/iem/iemgui/src/numberbox_matrix.c
+++ b/externals/iem/iemgui/src/numberbox_matrix.c
@@ -716,7 +716,7 @@ static void numberbox_matrix_click(t_numberbox_matrix *x, t_floatarg xpos, t_flo
                                    t_floatarg shift, t_floatarg ctrl, t_floatarg alt)
 {
   glist_grab(x->x_gui.x_glist, &x->x_gui.x_obj.te_g,
-    (t_glistmotionfn)numberbox_matrix_motion, numberbox_matrix_key, xpos, ypos);
+    (t_glistmotionfn)numberbox_matrix_motion, numberbox_matrix_key, 0, xpos, ypos);
 }
 
 static int numberbox_matrix_newclick(t_gobj *z, struct _glist *glist, int xpix, int ypix, int shift, int alt, int dbl, int doit)
diff --git a/externals/iem/iemgui/src/room_sim_2d.c b/externals/iem/iemgui/src/room_sim_2d.c
index 7f57c69296527284c511a119488afb5a8d2798ec..4dc9535b3263113c28d45c5f44b82b05e3d69d73 100644
--- a/externals/iem/iemgui/src/room_sim_2d.c
+++ b/externals/iem/iemgui/src/room_sim_2d.c
@@ -440,7 +440,7 @@ static void room_sim_2d_click(t_room_sim_2d *x, t_floatarg xpos, t_floatarg ypos
     x->x_pos_x = x->x_pix_src_x[sel];
     x->x_pos_y = x->x_pix_src_y[sel];
     glist_grab(x->x_gui.x_glist, &x->x_gui.x_obj.te_g,
-      (t_glistmotionfn)room_sim_2d_motion, 0, xpos, ypos);
+      (t_glistmotionfn)room_sim_2d_motion, 0, 0, xpos, ypos);
   }
 }
 
diff --git a/externals/iem/iemgui/src/room_sim_3d.c b/externals/iem/iemgui/src/room_sim_3d.c
index 7b845683760bd0e0aabcabc774872bbdf52bef70..11d9dad5367cd42cbdc4776d029ad0e6e4c5eb83 100644
--- a/externals/iem/iemgui/src/room_sim_3d.c
+++ b/externals/iem/iemgui/src/room_sim_3d.c
@@ -532,7 +532,7 @@ static void room_sim_3d_click(t_room_sim_3d *x, t_floatarg xpos, t_floatarg ypos
     x->x_pos_x = x->x_pix_src_x[sel];
     x->x_pos_y = x->x_pix_src_y[sel];
     x->x_pos_z = x->x_pix_src_z[sel];
-    glist_grab(x->x_gui.x_glist, &x->x_gui.x_obj.te_g, (t_glistmotionfn)room_sim_3d_motion, 0, xpos, ypos);
+    glist_grab(x->x_gui.x_glist, &x->x_gui.x_obj.te_g, (t_glistmotionfn)room_sim_3d_motion, 0, 0, xpos, ypos);
   }
 }
 
diff --git a/externals/miXed/cyclone/hammer/comment.c b/externals/miXed/cyclone/hammer/comment.c
index 003f2541645b08b55b4e941a9fe8aac1b1075886..25a71b7f4431be699d0251f45393cc759bfef83a 100644
--- a/externals/miXed/cyclone/hammer/comment.c
+++ b/externals/miXed/cyclone/hammer/comment.c
@@ -195,7 +195,7 @@ static void comment_dograb(t_comment *x)
        Here we use it just to prevent backspace from erasing entire text.
        This has to be done also when we are already active, because
        after being clicked at we have lost our previous grab. */
-    glist_grab(x->x_glist, (t_gobj *)x, 0, comment_grabbedkey, 0, 0);
+    glist_grab(x->x_glist, (t_gobj *)x, 0, comment_grabbedkey, 0, 0, 0);
 }
 
 static void comment__bboxhook(t_comment *x, t_symbol *bindsym,
diff --git a/externals/moonlib/mknob.c b/externals/moonlib/mknob.c
index f12edcf074f1e1726cf0b65bf2ab5c49113ce996..d8430ffd9a82dda7841619e81bb89f9b941560e7 100644
--- a/externals/moonlib/mknob.c
+++ b/externals/moonlib/mknob.c
@@ -450,13 +450,13 @@ static void mknob_click(t_mknob *x, t_floatarg xpos, t_floatarg ypos,
 
     if (x->x_gui.x_h<0)
         glist_grab(x->x_gui.x_glist, &x->x_gui.x_obj.te_g,
-                   (t_glistmotionfn)mknob_motion_fullcircular, 0, xpos, ypos);
+                   (t_glistmotionfn)mknob_motion_fullcircular, 0, 0, xpos, ypos);
     else if (x->x_gui.x_h==0)
         glist_grab(x->x_gui.x_glist, &x->x_gui.x_obj.te_g,
-                   (t_glistmotionfn)mknob_motion_circular, 0, xpos, ypos);
+                   (t_glistmotionfn)mknob_motion_circular, 0, 0, xpos, ypos);
     else
         glist_grab(x->x_gui.x_glist, &x->x_gui.x_obj.te_g,
-                   (t_glistmotionfn)mknob_motion, 0, xpos, ypos);
+                   (t_glistmotionfn)mknob_motion, 0, 0, xpos, ypos);
 }
 
 static int mknob_newclick(t_gobj *z, struct _glist *glist,
diff --git a/externals/pidip/modules/pdp_colorgrid.c b/externals/pidip/modules/pdp_colorgrid.c
index b60be7238206fc050a10405bb8d17f6534881bf1..c47b16fb43a514bc96da8a088e74c1964f698aba 100755
--- a/externals/pidip/modules/pdp_colorgrid.c
+++ b/externals/pidip/modules/pdp_colorgrid.c
@@ -1481,7 +1481,7 @@ static int pdp_colorgrid_click(t_gobj *z, struct _glist *glist,
       pdp_colorgrid_output_current(x);
       pdp_colorgrid_draw_update(x, glist);
       glist_grab(glist, &x->x_obj.te_g, (t_glistmotionfn)pdp_colorgrid_motion,
-	       0, xpix, ypix);
+	       0, 0, xpix, ypix);
     }
     return (1);
 }
diff --git a/externals/tof/src/w_breakpoints.h b/externals/tof/src/w_breakpoints.h
index b747672bc0d9f182871351c6eec5303f15f8fd76..24defdb2b036e566659596b106f9eecd029e2d00 100644
--- a/externals/tof/src/w_breakpoints.h
+++ b/externals/tof/src/w_breakpoints.h
@@ -518,7 +518,7 @@ static int breakpoints_newclick(t_breakpoints *x, struct _glist *glist,
          breakpoints_next_doodle(x,glist,xpos,ypos);
 
          glist_grab(x->w.glist, &x->x_obj.te_g, (t_glistmotionfn) breakpoints_motion,
-                    (t_glistkeyfn) breakpoints_key, xpos, ypos);
+                    (t_glistkeyfn) breakpoints_key, 0, xpos, ypos);
              
          x->w.shift = shift;
          breakpoints_followpointer(x,glist);
@@ -544,7 +544,7 @@ static int breakpoints_newclick(t_breakpoints *x, struct _glist *glist,
          breakpoints_next_doodle(x,glist,xpos,ypos);
 
          glist_grab(x->w.glist, &x->x_obj.te_g, (t_glistmotionfn) breakpoints_motion,
-                    (t_glistkeyfn) breakpoints_key, xpos, ypos);
+                    (t_glistkeyfn) breakpoints_key, 0, xpos, ypos);
 
          x->resizing = 0;     
          if (x->resizeable && (xpos > wxpos + x->w.width) && 
diff --git a/externals/unauthorized/audience~.c b/externals/unauthorized/audience~.c
index 237a70d69dc9ed63fd702c1450adcac0bfc7a7ca..87081724544af13a3fa6611942def8e0cceda186 100644
--- a/externals/unauthorized/audience~.c
+++ b/externals/unauthorized/audience~.c
@@ -670,7 +670,7 @@ static int audience_click(t_gobj *z, struct _glist *glist,
         }
         audience_draw_update(x, glist);
         glist_grab(glist, &x->x_obj.te_g, (t_glistmotionfn)audience_motion,
-                   0, xpix, ypix);
+                   0, 0, xpix, ypix);
     }
     return (1);
 }
diff --git a/externals/unauthorized/cooled~.c b/externals/unauthorized/cooled~.c
index 11354eb537217ca121278ba0223eb9f5c465e8d8..b234b7c179049938100a75f4d4646fa2baf845fd 100644
--- a/externals/unauthorized/cooled~.c
+++ b/externals/unauthorized/cooled~.c
@@ -880,7 +880,7 @@ static int cooled_click(t_gobj *z, struct _glist *glist,
             x->x_alted = alt;
             // activate motion callback
             glist_grab( glist, &x->x_obj.te_g, (t_glistmotionfn)cooled_motion,
-                        0, xpix, ypix );
+                        0, 0, xpix, ypix );
 
             // draw insertion line
             if ( glist_isvisible( x->x_glist ) )
diff --git a/externals/unauthorized/grid.c b/externals/unauthorized/grid.c
index ad67e504c0c1a39eb217e39aa9bf0a488eeb39dd..9a423dbe070e573cd2895fabf429b394db504cbf 100644
--- a/externals/unauthorized/grid.c
+++ b/externals/unauthorized/grid.c
@@ -510,7 +510,7 @@ static int grid_click(t_gobj *z, struct _glist *glist,
         grid_output_current(x);
         grid_draw_update(x, glist);
         glist_grab(glist, &x->x_obj.te_g, (t_glistmotionfn)grid_motion,
-            0, xpix, ypix);
+            0, 0, xpix, ypix);
     }
     return (1);
 }
diff --git a/externals/unauthorized/playlist.c b/externals/unauthorized/playlist.c
index f663152b09f8ace73d760d33d292aa7ca392c1bd..d9e869e7fbadb9886ec27b012dfbe8c41bd5e29c 100644
--- a/externals/unauthorized/playlist.c
+++ b/externals/unauthorized/playlist.c
@@ -640,7 +640,7 @@ static int playlist_click(t_gobj *z, struct _glist *glist,
         }
         x->x_glist = glist;
         glist_grab( glist, &x->x_obj.te_g, (t_glistmotionfn)playlist_motion,
-                    NULL, xpix, ypix );
+                    NULL, NULL, xpix, ypix );
     }
     return (1);
 }
diff --git a/externals/unauthorized/scratcher~.c b/externals/unauthorized/scratcher~.c
index e4c5c168d8daa2472c188f45d0c5e6b07ed57a44..14b5088fb030f9c79fc45da3f5f5656a749e387f 100644
--- a/externals/unauthorized/scratcher~.c
+++ b/externals/unauthorized/scratcher~.c
@@ -417,7 +417,7 @@ static int scratcher_click(t_gobj *z, struct _glist *glist,
     {
         // activate motion callback
         glist_grab( glist, &x->x_obj.te_g, (t_glistmotionfn)scratcher_motion,
-                    0, xpix, ypix );
+                    0, 0, xpix, ypix );
         x->x_readspeed=0.;
         x->x_motioned = 1;
         if ( x->x_showspeed )
diff --git a/externals/unauthorized/scrolllist.c b/externals/unauthorized/scrolllist.c
index cb4f0a0680ddbf504d9b9f692f209452222a5084..5a85c2fbdb9bd287ee6fe1051e404a0b8fbb3756 100644
--- a/externals/unauthorized/scrolllist.c
+++ b/externals/unauthorized/scrolllist.c
@@ -426,7 +426,7 @@ static int scrolllist_click(t_gobj *z, struct _glist *glist,
         }
         x->x_glist = glist;
         glist_grab( glist, &x->x_obj.te_g, (t_glistmotionfn)scrolllist_motion,
-                    NULL, xpix, ypix );
+                    NULL, NULL, xpix, ypix );
     }
     return (1);
 }
diff --git a/externals/unauthorized/sonogram~.c b/externals/unauthorized/sonogram~.c
index 9d3b1aeff0a3ad81917b6b1b519fe2494f686a04..30efb5c2acd502cc538994817efc688639dced40 100644
--- a/externals/unauthorized/sonogram~.c
+++ b/externals/unauthorized/sonogram~.c
@@ -1116,7 +1116,7 @@ static int sonogram_click(t_gobj *z, struct _glist *glist,
         x->x_alted = alt;
         // activate motion callback
         glist_grab( glist, &x->x_obj.te_g, (t_glistmotionfn)sonogram_motion,
-                    0, xpix, ypix );
+                    0, 0, xpix, ypix );
 
         if ( shift && alt && (x->x_xstartcapture != x->x_xendcapture ) )
         {