mirror of
https://github.com/Mercury-Language/mercury.git
synced 2026-04-22 04:43:53 +00:00
C does not have negative integer constants so "(MR_Integer) -nnnn" is the negation of a positive integer constant nnnn, converted to MR_Integer. In C89/C90 an unsuffixed decimal integer constant must be typed `int' or `long int' or `unsigned long int', whichever fits first. The negated result will have the same type. If nnnn > LONG_MAX then it will be typed `unsigned long int'. If MR_Integer is wider than `unsigned long int' then the conversion to MR_Integer yields a positive value, not negative. The solution here is essentially to write "-(MR_Integer) nnnn" so the integer constant is converted to a signed MR_Integer before negation. After this fix we no longer get these warnings from gcc: "this decimal constant is unsigned only in ISO C90". It turns out gcc was trying to tell us something. compiler/c_util.m: Add predicate `output_int_expr' to write ints in a way that avoids the problem. compiler/llds_out_data.m: compiler/mlds_to_c.m: Use `output_int_expr' to write ints. tests/hard_coded/Mmakefile: tests/hard_coded/c89_neg_int.exp: tests/hard_coded/c89_neg_int.m: Add test case.
3 lines
24 B
Plaintext
3 lines
24 B
Plaintext
-2147483647
|
|
-2147483648
|