From f432a3234f9f2ee09bd40be03e06bf72865ee375 Mon Sep 17 00:00:00 2001 From: Stefan Krah Date: Mon, 21 Aug 2017 13:09:59 +0200 Subject: [PATCH] bpo-30923: Silence fall-through warnings included in -Wextra since gcc-7.0. (#3157) --- Modules/_ctypes/_ctypes.c | 2 +- Objects/call.c | 4 ++-- Objects/stringlib/codecs.h | 4 ++-- Objects/unicodeobject.c | 5 +++-- Python/ast.c | 3 +++ Python/ceval.c | 4 +++- Python/compile.c | 5 +++-- Python/dtoa.c | 8 ++++---- Python/formatter_unicode.c | 1 + Python/getargs.c | 2 +- Python/marshal.c | 3 +++ Python/pyhash.c | 12 ++++++------ Python/wordcode_helpers.h | 3 +++ 13 files changed, 35 insertions(+), 21 deletions(-) diff --git a/Modules/_ctypes/_ctypes.c b/Modules/_ctypes/_ctypes.c index 010658ebcd..0bcfc13ad0 100644 --- a/Modules/_ctypes/_ctypes.c +++ b/Modules/_ctypes/_ctypes.c @@ -3616,7 +3616,7 @@ _build_callargs(PyCFuncPtrObject *self, PyObject *argtypes, case (PARAMFLAG_FIN | PARAMFLAG_FOUT): *pinoutmask |= (1 << i); /* mark as inout arg */ (*pnumretvals)++; - /* fall through to PARAMFLAG_FIN... */ + /* fall through */ case 0: case PARAMFLAG_FIN: /* 'in' parameter. Copy it from inargs. */ diff --git a/Objects/call.c b/Objects/call.c index 3b08cb2592..4294a9beb0 100644 --- a/Objects/call.c +++ b/Objects/call.c @@ -499,7 +499,7 @@ _PyMethodDef_RawFastCallDict(PyMethodDef *method, PyObject *self, PyObject **arg if (kwargs != NULL && PyDict_GET_SIZE(kwargs) != 0) { goto no_keyword_error; } - /* fall through next case */ + /* fall through */ case METH_VARARGS | METH_KEYWORDS: { @@ -656,7 +656,7 @@ _PyMethodDef_RawFastCallKeywords(PyMethodDef *method, PyObject *self, PyObject * if (nkwargs) { goto no_keyword_error; } - /* fall through next case */ + /* fall through */ case METH_VARARGS | METH_KEYWORDS: { diff --git a/Objects/stringlib/codecs.h b/Objects/stringlib/codecs.h index 43f2f3266f..f019d9a96b 100644 --- a/Objects/stringlib/codecs.h +++ b/Objects/stringlib/codecs.h @@ -330,7 +330,7 @@ STRINGLIB(utf8_encoder)(PyObject *unicode, case _Py_ERROR_REPLACE: memset(p, '?', endpos - startpos); p += (endpos - startpos); - /* fall through the ignore handler */ + /* fall through */ case _Py_ERROR_IGNORE: i += (endpos - startpos - 1); break; @@ -378,7 +378,7 @@ STRINGLIB(utf8_encoder)(PyObject *unicode, } startpos = k; assert(startpos < endpos); - /* fall through the default handler */ + /* fall through */ default: rep = unicode_encode_call_errorhandler( errors, &error_handler_obj, "utf-8", "surrogates not allowed", diff --git a/Objects/unicodeobject.c b/Objects/unicodeobject.c index 0e6cb7f2a5..f7b2aa6c3d 100644 --- a/Objects/unicodeobject.c +++ b/Objects/unicodeobject.c @@ -1794,6 +1794,7 @@ unicode_dealloc(PyObject *unicode) case SSTATE_INTERNED_IMMORTAL: Py_FatalError("Immortal interned string died."); + /* fall through */ default: Py_FatalError("Inconsistent interned string state."); @@ -6778,7 +6779,7 @@ unicode_encode_ucs1(PyObject *unicode, case _Py_ERROR_REPLACE: memset(str, '?', collend - collstart); str += (collend - collstart); - /* fall through ignore error handler */ + /* fall through */ case _Py_ERROR_IGNORE: pos = collend; break; @@ -6817,7 +6818,7 @@ unicode_encode_ucs1(PyObject *unicode, break; collstart = pos; assert(collstart != collend); - /* fallback to general error handling */ + /* fall through */ default: rep = unicode_encode_call_errorhandler(errors, &error_handler_obj, diff --git a/Python/ast.c b/Python/ast.c index becf0addef..89206c3464 100644 --- a/Python/ast.c +++ b/Python/ast.c @@ -1182,6 +1182,7 @@ ast_for_comp_op(struct compiling *c, const node *n) return In; if (strcmp(STR(n), "is") == 0) return Is; + /* fall through */ default: PyErr_Format(PyExc_SystemError, "invalid comp_op: %s", STR(n)); @@ -1196,6 +1197,7 @@ ast_for_comp_op(struct compiling *c, const node *n) return NotIn; if (strcmp(STR(CHILD(n, 0)), "is") == 0) return IsNot; + /* fall through */ default: PyErr_Format(PyExc_SystemError, "invalid comp_op: %s %s", STR(CHILD(n, 0)), STR(CHILD(n, 1))); @@ -3147,6 +3149,7 @@ ast_for_flow_stmt(struct compiling *c, const node *n) } return Raise(expression, cause, LINENO(n), n->n_col_offset, c->c_arena); } + /* fall through */ default: PyErr_Format(PyExc_SystemError, "unexpected flow_stmt: %d", TYPE(ch)); diff --git a/Python/ceval.c b/Python/ceval.c index 9f732f56ba..92b1331135 100644 --- a/Python/ceval.c +++ b/Python/ceval.c @@ -1807,9 +1807,11 @@ _PyEval_EvalFrameDefault(PyFrameObject *f, int throwflag) switch (oparg) { case 2: cause = POP(); /* cause */ + /* fall through */ case 1: exc = POP(); /* exc */ - case 0: /* Fallthrough */ + /* fall through */ + case 0: if (do_raise(exc, cause)) { why = WHY_EXCEPTION; goto fast_block_end; diff --git a/Python/compile.c b/Python/compile.c index 280ddc39e3..78e797a2c3 100644 --- a/Python/compile.c +++ b/Python/compile.c @@ -4154,6 +4154,7 @@ expr_constant(struct compiler *c, expr_ty e) else if (o == Py_False) return 0; } + /* fall through */ default: return -1; } @@ -4446,13 +4447,13 @@ compiler_visit_expr(struct compiler *c, expr_ty e) switch (e->v.Attribute.ctx) { case AugLoad: ADDOP(c, DUP_TOP); - /* Fall through to load */ + /* Fall through */ case Load: ADDOP_NAME(c, LOAD_ATTR, e->v.Attribute.attr, names); break; case AugStore: ADDOP(c, ROT_TWO); - /* Fall through to save */ + /* Fall through */ case Store: ADDOP_NAME(c, STORE_ATTR, e->v.Attribute.attr, names); break; diff --git a/Python/dtoa.c b/Python/dtoa.c index efcadc31e9..01ca9b0b22 100644 --- a/Python/dtoa.c +++ b/Python/dtoa.c @@ -1454,7 +1454,7 @@ _Py_dg_strtod(const char *s00, char **se) switch (c) { case '-': sign = 1; - /* no break */ + /* fall through */ case '+': c = *++s; } @@ -1523,7 +1523,7 @@ _Py_dg_strtod(const char *s00, char **se) switch (c) { case '-': esign = 1; - /* no break */ + /* fall through */ case '+': c = *++s; } @@ -2441,7 +2441,7 @@ _Py_dg_dtoa(double dd, int mode, int ndigits, break; case 2: leftright = 0; - /* no break */ + /* fall through */ case 4: if (ndigits <= 0) ndigits = 1; @@ -2449,7 +2449,7 @@ _Py_dg_dtoa(double dd, int mode, int ndigits, break; case 3: leftright = 0; - /* no break */ + /* fall through */ case 5: i = ndigits + k + 1; ilim = i; diff --git a/Python/formatter_unicode.c b/Python/formatter_unicode.c index a2c2b3627c..9192bfd6a6 100644 --- a/Python/formatter_unicode.c +++ b/Python/formatter_unicode.c @@ -312,6 +312,7 @@ parse_internal_render_format_spec(PyObject *format_spec, format->thousands_separators = LT_UNDER_FOUR_LOCALE; break; } + /* fall through */ default: invalid_comma_type(format->type); return 0; diff --git a/Python/getargs.c b/Python/getargs.c index 471f72924f..4645b0f200 100644 --- a/Python/getargs.c +++ b/Python/getargs.c @@ -2304,8 +2304,8 @@ skipitem(const char **p_format, va_list *p_va, int flags) /* after 'e', only 's' and 't' is allowed */ goto err; format++; - /* explicit fallthrough to string cases */ } + /* fall through */ case 's': /* string */ case 'z': /* string or None */ diff --git a/Python/marshal.c b/Python/marshal.c index b2c00a0b6c..b6337e1450 100644 --- a/Python/marshal.c +++ b/Python/marshal.c @@ -1112,6 +1112,7 @@ r_object(RFILE *p) case TYPE_ASCII_INTERNED: is_interned = 1; + /* fall through */ case TYPE_ASCII: n = r_long(p); if (PyErr_Occurred()) @@ -1124,6 +1125,7 @@ r_object(RFILE *p) case TYPE_SHORT_ASCII_INTERNED: is_interned = 1; + /* fall through */ case TYPE_SHORT_ASCII: n = r_byte(p); if (n == EOF) { @@ -1149,6 +1151,7 @@ r_object(RFILE *p) case TYPE_INTERNED: is_interned = 1; + /* fall through */ case TYPE_UNICODE: { const char *buffer; diff --git a/Python/pyhash.c b/Python/pyhash.c index 57a2da715e..a2ec2309c7 100644 --- a/Python/pyhash.c +++ b/Python/pyhash.c @@ -393,13 +393,13 @@ siphash24(const void *src, Py_ssize_t src_sz) { pt = (uint8_t *)&t; m = (uint8_t *)in; switch (src_sz) { - case 7: pt[6] = m[6]; - case 6: pt[5] = m[5]; - case 5: pt[4] = m[4]; + case 7: pt[6] = m[6]; /* fall through */ + case 6: pt[5] = m[5]; /* fall through */ + case 5: pt[4] = m[4]; /* fall through */ case 4: memcpy(pt, m, sizeof(uint32_t)); break; - case 3: pt[2] = m[2]; - case 2: pt[1] = m[1]; - case 1: pt[0] = m[0]; + case 3: pt[2] = m[2]; /* fall through */ + case 2: pt[1] = m[1]; /* fall through */ + case 1: pt[0] = m[0]; /* fall through */ } b |= _le64toh(t); diff --git a/Python/wordcode_helpers.h b/Python/wordcode_helpers.h index b0e3a91776..cce81c1d24 100644 --- a/Python/wordcode_helpers.h +++ b/Python/wordcode_helpers.h @@ -28,10 +28,13 @@ write_op_arg(_Py_CODEUNIT *codestr, unsigned char opcode, switch (ilen) { case 4: *codestr++ = PACKOPARG(EXTENDED_ARG, (oparg >> 24) & 0xff); + /* fall through */ case 3: *codestr++ = PACKOPARG(EXTENDED_ARG, (oparg >> 16) & 0xff); + /* fall through */ case 2: *codestr++ = PACKOPARG(EXTENDED_ARG, (oparg >> 8) & 0xff); + /* fall through */ case 1: *codestr++ = PACKOPARG(opcode, oparg & 0xff); break; -- 2.40.0