]> git.eshelyaron.com Git - emacs.git/commitdiff
* xterm.c (x_alloc_nearest_color_1): Go back to original algorithm.
authorPaul Eggert <eggert@cs.ucla.edu>
Mon, 13 Jun 2011 16:08:46 +0000 (09:08 -0700)
committerPaul Eggert <eggert@cs.ucla.edu>
Mon, 13 Jun 2011 16:08:46 +0000 (09:08 -0700)
src/ChangeLog
src/xterm.c

index 6bac6f00a3fe5e0d3d4d8471d6b0d558cc6403cf..43e1f9dbc067f841b57358b91cbd8333c6870585 100644 (file)
@@ -1,8 +1,6 @@
 2011-06-13  Paul Eggert  <eggert@cs.ucla.edu>
 
-       * xterm.c (x_alloc_nearest_color_1): Use a more-precise algorithm
-       for nearest color, one that neither overflows nor relies on unsigned
-       arithmetic.
+       * xterm.c (x_alloc_nearest_color_1): Prefer int to long when int works.
 
        Remove unnecessary casts.
        * xterm.c (x_term_init):
index 914cdc429d6a25011c920cdf5e16d52ef18a1389..f40d260dabe134b6c4890ad48af14c747c127f31 100644 (file)
@@ -1697,7 +1697,7 @@ x_alloc_nearest_color_1 (Display *dpy, Colormap cmap, XColor *color)
         a least-squares matching, which is what X uses for closest
         color matching with StaticColor visuals.  */
       int nearest, i;
-      int max_color_delta = (1 << (16 - 2)) - 1;
+      int max_color_delta = 255;
       int max_delta = 3 * max_color_delta;
       int nearest_delta = max_delta + 1;
       int ncells;
@@ -1705,9 +1705,9 @@ x_alloc_nearest_color_1 (Display *dpy, Colormap cmap, XColor *color)
 
       for (nearest = i = 0; i < ncells; ++i)
        {
-         int dred   = (color->red   >> 2) - (cells[i].red   >> 2);
-         int dgreen = (color->green >> 2) - (cells[i].green >> 2);
-         int dblue  = (color->blue  >> 2) - (cells[i].blue  >> 2);
+         int dred   = (color->red   >> 8) - (cells[i].red   >> 8);
+         int dgreen = (color->green >> 8) - (cells[i].green >> 8);
+         int dblue  = (color->blue  >> 8) - (cells[i].blue  >> 8);
          int delta = dred * dred + dgreen * dgreen + dblue * dblue;
 
          if (delta < nearest_delta)