]> git.eshelyaron.com Git - emacs.git/commitdiff
* xdisp.c (set_cursor_from_row): Simplify conditionals,
authorPaul Eggert <eggert@cs.ucla.edu>
Wed, 12 Oct 2011 05:50:15 +0000 (22:50 -0700)
committerPaul Eggert <eggert@cs.ucla.edu>
Wed, 12 Oct 2011 05:50:15 +0000 (22:50 -0700)
to pacify GCC 4.6.1 x86-64 with -O2 -Wstrict-overflow.

src/ChangeLog
src/xdisp.c

index 8ad59d5eb27bb8e8a40368f89858d340f1a554ed..8b4f56dd8c2e336dff091f29574486b826a1f7a2 100644 (file)
@@ -1,5 +1,8 @@
 2011-10-12  Paul Eggert  <eggert@cs.ucla.edu>
 
+       * xdisp.c (set_cursor_from_row): Simplify conditionals,
+       to pacify GCC 4.6.1 x86-64 with -O2 -Wstrict-overflow.
+
        * lread.c (read_escape): Allow hex escapes as large as ?\xfffffff.
        Some packages use them to denote characters with modifiers.
 
index e7fc1b4b37e50970106c8a59fc438a5e62afe25a..86098553e1dd06c45b6cb4c4bb5cb64852df1b5d 100644 (file)
@@ -13874,27 +13874,9 @@ set_cursor_from_row (struct window *w, struct glyph_row *row,
              glyph--;
            }
        }
-      else if (match_with_avoid_cursor
-              /* A truncated row may not include PT among its
-                 character positions.  Setting the cursor inside the
-                 scroll margin will trigger recalculation of hscroll
-                 in hscroll_window_tree.  But if a display string
-                 covers point, defer to the string-handling code
-                 below to figure this out.  */
-              || (!string_seen
-                  && ((row->truncated_on_left_p && pt_old < bpos_min)
-                      || (row->truncated_on_right_p && pt_old > bpos_max)
-                      /* Zero-width characters produce no glyphs.  */
-                      || (!empty_line_p
-                          && (row->reversed_p
-                              ? glyph_after > glyphs_end
-                              : glyph_after < glyphs_end)))))
-       {
-         if (!match_with_avoid_cursor
-             && row->truncated_on_left_p && pt_old < bpos_min)
-           cursor = glyph_before;
-         else
-           cursor = glyph_after;
+      else if (match_with_avoid_cursor)
+       {
+         cursor = glyph_after;
          x = -1;
        }
       else if (string_seen)
@@ -14033,6 +14015,26 @@ set_cursor_from_row (struct window *w, struct glyph_row *row,
              && row->continued_p)
            return 0;
        }
+      /* A truncated row may not include PT among its character positions.
+        Setting the cursor inside the scroll margin will trigger
+        recalculation of hscroll in hscroll_window_tree.  But if a
+        display string covers point, defer to the string-handling
+        code below to figure this out.  */
+      else if (row->truncated_on_left_p && pt_old < bpos_min)
+       {
+         cursor = glyph_before;
+         x = -1;
+       }
+      else if ((row->truncated_on_right_p && pt_old > bpos_max)
+              /* Zero-width characters produce no glyphs.  */
+              || (!empty_line_p
+                  && (row->reversed_p
+                      ? glyph_after > glyphs_end
+                      : glyph_after < glyphs_end)))
+       {
+         cursor = glyph_after;
+         x = -1;
+       }
     }
 
  compute_x: