]> err.no Git - libchamplain/commitdiff
Catch the division by 0 as soon as possible
authorEmmanuel Rodriguez <emmanuel.rodriguez@booking.com>
Fri, 31 Jul 2009 18:53:34 +0000 (20:53 +0200)
committerPierre-Luc Beaudoin <pierre-luc@pierlux.com>
Sat, 1 Aug 2009 19:22:09 +0000 (15:22 -0400)
tidy/tidy-finger-scroll.c

index f57f379d48b2ab2ee20d2bfb32a56be58b006c06..55ebe85c6d8351daed9c75f40fe19d710f10c68e 100644 (file)
@@ -424,22 +424,23 @@ button_release_event_cb (ClutterActor *actor,
             time_diff = release_time.tv_usec +
                         (G_USEC_PER_SEC - motion_time.tv_usec);
           
-          /* Work out the fraction of 1/60th of a second that has elapsed */
-          frac = clutter_qdivx (CLUTTER_FLOAT_TO_FIXED (time_diff/1000.0),
-                                CLUTTER_FLOAT_TO_FIXED (1000.0/60.0));
-          
-          /* On a macbook that's running Ubuntu 9.04 sometimes frac is 0 and
-             this causes a division by 0. Here we try to avoid that.
+          /* On a macbook that's running Ubuntu 9.04 sometimes 'time_diff' is 0
+             and this causes a division by 0 when computing 'frac'. This check
+             avoids this error.
            */
-          if (frac == 0)
+          if (time_diff == 0)
             {
-                g_print ("Caught a division by 0 (%d / %d).\n",
+                g_print ("Preventing a division by 0 (%d / %d).\n",
                     CLUTTER_FLOAT_TO_FIXED (time_diff/1000.0),
                     CLUTTER_FLOAT_TO_FIXED (1000.0/60.0)
                 );
                 clutter_event_put ((ClutterEvent *)event);
                 return TRUE;
             }
+
+          /* Work out the fraction of 1/60th of a second that has elapsed */
+          frac = clutter_qdivx (CLUTTER_FLOAT_TO_FIXED (time_diff/1000.0),
+                                CLUTTER_FLOAT_TO_FIXED (1000.0/60.0));
           /* See how many units to move in 1/60th of a second */
           priv->dx = CLUTTER_UNITS_FROM_FIXED(clutter_qdivx (
                      CLUTTER_UNITS_TO_FIXED(x_origin - x), frac));