+2011-05-24 Paul Eggert <eggert@cs.ucla.edu>
+
+ intprops: shorten, to pacify gcc -Woverlength-strings
+ * lib/intprops.h (_GL_INT_CONVERT, _GL_INT_NEGATE_CONVERT):
+ (_GL_BINARY_OP_OVERFLOW): Say "0 * (x)" rather than "(x) - (x)",
+ so that, for example, verify (INT_MULTIPLY_OVERFLOW (...)) is less
+ likely to run afoul of C compiler limits for string constant lengths.
+ See <http://lists.gnu.org/archive/html/bug-gnulib/2011-05/msg00528.html>.
+
2011-05-24 Eric Blake <eblake@redhat.com>
docs: document recently fixed glibc printf bug
/* Return a integer value, converted to the same type as the integer
expression E after integer type promotion. V is the unconverted value.
E should not have side effects. */
-#define _GL_INT_CONVERT(e, v) ((e) - (e) + (v))
+#define _GL_INT_CONVERT(e, v) (0 * (e) + (v))
/* Act like _GL_INT_CONVERT (E, -V) but work around a bug in IRIX 6.5 cc; see
<http://lists.gnu.org/archive/html/bug-gnulib/2011-05/msg00406.html>. */
-#define _GL_INT_NEGATE_CONVERT(e, v) ((e) - (e) - (v))
+#define _GL_INT_NEGATE_CONVERT(e, v) (0 * (e) - (v))
/* The extra casts in the following macros work around compiler bugs,
e.g., in Cray C 5.0.3.0. */
Arguments should be free of side effects. */
#define _GL_BINARY_OP_OVERFLOW(a, b, op_result_overflow) \
op_result_overflow (a, b, \
- _GL_INT_MINIMUM ((b) - (b) + (a)), \
- _GL_INT_MAXIMUM ((b) - (b) + (a)))
+ _GL_INT_MINIMUM (0 * (b) + (a)), \
+ _GL_INT_MAXIMUM (0 * (b) + (a)))
#endif /* _GL_INTPROPS_H */