]> git.eshelyaron.com Git - emacs.git/commitdiff
Merge with gnulib, pacifying GCC 7
authorPaul Eggert <eggert@cs.ucla.edu>
Tue, 16 May 2017 17:24:19 +0000 (10:24 -0700)
committerPaul Eggert <eggert@cs.ucla.edu>
Tue, 16 May 2017 17:27:41 +0000 (10:27 -0700)
This incorporates:
2017-05-16 manywarnings: update for GCC 7
2017-05-15 sys_select: Avoid "was expanded before it was required"
* configure.ac (nw): Suppress GCC 7’s new -Wduplicated-branches and
-Wformat-overflow=2 options, due to too many false alarms.
* doc/misc/texinfo.tex, lib/strftime.c, m4/manywarnings.m4:
Copy from gnulib.
* m4/gnulib-comp.m4: Regenerate.
* src/coding.c (decode_coding_iso_2022):
Fix bug uncovered by -Wimplicit-fallthrough.
* src/conf_post.h (FALLTHROUGH): New macro.
Use it to mark all switch cases that fall through.
* src/editfns.c (styled_format): Use !, not ~, on bool.
* src/gtkutil.c (xg_check_special_colors):
When using sprintf, don’t trust Gtk to output colors in [0, 1] range.
(xg_update_scrollbar_pos): Avoid use of possibly-uninitialized bool;
this bug was actually caught by Clang.
* src/search.c (boyer_moore):
Tell GCC that CHAR_BASE, if nonzero, must be a non-ASCII character.
* src/xterm.c (x_draw_glyphless_glyph_string_foreground):
Tell GCC that glyph->u.glyphless.ch must be a character.

25 files changed:
configure.ac
doc/misc/texinfo.tex
lib-src/ebrowse.c
lib-src/etags.c
lib/strftime.c
m4/gnulib-comp.m4
m4/manywarnings.m4
src/bidi.c
src/callint.c
src/ccl.c
src/coding.c
src/conf_post.h
src/data.c
src/doprnt.c
src/editfns.c
src/eval.c
src/filelock.c
src/gnutls.c
src/gtkutil.c
src/indent.c
src/lread.c
src/regex.c
src/search.c
src/syntax.c
src/xterm.c

index d085552ffea928050e67d881152e14395b29242c..34b75a768bf84c28925f7589630664e9c18b9538 100644 (file)
@@ -921,6 +921,8 @@ AS_IF([test $gl_gcc_warnings = no],
     [gl_WARN_ADD([-Werror], [WERROR_CFLAGS])])
   AC_SUBST([WERROR_CFLAGS])
 
+  nw="$nw -Wduplicated-branches"    # Too many false alarms
+  nw="$nw -Wformat-overflow=2"      # False alarms due to GCC bug 80776
   nw="$nw -Wsystem-headers"         # Don't let system headers trigger warnings
   nw="$nw -Woverlength-strings"     # Not a problem these days
   nw="$nw -Wformat-nonliteral"      # we do this a lot
index 9cd73101c1fb4ee0bcaf033be0f24e893b9bbf72..8204f3e3aeb894572b1a1d6794c7234ed9c32cb1 100644 (file)
@@ -3,7 +3,7 @@
 % Load plain if necessary, i.e., if running under initex.
 \expandafter\ifx\csname fmtname\endcsname\relax\input plain\fi
 %
-\def\texinfoversion{2017-04-14.11}
+\def\texinfoversion{2017-05-14.14}
 %
 % Copyright 1985, 1986, 1988, 1990, 1991, 1992, 1993, 1994, 1995,
 % 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006,
@@ -9118,7 +9118,13 @@ end
     \xdef\safexrefname{#1}%
   }%
   %
-  \expandafter\gdef\csname XR\safexrefname\endcsname{#2}% remember this xref
+  \bgroup
+    \expandafter\gdef\csname XR\safexrefname\endcsname{#2}%
+  \egroup
+  % We put the \gdef inside a group to avoid the definitions building up on 
+  % TeX's save stack, which can cause it to run out of space for aux files with 
+  % thousands of lines.  \gdef doesn't use the save stack, but \csname does
+  % when it defines an unknown control sequence as \relax. 
   %
   % Was that xref control sequence that we just defined for a float?
   \expandafter\iffloat\csname XR\safexrefname\endcsname
index 623911027cea4a441e8b71b167f2549cde289a32..51d181997b16fada3dd70370f3e037e64d841f5e 100644 (file)
@@ -3059,8 +3059,7 @@ class_definition (struct sym *containing, int tag, int flags, int nested)
                  MATCH until we see something like `;' or `{'.  */
               while (!LOOKING_AT3 (';', YYEOF, '{'))
                 MATCH ();
-             done = 1;
-
+             FALLTHROUGH;
             case '{':
               done = 1;
              break;
@@ -3184,7 +3183,7 @@ declaration (int flags)
              free (id);
              return;
            }
-
+         FALLTHROUGH;
         case '=':
           /* Assumed to be the start of an initialization in this
             context.  */
index 015cbbe0ef3eca166a4b429fd4987ece710f8d37..6f280d8ab40bc03d04598babef5c34cd6a06f675 100644 (file)
@@ -1157,7 +1157,7 @@ main (int argc, char **argv)
       case 'c':
        /* Backward compatibility: support obsolete --ignore-case-regexp. */
        optarg = concat (optarg, "i", ""); /* memory leak here */
-       /* FALLTHRU */
+       FALLTHROUGH;
       case 'r':
        argbuffer[current_arg].arg_type = at_regexp;
        argbuffer[current_arg].what = optarg;
@@ -1192,7 +1192,7 @@ main (int argc, char **argv)
       case 't': typedefs = true;                               break;
       case 'T': typedefs = typedefs_or_cplusplus = true;       break;
       case 'u': update = true;                                 break;
-      case 'v': vgrind_style = true;                     /*FALLTHRU*/
+      case 'v': vgrind_style = true;                           FALLTHROUGH;
       case 'x': cxref_style = true;                            break;
       case 'w': no_warnings = true;                            break;
       default:
@@ -2564,7 +2564,7 @@ hash (const char *str, int len)
     {
       default:
         hval += asso_values[(unsigned char) str[2]];
-      /*FALLTHROUGH*/
+       FALLTHROUGH;
       case 2:
         hval += asso_values[(unsigned char) str[1]];
         break;
@@ -3013,7 +3013,7 @@ consider_token (char *str, int len, int c, int *c_extp,
         *c_extp = (*c_extp | C_PLPL) & ~C_AUTO;
        if (toktype == st_C_template)
         break;
-       /* FALLTHRU */
+       FALLTHROUGH;
      case st_C_struct:
      case st_C_enum:
        if (parlev == 0
@@ -3176,7 +3176,7 @@ consider_token (char *str, int len, int c, int *c_extp,
             default:
               break;
             }
-         /* FALLTHRU */
+          FALLTHROUGH;
          case fvnameseen:
          if (len >= 10 && strneq (str+len-10, "::operator", 10))
            {
@@ -3387,7 +3387,7 @@ C_entries (int c_ext, FILE *inf)
            case '\0':
              /* Hmmm, something went wrong. */
              CNL ();
-             /* FALLTHRU */
+             FALLTHROUGH;
            case '\'':
              inchar = false;
              break;
@@ -3828,7 +3828,7 @@ C_entries (int c_ext, FILE *inf)
                      || (members
                          && plainc && instruct))
                    make_C_tag (true);  /* a function */
-                 /* FALLTHRU */
+                 FALLTHROUGH;
                default:
                  fvextern = false;
                  fvdef = fvnone;
@@ -3838,7 +3838,7 @@ C_entries (int c_ext, FILE *inf)
                  else
                    token.valid = false;
                } /* switch (fvdef) */
-             /* FALLTHRU */
+             FALLTHROUGH;
            default:
              if (!instruct)
                typdef = tnone;
@@ -3926,7 +3926,7 @@ C_entries (int c_ext, FILE *inf)
                      || (globals && bracelev == 0
                          && (!fvextern || declarations)))
                    make_C_tag (false); /* a variable */
-                 /* FALLTHRU */
+                 FALLTHROUGH;
                default:
                  fvdef = fvnone;
                }
@@ -3959,7 +3959,7 @@ C_entries (int c_ext, FILE *inf)
                  fvdef = fignore;
                  break;
                }
-             /* FALLTHRU */
+             FALLTHROUGH;
            case foperator:
              fvdef = fstartlist;
              break;
@@ -4049,7 +4049,7 @@ C_entries (int c_ext, FILE *inf)
                    }
                }
              make_C_tag (true);    /* a function */
-             /* FALLTHRU */
+             FALLTHROUGH;
            case fignore:
              fvdef = fvnone;
              break;
@@ -4142,7 +4142,7 @@ C_entries (int c_ext, FILE *inf)
              if ((members && bracelev == 1)
                  || (globals && bracelev == 0 && (!fvextern || declarations)))
                make_C_tag (false); /* a variable */
-             /* FALLTHRU */
+             FALLTHROUGH;
            default:
              fvdef = vignore;
            }
@@ -4169,7 +4169,7 @@ C_entries (int c_ext, FILE *inf)
              objdef = omethodsign;
              break;
            }
-         /* FALLTHRU */
+         FALLTHROUGH;
        resetfvdef:
        case '#': case '~': case '&': case '%': case '/':
        case '|': case '^': case '!': case '.': case '?':
@@ -6354,7 +6354,7 @@ add_regex (char *regexp_pattern, language *lang)
        break;
       case 's':
        single_line = true;
-       /* FALLTHRU */
+       FALLTHROUGH;
       case 'm':
        multi_line = true;
        need_filebuf = true;
index e4d78ef70119425254180e2505c51980729b8466..99bee4ef978048e89b8a386b31aa70ac8441217f 100644 (file)
@@ -68,6 +68,14 @@ extern char *tzname[];
 #include <string.h>
 #include <stdbool.h>
 
+#ifndef FALLTHROUGH
+# if __GNUC__ < 7
+#  define FALLTHROUGH ((void) 0)
+# else
+#  define FALLTHROUGH __attribute__ ((__fallthrough__))
+# endif
+#endif
+
 #ifdef COMPILE_WIDE
 # include <endian.h>
 # define CHAR_T wchar_t
@@ -1138,8 +1146,7 @@ __strftime_internal (STREAM_OR_CHAR_T *s, STRFTIME_ARG (size_t maxsize)
 #ifndef _NL_CURRENT
           format_char = L_('p');
 #endif
-          /* FALLTHROUGH */
-
+          FALLTHROUGH;
         case L_('p'):
           if (change_case)
             {
@@ -1474,7 +1481,7 @@ __strftime_internal (STREAM_OR_CHAR_T *s, STRFTIME_ARG (size_t maxsize)
 
         case L_('\0'):          /* GNU extension: % at end of format.  */
             --f;
-            /* Fall through.  */
+            FALLTHROUGH;
         default:
           /* Unknown format; output the format, including the '%',
              since this is most likely the right thing to do if a
index 8295e483582307a99c003febe1e262f332e76fc3..3f196d4f1dee452d58f3fb0b7e2632578c3f921e 100644 (file)
@@ -375,7 +375,7 @@ AC_DEFUN([gl_INIT],
     AC_LIBOBJ([symlink])
   fi
   gl_UNISTD_MODULE_INDICATOR([symlink])
-  gl_HEADER_SYS_SELECT
+  AC_REQUIRE([gl_HEADER_SYS_SELECT])
   AC_PROG_MKDIR_P
   gl_HEADER_SYS_STAT_H
   AC_PROG_MKDIR_P
index 0f06adecfbb511b049d70c3097e0c8e07839d952..2d35eff6a2cf2981469f14212b11d70fec251561 100644 (file)
@@ -99,12 +99,11 @@ AC_DEFUN([gl_MANYWARN_ALL_GCC],
   # comm -3 \
   #  <(sed -n 's/^  *\(-[^ ]*\) .*/\1/p' manywarnings.m4 | sort) \
   #  <(gcc --help=warnings | sed -n 's/^  \(-[^ ]*\) .*/\1/p' | sort |
-  #      grep -v -x -f <(
+  #      grep -v -x -F -f <(
   #         awk '/^[^#]/ {print $1}' ../build-aux/gcc-warning.spec))
 
   gl_manywarn_set=
-  for gl_manywarn_item in \
-    -fno-common \
+  for gl_manywarn_item in -fno-common \
     -W \
     -Wabi \
     -Waddress \
@@ -113,6 +112,8 @@ AC_DEFUN([gl_MANYWARN_ALL_GCC],
     -Wattributes \
     -Wbad-function-cast \
     -Wbool-compare \
+    -Wbool-operation \
+    -Wbuiltin-declaration-mismatch \
     -Wbuiltin-macro-redefined \
     -Wcast-align \
     -Wchar-subscripts \
@@ -122,6 +123,7 @@ AC_DEFUN([gl_MANYWARN_ALL_GCC],
     -Wcomments \
     -Wcoverage-mismatch \
     -Wcpp \
+    -Wdangling-else \
     -Wdate-time \
     -Wdeprecated \
     -Wdeprecated-declarations \
@@ -131,10 +133,13 @@ AC_DEFUN([gl_MANYWARN_ALL_GCC],
     -Wdiscarded-qualifiers \
     -Wdiv-by-zero \
     -Wdouble-promotion \
+    -Wduplicated-branches \
     -Wduplicated-cond \
+    -Wduplicate-decl-specifier \
     -Wempty-body \
     -Wendif-labels \
     -Wenum-compare \
+    -Wexpansion-to-defined \
     -Wextra \
     -Wformat-contains-nul \
     -Wformat-extra-args \
@@ -155,6 +160,7 @@ AC_DEFUN([gl_MANYWARN_ALL_GCC],
     -Winit-self \
     -Winline \
     -Wint-conversion \
+    -Wint-in-bool-context \
     -Wint-to-pointer-cast \
     -Winvalid-memory-model \
     -Winvalid-pch \
@@ -163,6 +169,7 @@ AC_DEFUN([gl_MANYWARN_ALL_GCC],
     -Wlogical-op \
     -Wmain \
     -Wmaybe-uninitialized \
+    -Wmemset-elt-size \
     -Wmemset-transposed-args \
     -Wmisleading-indentation \
     -Wmissing-braces \
@@ -188,9 +195,12 @@ AC_DEFUN([gl_MANYWARN_ALL_GCC],
     -Wpacked-bitfield-compat \
     -Wparentheses \
     -Wpointer-arith \
+    -Wpointer-compare \
     -Wpointer-sign \
     -Wpointer-to-int-cast \
     -Wpragmas \
+    -Wpsabi \
+    -Wrestrict \
     -Wreturn-local-addr \
     -Wreturn-type \
     -Wscalar-storage-order \
@@ -214,6 +224,7 @@ AC_DEFUN([gl_MANYWARN_ALL_GCC],
     -Wswitch \
     -Wswitch-bool \
     -Wswitch-default \
+    -Wswitch-unreachable \
     -Wsync-nand \
     -Wsystem-headers \
     -Wtautological-compare \
@@ -247,10 +258,18 @@ AC_DEFUN([gl_MANYWARN_ALL_GCC],
 
   # gcc --help=warnings outputs an unusual form for these options; list
   # them here so that the above 'comm' command doesn't report a false match.
+  # Would prefer "min (PTRDIFF_MAX, SIZE_MAX)", but it must be a literal:
+  ptrdiff_max_max=9223372036854775807
+  gl_manywarn_set="$gl_manywarn_set -Walloc-size-larger-than=$ptrdiff_max_max"
   gl_manywarn_set="$gl_manywarn_set -Warray-bounds=2"
+  gl_manywarn_set="$gl_manywarn_set -Wformat-overflow=2"
+  gl_manywarn_set="$gl_manywarn_set -Wformat-truncation=2"
+  gl_manywarn_set="$gl_manywarn_set -Wimplicit-fallthrough=5"
   gl_manywarn_set="$gl_manywarn_set -Wnormalized=nfc"
   gl_manywarn_set="$gl_manywarn_set -Wshift-overflow=2"
+  gl_manywarn_set="$gl_manywarn_set -Wstringop-overflow=2"
   gl_manywarn_set="$gl_manywarn_set -Wunused-const-variable=2"
+  gl_manywarn_set="$gl_manywarn_set -Wvla-larger-than=4031"
 
   # These are needed for older GCC versions.
   if test -n "$GCC"; then
index b75ad933626793ccbe27bfa235aeb76ae7f2c5e7..dce0bf695f6fa188f80bebdf118ea628ac00ed1b 100644 (file)
@@ -2092,7 +2092,7 @@ bidi_resolve_explicit (struct bidi_it *bidi_it)
          type = RLI;
          bidi_it->orig_type = type;
        }
-      /* FALLTHROUGH */
+      FALLTHROUGH;
     case RLI:  /* X5a */
       if (override == NEUTRAL_DIR)
        bidi_it->type_after_wn = type;
index d96454883cf7f215382b72a6a1161d60d690bb3e..96436116c8bef9b827670f9c0c516a96ff0b4473 100644 (file)
@@ -690,6 +690,7 @@ invoke it.  If KEYS is omitted or nil, the return value of
        case 'N':     /* Prefix arg as number, else number from minibuffer.  */
          if (!NILP (prefix_arg))
            goto have_prefix_arg;
+         FALLTHROUGH;
        case 'n':               /* Read number from minibuffer.  */
          args[i] = call1 (Qread_number, callint_message);
          /* Passing args[i] directly stimulates compiler bug.  */
index 90bd2f4679432914cadf448074dd368e4cd465ce..b2caf413f7ab642787c35b75207687d5fc608321 100644 (file)
--- a/src/ccl.c
+++ b/src/ccl.c
@@ -1000,7 +1000,7 @@ ccl_driver (struct ccl_program *ccl, int *source, int *destination, int src_size
 
        case CCL_ReadBranch:    /* CCCCCCCCCCCCCCCCCCCCrrrXXXXX */
          CCL_READ_CHAR (reg[rrr]);
-         /* fall through ... */
+         FALLTHROUGH;
        case CCL_Branch:        /* CCCCCCCCCCCCCCCCCCCCrrrXXXXX */
        {
          int ioff = 0 <= reg[rrr] && reg[rrr] < field1 ? reg[rrr] : field1;
@@ -1174,6 +1174,7 @@ ccl_driver (struct ccl_program *ccl, int *source, int *destination, int src_size
 
        case CCL_ReadJumpCondExprConst: /* A--D--D--R--E--S--S-rrrXXXXX */
          CCL_READ_CHAR (reg[rrr]);
+         FALLTHROUGH;
        case CCL_JumpCondExprConst: /* A--D--D--R--E--S--S-rrrXXXXX */
          i = reg[rrr];
          jump_address = ic + ADDR;
@@ -1184,6 +1185,7 @@ ccl_driver (struct ccl_program *ccl, int *source, int *destination, int src_size
 
        case CCL_ReadJumpCondExprReg: /* A--D--D--R--E--S--S-rrrXXXXX */
          CCL_READ_CHAR (reg[rrr]);
+         FALLTHROUGH;
        case CCL_JumpCondExprReg:
          i = reg[rrr];
          jump_address = ic + ADDR;
index 367a9759848f84bd98b36232af665913f979fdd9..5682fc015add63ff29fbaef81a22496b4f0dfefc 100644 (file)
@@ -3611,7 +3611,7 @@ decode_coding_iso_2022 (struct coding_system *coding)
              || CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_SEVEN_BITS)
            goto invalid_code;
          /* This is a graphic character, we fall down ... */
-
+         FALLTHROUGH;
        case ISO_graphic_plane_1:
          if (charset_id_1 < 0)
            goto invalid_code;
@@ -3646,6 +3646,7 @@ decode_coding_iso_2022 (struct coding_system *coding)
        case ISO_single_shift_2_7:
          if (! (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_SEVEN_BITS))
            goto invalid_code;
+         FALLTHROUGH;
        case ISO_single_shift_2:
          if (! (CODING_ISO_FLAGS (coding) & CODING_ISO_FLAG_SINGLE_SHIFT))
            goto invalid_code;
@@ -3797,6 +3798,7 @@ decode_coding_iso_2022 (struct coding_system *coding)
                {
                case ']':       /* end of the current direction */
                  coding->mode &= ~CODING_MODE_DIRECTION;
+                 break;
 
                case '0':       /* end of the current direction */
                case '1':       /* start of left-to-right direction */
index 95ebd5511ca48285620c7d90e9799273dc3e6a4c..4fc0428df5aecf8e77d94d588370fca892ea087f 100644 (file)
@@ -244,6 +244,12 @@ extern int emacs_setenv_TZ (char const *);
 # define ATTRIBUTE_FORMAT(spec) /* empty */
 #endif
 
+#if GNUC_PREREQ (7, 0, 0)
+# define FALLTHROUGH __attribute__ ((__fallthrough__))
+#else
+# define FALLTHROUGH ((void) 0)
+#endif
+
 #if GNUC_PREREQ (4, 4, 0) && defined __GLIBC_MINOR__
 # define PRINTF_ARCHETYPE __gnu_printf__
 #elif GNUC_PREREQ (4, 4, 0) && defined __MINGW32__
index 44f7ba0e8816479ba6cb739e5d1d8fc6dda6696f..3ff2a809744c4809c2ab35754934c5b8044f5fb1 100644 (file)
@@ -2153,7 +2153,7 @@ If the current binding is global (the default), the value is nil.  */)
        else if (!BUFFER_OBJFWDP (valcontents))
          return Qnil;
       }
-      /* FALLTHROUGH */
+      FALLTHROUGH;
     case SYMBOL_LOCALIZED:
       /* For a local variable, record both the symbol and which
         buffer's or frame's value we are saving.  */
index 09051adc05313951a6abb313a124b2b9413f5bf6..bed9350f4a6d6e26ffe82cd0691c7c4fae80bdb1 100644 (file)
@@ -352,6 +352,7 @@ doprnt (char *buffer, ptrdiff_t bufsize, const char *format,
 
            case 'S':
              string[-1] = 's';
+             FALLTHROUGH;
            case 's':
              if (fmtcpy[1] != 's')
                minlen = atoi (&fmtcpy[1]);
index 38530437a2f5ab725f6370353aa87feb4924186b..ecb8e3f083889af936138cd611790685d6b2db77 100644 (file)
@@ -1595,10 +1595,10 @@ time_arith (Lisp_Object a, Lisp_Object b,
     {
     default:
       val = Fcons (make_number (t.ps), val);
-      /* Fall through.  */
+      FALLTHROUGH;
     case 3:
       val = Fcons (make_number (t.us), val);
-      /* Fall through.  */
+      FALLTHROUGH;
     case 2:
       val = Fcons (make_number (t.lo), val);
       val = Fcons (make_number (t.hi), val);
@@ -4072,8 +4072,8 @@ styled_format (ptrdiff_t nargs, Lisp_Object *args, bool message)
            }
 
          /* Ignore flags when sprintf ignores them.  */
-         space_flag &= ~ plus_flag;
-         zero_flag &= ~ minus_flag;
+         space_flag &= ! plus_flag;
+         zero_flag &= ! minus_flag;
 
          char *num_end;
          uintmax_t raw_field_width = strtoumax (format, &num_end, 10);
@@ -4311,7 +4311,7 @@ styled_format (ptrdiff_t nargs, Lisp_Object *args, bool message)
                  {
                    memcpy (f, pMd, pMlen);
                    f += pMlen;
-                   zero_flag &= ~ precision_given;
+                   zero_flag &= ! precision_given;
                  }
                *f++ = conversion;
                *f = '\0';
index 848955c2794c257ee6974a7c496ace633b2beb9c..98d25cc4fedb277934f0011fe7acf7ba1505e064 100644 (file)
@@ -3212,7 +3212,7 @@ do_specbind (struct Lisp_Symbol *sym, union specbinding *bind,
           set_default_internal (specpdl_symbol (bind), value, bindflag);
          return;
        }
-      /* FALLTHROUGH */
+      FALLTHROUGH;
     case SYMBOL_LOCALIZED:
       set_internal (specpdl_symbol (bind), value, Qnil, bindflag);
       break;
@@ -3390,12 +3390,10 @@ do_one_unbind (union specbinding *this_binding, bool unwinding,
                             Qnil, bindflag);
            break;
          }
-       else
-         { /* FALLTHROUGH!!
-              NOTE: we only ever come here if make_local_foo was used for
-              the first time on this var within this let.  */
-         }
       }
+      /* Come here only if make_local_foo was used for the first time
+        on this var within this let.  */
+      FALLTHROUGH;
     case SPECPDL_LET_DEFAULT:
       set_default_internal (specpdl_symbol (this_binding),
                             specpdl_old_value (this_binding),
@@ -3676,12 +3674,10 @@ backtrace_eval_unrewind (int distance)
                SET_SYMBOL_VAL (XSYMBOL (sym), old_value);
                break;
              }
-           else
-             { /* FALLTHROUGH!!
-                  NOTE: we only ever come here if make_local_foo was used for
-                  the first time on this var within this let.  */
-             }
          }
+         /* Come here only if make_local_foo was used for the first
+            time on this var within this let.  */
+         FALLTHROUGH;
        case SPECPDL_LET_DEFAULT:
          {
            Lisp_Object sym = specpdl_symbol (tmp);
@@ -3837,7 +3833,7 @@ mark_specpdl (union specbinding *first, union specbinding *ptr)
        case SPECPDL_LET_DEFAULT:
        case SPECPDL_LET_LOCAL:
          mark_object (specpdl_where (pdl));
-         /* Fall through.  */
+         FALLTHROUGH;
        case SPECPDL_LET:
          mark_object (specpdl_symbol (pdl));
          mark_object (specpdl_old_value (pdl));
index 67e8dbd34edf50642471414861237b66f871dd59..bfa1d63d8339a6b67426bf18d0bbfc2af35e977a 100644 (file)
@@ -569,7 +569,7 @@ current_lock_owner (lock_info_type *owner, char *lfname)
       if (! (boot[0] == '\200' && boot[1] == '\242'))
        return -1;
       boot += 2;
-      /* Fall through.  */
+      FALLTHROUGH;
     case ':':
       if (! c_isdigit (boot[0]))
        return -1;
index 28ab10de05c8a32085bda9aff3e0f1d9ddb65657..2078ad88f2873af66492b7f660a8413b0e6ea7ba 100644 (file)
@@ -605,6 +605,7 @@ emacs_gnutls_handle_error (gnutls_session_t session, int err)
                        max_log_level,
                        "retry:",
                        str);
+         FALLTHROUGH;
         default:
           GNUTLS_LOG2 (1,
                        max_log_level,
index 1b63293fe55dfb3ce02de1fc04f60a5030fc6a30..16eb284d7c799a678e0e4758584b9edaf964c6a3 100644 (file)
@@ -554,10 +554,11 @@ xg_check_special_colors (struct frame *f,
     else
       gtk_style_context_get_background_color (gsty, state, &col);
 
-    sprintf (buf, "rgb:%04x/%04x/%04x",
-             (unsigned) (col.red * 65535),
-             (unsigned) (col.green * 65535),
-             (unsigned) (col.blue * 65535));
+    unsigned short
+      r = col.red * 65535,
+      g = col.green * 65535,
+      b = col.blue * 65535;
+    sprintf (buf, "rgb:%04x/%04x/%04x", r, g, b);
     success_p = x_parse_color (f, buf, color) != 0;
 #else
     GtkStyle *gsty = gtk_widget_get_style (FRAME_GTK_WIDGET (f));
@@ -3856,7 +3857,6 @@ xg_update_scrollbar_pos (struct frame *f,
       GtkWidget *wparent = gtk_widget_get_parent (wscroll);
       gint msl;
       int scale = xg_get_gdk_scale ();
-      bool hidden;
 
       top /= scale;
       left /= scale;
@@ -3875,13 +3875,13 @@ xg_update_scrollbar_pos (struct frame *f,
       /* Move and resize to new values.  */
       gtk_fixed_move (GTK_FIXED (wfixed), wparent, left, top);
       gtk_widget_style_get (wscroll, "min-slider-length", &msl, NULL);
-      if (msl > height)
+      bool hidden = height < msl;
+      if (hidden)
         {
           /* No room.  Hide scroll bar as some themes output a warning if
              the height is less than the min size.  */
           gtk_widget_hide (wparent);
           gtk_widget_hide (wscroll);
-         hidden = true;
         }
       else
         {
index f630ebb847c619c133f0debea2b7d4f87f66073f..adecc3622a8a1a6a00e3203cf94a4f867b914b59 100644 (file)
@@ -925,6 +925,7 @@ position_indentation (ptrdiff_t pos_byte)
        case 0240:
          if (! NILP (BVAR (current_buffer, enable_multibyte_characters)))
            return column;
+         FALLTHROUGH;
        case ' ':
          column++;
          break;
index c03aad4f722d26eff7f4920c68dda81da1cce76d..5e737d690c605cd878a861f4fccedb5cefb7fd5d 100644 (file)
@@ -2309,6 +2309,7 @@ read_escape (Lisp_Object readcharfun, bool stringp)
       c = READCHAR;
       if (c != '-')
        error ("Invalid escape character syntax");
+      FALLTHROUGH;
     case '^':
       c = READCHAR;
       if (c == '\\')
@@ -2399,6 +2400,7 @@ read_escape (Lisp_Object readcharfun, bool stringp)
     case 'U':
       /* Post-Unicode-2.0: Up to eight hex chars.  */
       unicode_hex_count = 8;
+      FALLTHROUGH;
     case 'u':
 
       /* A Unicode escape.  We only permit them in strings and characters,
@@ -3278,11 +3280,11 @@ read1 (Lisp_Object readcharfun, int *pch, bool first_in_list)
            *pch = c;
            return Qnil;
          }
-
-       /* Otherwise, we fall through!  Note that the atom-reading loop
-          below will now loop at least once, assuring that we will not
-          try to UNREAD two characters in a row.  */
       }
+      /* The atom-reading loop below will now loop at least once,
+        assuring that we will not try to UNREAD two characters in a
+        row.  */
+      FALLTHROUGH;
     default:
     default_label:
       if (c <= 040) goto retry;
index 8e38a920cdb1615d8ca9c7018f1afd242fc8e39f..ed848902086294ba109d059edf0945c20e742c52 100644 (file)
@@ -2636,6 +2636,7 @@ regex_compile (const_re_char *pattern, size_t size,
          if ((syntax & RE_BK_PLUS_QM)
              || (syntax & RE_LIMITED_OPS))
            goto normal_char;
+         FALLTHROUGH;
        handle_plus:
        case '*':
          /* If there is no previous pattern...  */
@@ -3086,6 +3087,7 @@ regex_compile (const_re_char *pattern, size_t size,
                                   with non-0. */
                                if (regnum == 0)
                                  FREE_STACK_RETURN (REG_BADPAT);
+                               FALLTHROUGH;
                              case '1': case '2': case '3': case '4':
                              case '5': case '6': case '7': case '8': case '9':
                                regnum = 10*regnum + (c - '0'); break;
@@ -3905,8 +3907,7 @@ analyze_first (const_re_char *p, const_re_char *pend, char *fastmap,
                 j < (1 << BYTEWIDTH); j++)
              fastmap[j] = 1;
          }
-
-         /* Fallthrough */
+         FALLTHROUGH;
        case charset:
          if (!fastmap) break;
          not = (re_opcode_t) *(p - 1) == charset_not;
@@ -6182,8 +6183,7 @@ re_match_2_internal (struct re_pattern_buffer *bufp, const_re_char *string1,
            case on_failure_jump_nastyloop:
              assert ((re_opcode_t)pat[-2] == no_op);
              PUSH_FAILURE_POINT (pat - 2, str);
-             /* Fallthrough */
-
+             FALLTHROUGH;
            case on_failure_jump_loop:
            case on_failure_jump:
            case succeed_n:
index 1223cbf07cc1d922310755a21ed31edbbc83f65f..19e789dfa871390ba70502a95a56f0522d76f44e 100644 (file)
@@ -1804,6 +1804,7 @@ boyer_moore (EMACS_INT n, unsigned char *base_pat,
     {
       /* Setup translate_prev_byte1/2/3/4 from CHAR_BASE.  Only a
         byte following them are the target of translation.  */
+      eassume (0x80 <= char_base && char_base <= MAX_CHAR);
       unsigned char str[MAX_MULTIBYTE_LENGTH];
       int cblen = CHAR_STRING (char_base, str);
 
index 7aa43e6e5c77fbb954a0cb20392f9cec9670b876..dcaca22f0e2c04f22098411f003ae224bbd15961 100644 (file)
@@ -810,6 +810,7 @@ back_comment (ptrdiff_t from, ptrdiff_t from_byte, ptrdiff_t stop,
        case Sstring_fence:
        case Scomment_fence:
          c = (code == Sstring_fence ? ST_STRING_STYLE : ST_COMMENT_STYLE);
+         FALLTHROUGH;
        case Sstring:
          /* Track parity of quotes.  */
          if (string_style == -1)
@@ -2690,6 +2691,7 @@ scan_lists (EMACS_INT from, EMACS_INT count, EMACS_INT depth, bool sexpflag)
                goto lose;
              INC_BOTH (from, from_byte);
              /* Treat following character as a word constituent.  */
+             FALLTHROUGH;
            case Sword:
            case Ssymbol:
              if (depth || !sexpflag) break;
@@ -2721,7 +2723,7 @@ scan_lists (EMACS_INT from, EMACS_INT count, EMACS_INT depth, bool sexpflag)
 
            case Scomment_fence:
              comstyle = ST_COMMENT_STYLE;
-             /* FALLTHROUGH */
+             FALLTHROUGH;
            case Scomment:
              if (!parse_sexp_ignore_comments) break;
              UPDATE_SYNTAX_TABLE_FORWARD (from);
@@ -2753,7 +2755,7 @@ scan_lists (EMACS_INT from, EMACS_INT count, EMACS_INT depth, bool sexpflag)
                  goto close1;
                }
              mathexit = 1;
-
+             FALLTHROUGH;
            case Sopen:
              if (!++depth) goto done;
              break;
@@ -2909,7 +2911,7 @@ scan_lists (EMACS_INT from, EMACS_INT count, EMACS_INT depth, bool sexpflag)
                  goto open2;
                }
              mathexit = 1;
-
+             FALLTHROUGH;
            case Sclose:
              if (!++depth) goto done2;
              break;
index e9068830f85153fe656c096c0f7cea9aa8cd54b7..c8836b7ca78ba1005daa661f0d53448528a2c8d4 100644 (file)
@@ -2005,9 +2005,9 @@ x_draw_glyphless_glyph_string_foreground (struct glyph_string *s)
        }
       else if (glyph->u.glyphless.method == GLYPHLESS_DISPLAY_HEX_CODE)
        {
-         sprintf (buf, "%0*X",
-                  glyph->u.glyphless.ch < 0x10000 ? 4 : 6,
-                  glyph->u.glyphless.ch + 0u);
+         unsigned int ch = glyph->u.glyphless.ch;
+         eassume (ch <= MAX_CHAR);
+         sprintf (buf, "%0*X", ch < 0x10000 ? 4 : 6, ch);
          str = buf;
        }
 
@@ -8949,7 +8949,7 @@ handle_one_xevent (struct x_display_info *dpyinfo,
         {
         case MappingModifier:
           x_find_modifier_meanings (dpyinfo);
-          /* This is meant to fall through.  */
+         FALLTHROUGH;
         case MappingKeyboard:
           XRefreshKeyboardMapping ((XMappingEvent *) &event->xmapping);
         }