diff --git a/src/kernel_internals/typing/cabs2cil.ml b/src/kernel_internals/typing/cabs2cil.ml index 4317af5b04cbe11e8f1e95f0b8557a28c842efb5..e0712af22e910eb4864f65eefce54e66b916c397 100644 --- a/src/kernel_internals/typing/cabs2cil.ml +++ b/src/kernel_internals/typing/cabs2cil.ml @@ -1443,7 +1443,7 @@ let rec isCabsZeroExp e = match e.expr_node with | SINGLE_INIT e -> isCabsZeroExp e | NO_INIT | COMPOUND_INIT _ -> false) | CONSTANT (CONST_INT i) -> - Integer.is_zero (Cil.parseInt i) + Option.fold ~none:false ~some:Integer.is_zero (Cil.parseInt_opt i) | _ -> false module BlockChunk = diff --git a/tests/syntax/oracle/very_large_integers.0.res.oracle b/tests/syntax/oracle/very_large_integers.0.res.oracle index 64ae83250fee7836a6a4c7702d1a64e0a85f35c8..db573af932d7288a94e547a1e729ad2581a7c585 100644 --- a/tests/syntax/oracle/very_large_integers.0.res.oracle +++ b/tests/syntax/oracle/very_large_integers.0.res.oracle @@ -1,11 +1,11 @@ [kernel] Parsing tests/syntax/very_large_integers.c (with preprocessing) -[kernel] tests/syntax/very_large_integers.c:21: User Error: - integer constant too large in expression (unsigned long long)999999999999999999 + 9999999999999999999 [kernel] tests/syntax/very_large_integers.c:22: User Error: + integer constant too large in expression (unsigned long long)999999999999999999 + 9999999999999999999 +[kernel] tests/syntax/very_large_integers.c:23: User Error: bitfield width is not a valid integer constant -[kernel] tests/syntax/very_large_integers.c:57: Warning: +[kernel] tests/syntax/very_large_integers.c:58: Warning: ignoring invalid aligned attribute: __aligned__(9223372036854775808) -[kernel] tests/syntax/very_large_integers.c:57: Warning: +[kernel] tests/syntax/very_large_integers.c:58: Warning: ignoring invalid aligned attribute: __aligned__((9223372036854775808)+ (9223372036854775808) ) [kernel] User Error: stopping on file "tests/syntax/very_large_integers.c" that has errors. Add diff --git a/tests/syntax/oracle/very_large_integers.1.res.oracle b/tests/syntax/oracle/very_large_integers.1.res.oracle index 4c65204b2faa18b302bd50ba561aa4192227fcfe..23cfa866c0b1679b16c8da7e786139aeb6c49151 100644 --- a/tests/syntax/oracle/very_large_integers.1.res.oracle +++ b/tests/syntax/oracle/very_large_integers.1.res.oracle @@ -1,11 +1,11 @@ [kernel] Parsing tests/syntax/very_large_integers.c (with preprocessing) -[kernel] tests/syntax/very_large_integers.c:28: User Error: +[kernel] tests/syntax/very_large_integers.c:29: User Error: Cannot represent the integer 99999999999999999999U -[kernel] tests/syntax/very_large_integers.c:28: User Error: +[kernel] tests/syntax/very_large_integers.c:29: User Error: Cannot represent the integer 99999999999999999999U -[kernel] tests/syntax/very_large_integers.c:57: Warning: +[kernel] tests/syntax/very_large_integers.c:58: Warning: ignoring invalid aligned attribute: __aligned__(9223372036854775808) -[kernel] tests/syntax/very_large_integers.c:57: Warning: +[kernel] tests/syntax/very_large_integers.c:58: Warning: ignoring invalid aligned attribute: __aligned__((9223372036854775808)+ (9223372036854775808) ) [kernel] User Error: stopping on file "tests/syntax/very_large_integers.c" that has errors. Add diff --git a/tests/syntax/oracle/very_large_integers.10.res.oracle b/tests/syntax/oracle/very_large_integers.10.res.oracle index a1176c2d521a2b0a257355922262475a6377318f..4f848474e09b65819663cd76d18d5f514f53c968 100644 --- a/tests/syntax/oracle/very_large_integers.10.res.oracle +++ b/tests/syntax/oracle/very_large_integers.10.res.oracle @@ -1,22 +1,11 @@ [kernel] Parsing tests/syntax/very_large_integers.c (with preprocessing) -[kernel] tests/syntax/very_large_integers.c:57: Warning: +[kernel] tests/syntax/very_large_integers.c:58: Warning: ignoring invalid aligned attribute: __aligned__(9223372036854775808) -[kernel] tests/syntax/very_large_integers.c:57: Warning: +[kernel] tests/syntax/very_large_integers.c:58: Warning: ignoring invalid aligned attribute: __aligned__((9223372036854775808)+ (9223372036854775808) ) -[kernel] tests/syntax/very_large_integers.c:85: Warning: - ignoring unrolling directive (not an understood constant expression) -/* Generated by Frama-C */ -int volatile nondet; -/*@ logic ℤ too_large_integer= 9999999999999999999; - */ -int main(void) -{ - int __retres; - /*@ loop pragma UNROLL 99999999999999999999; */ - while (nondet) ; - __retres = 0; - return __retres; -} - - +[kernel] tests/syntax/very_large_integers.c:84: User Error: + Invalid digit 9 in integer literal '09' in base 8. +[kernel] User Error: stopping on file "tests/syntax/very_large_integers.c" that has errors. Add + '-kernel-msg-key pp' for preprocessing command. +[kernel] Frama-C aborted: invalid user input. diff --git a/tests/syntax/oracle/very_large_integers.11.res.oracle b/tests/syntax/oracle/very_large_integers.11.res.oracle new file mode 100644 index 0000000000000000000000000000000000000000..c352a476c8d0b1515924c1ac46c2014c9c8c1d55 --- /dev/null +++ b/tests/syntax/oracle/very_large_integers.11.res.oracle @@ -0,0 +1,22 @@ +[kernel] Parsing tests/syntax/very_large_integers.c (with preprocessing) +[kernel] tests/syntax/very_large_integers.c:58: Warning: + ignoring invalid aligned attribute: __aligned__(9223372036854775808) +[kernel] tests/syntax/very_large_integers.c:58: Warning: + ignoring invalid aligned attribute: __aligned__((9223372036854775808)+ + (9223372036854775808) ) +[kernel] tests/syntax/very_large_integers.c:89: Warning: + ignoring unrolling directive (not an understood constant expression) +/* Generated by Frama-C */ +int volatile nondet; +/*@ logic ℤ too_large_integer= 9999999999999999999; + */ +int main(void) +{ + int __retres; + /*@ loop pragma UNROLL 99999999999999999999; */ + while (nondet) ; + __retres = 0; + return __retres; +} + + diff --git a/tests/syntax/oracle/very_large_integers.2.res.oracle b/tests/syntax/oracle/very_large_integers.2.res.oracle index 2c763bf0674a6ffdacdab5d440e40387fc57f8d4..bb5f47fe756242bc9ba320bc6435621eb289b4e1 100644 --- a/tests/syntax/oracle/very_large_integers.2.res.oracle +++ b/tests/syntax/oracle/very_large_integers.2.res.oracle @@ -1,7 +1,7 @@ [kernel] Parsing tests/syntax/very_large_integers.c (with preprocessing) -[kernel] tests/syntax/very_large_integers.c:35: User Error: +[kernel] tests/syntax/very_large_integers.c:36: User Error: integer constant too large in expression 9999999999999999999U -[kernel] tests/syntax/very_large_integers.c:35: Failure: +[kernel] tests/syntax/very_large_integers.c:36: Failure: Cannot understand the constants in case range [kernel] User Error: stopping on file "tests/syntax/very_large_integers.c" that has errors. Add '-kernel-msg-key pp' for preprocessing command. diff --git a/tests/syntax/oracle/very_large_integers.3.res.oracle b/tests/syntax/oracle/very_large_integers.3.res.oracle index ac927237baf7cd2545380697b69b2d9851652cb9..ad9de534b05aef91ec8a722ad0b193c72ef89375 100644 --- a/tests/syntax/oracle/very_large_integers.3.res.oracle +++ b/tests/syntax/oracle/very_large_integers.3.res.oracle @@ -1,5 +1,5 @@ [kernel] Parsing tests/syntax/very_large_integers.c (with preprocessing) -[kernel] tests/syntax/very_large_integers.c:40: Failure: +[kernel] tests/syntax/very_large_integers.c:41: Failure: Array length 9999999999999999999U is not a compile-time constant: no explicit initializer allowed. [kernel] User Error: stopping on file "tests/syntax/very_large_integers.c" that has errors. Add '-kernel-msg-key pp' for preprocessing command. diff --git a/tests/syntax/oracle/very_large_integers.4.res.oracle b/tests/syntax/oracle/very_large_integers.4.res.oracle index 403d2a65c2fd6968e35a53798b038a69496b277a..0d8599e32958e49f9a178eaa551bc2692388d0cb 100644 --- a/tests/syntax/oracle/very_large_integers.4.res.oracle +++ b/tests/syntax/oracle/very_large_integers.4.res.oracle @@ -1,12 +1,12 @@ [kernel] Parsing tests/syntax/very_large_integers.c (with preprocessing) -[kernel] tests/syntax/very_large_integers.c:44: User Error: +[kernel] tests/syntax/very_large_integers.c:45: User Error: INDEX initialization designator overflows - 42 - 43 #ifdef INIT_DESIGNATOR2 - 44 int arr3[1] = { [9999999999999999999U] = 42 }; + 43 + 44 #ifdef INIT_DESIGNATOR2 + 45 int arr3[1] = { [9999999999999999999U] = 42 }; ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ - 45 #endif - 46 + 46 #endif + 47 [kernel] User Error: stopping on file "tests/syntax/very_large_integers.c" that has errors. Add '-kernel-msg-key pp' for preprocessing command. [kernel] Frama-C aborted: invalid user input. diff --git a/tests/syntax/oracle/very_large_integers.5.res.oracle b/tests/syntax/oracle/very_large_integers.5.res.oracle index 46e43a1bedb0f44f1df6c29b995ed20d738f5336..1798bfe46e3610238348f88b53f77a757bb82440 100644 --- a/tests/syntax/oracle/very_large_integers.5.res.oracle +++ b/tests/syntax/oracle/very_large_integers.5.res.oracle @@ -1,9 +1,9 @@ [kernel] Parsing tests/syntax/very_large_integers.c (with preprocessing) -[kernel] tests/syntax/very_large_integers.c:48: User Error: +[kernel] tests/syntax/very_large_integers.c:49: User Error: integer constant too large in expression -9999999999999999999U -[kernel] tests/syntax/very_large_integers.c:48: User Error: +[kernel] tests/syntax/very_large_integers.c:49: User Error: integer constant too large in expression 9999999999999999999U -[kernel] tests/syntax/very_large_integers.c:48: Failure: +[kernel] tests/syntax/very_large_integers.c:49: Failure: INDEX_RANGE initialization designator is not a valid constant [kernel] User Error: stopping on file "tests/syntax/very_large_integers.c" that has errors. Add '-kernel-msg-key pp' for preprocessing command. diff --git a/tests/syntax/oracle/very_large_integers.6.res.oracle b/tests/syntax/oracle/very_large_integers.6.res.oracle index 45af4ca20329ffc5985135901f421f33a18a7840..c531dfb15a1f18822fb312d21c18796860aae437 100644 --- a/tests/syntax/oracle/very_large_integers.6.res.oracle +++ b/tests/syntax/oracle/very_large_integers.6.res.oracle @@ -1,9 +1,9 @@ [kernel] Parsing tests/syntax/very_large_integers.c (with preprocessing) -[kernel] tests/syntax/very_large_integers.c:52: User Error: +[kernel] tests/syntax/very_large_integers.c:53: User Error: Invalid attribute constant: 0x80000000000000000 -[kernel] tests/syntax/very_large_integers.c:57: Warning: +[kernel] tests/syntax/very_large_integers.c:58: Warning: ignoring invalid aligned attribute: __aligned__(9223372036854775808) -[kernel] tests/syntax/very_large_integers.c:57: Warning: +[kernel] tests/syntax/very_large_integers.c:58: Warning: ignoring invalid aligned attribute: __aligned__((9223372036854775808)+ (9223372036854775808) ) [kernel] User Error: stopping on file "tests/syntax/very_large_integers.c" that has errors. Add diff --git a/tests/syntax/oracle/very_large_integers.7.res.oracle b/tests/syntax/oracle/very_large_integers.7.res.oracle index e34bb47c39d686dfebced25abf93180bbe7fdad9..75dbebc66e69abf8a3bedb63843d538f6957ce7c 100644 --- a/tests/syntax/oracle/very_large_integers.7.res.oracle +++ b/tests/syntax/oracle/very_large_integers.7.res.oracle @@ -1,7 +1,7 @@ [kernel] Parsing tests/syntax/very_large_integers.c (with preprocessing) -[kernel] tests/syntax/very_large_integers.c:57: Warning: +[kernel] tests/syntax/very_large_integers.c:58: Warning: ignoring invalid aligned attribute: __aligned__(9223372036854775808) -[kernel] tests/syntax/very_large_integers.c:57: Warning: +[kernel] tests/syntax/very_large_integers.c:58: Warning: ignoring invalid aligned attribute: __aligned__((9223372036854775808)+ (9223372036854775808) ) [kernel] Failure: Cannot represent logical integer in C: 9999999999999999999 diff --git a/tests/syntax/oracle/very_large_integers.8.res.oracle b/tests/syntax/oracle/very_large_integers.8.res.oracle index 0f63c2ee5d2cbc3743a4b735455ceee727102006..a0898661e147feeff6bc975032c9c15c8f0f9fd0 100644 --- a/tests/syntax/oracle/very_large_integers.8.res.oracle +++ b/tests/syntax/oracle/very_large_integers.8.res.oracle @@ -1,10 +1,10 @@ [kernel] Parsing tests/syntax/very_large_integers.c (with preprocessing) -[kernel] tests/syntax/very_large_integers.c:57: Warning: +[kernel] tests/syntax/very_large_integers.c:58: Warning: ignoring invalid aligned attribute: __aligned__(9223372036854775808) -[kernel] tests/syntax/very_large_integers.c:57: Warning: +[kernel] tests/syntax/very_large_integers.c:58: Warning: ignoring invalid aligned attribute: __aligned__((9223372036854775808)+ (9223372036854775808) ) -[kernel] tests/syntax/very_large_integers.c:70: Failure: +[kernel] tests/syntax/very_large_integers.c:71: Failure: Invalid digit 9 in integer literal '09876543210' in base 8. [kernel] User Error: stopping on file "tests/syntax/very_large_integers.c" that has errors. Add '-kernel-msg-key pp' for preprocessing command. diff --git a/tests/syntax/oracle/very_large_integers.9.res.oracle b/tests/syntax/oracle/very_large_integers.9.res.oracle index 95d122b7737555edb536980e820d1f4672e217e2..9ed0fe33d85bcd2a4c2cbca98f244296c17a65c1 100644 --- a/tests/syntax/oracle/very_large_integers.9.res.oracle +++ b/tests/syntax/oracle/very_large_integers.9.res.oracle @@ -1,10 +1,10 @@ [kernel] Parsing tests/syntax/very_large_integers.c (with preprocessing) -[kernel] tests/syntax/very_large_integers.c:57: Warning: +[kernel] tests/syntax/very_large_integers.c:58: Warning: ignoring invalid aligned attribute: __aligned__(9223372036854775808) -[kernel] tests/syntax/very_large_integers.c:57: Warning: +[kernel] tests/syntax/very_large_integers.c:58: Warning: ignoring invalid aligned attribute: __aligned__((9223372036854775808)+ (9223372036854775808) ) -[kernel:annot-error] tests/syntax/very_large_integers.c:79: Warning: +[kernel:annot-error] tests/syntax/very_large_integers.c:80: Warning: Invalid slevel directive. Ignoring code annotation [kernel] User Error: warning annot-error treated as fatal error. [kernel] User Error: stopping on file "tests/syntax/very_large_integers.c" that has errors. Add diff --git a/tests/syntax/very_large_integers.c b/tests/syntax/very_large_integers.c index 48dff8b8376d5f74f2bd3698b2994a1420901286..80e80299c6dc82f3f76654a45efd9e587e1e307a 100644 --- a/tests/syntax/very_large_integers.c +++ b/tests/syntax/very_large_integers.c @@ -11,6 +11,7 @@ STDOPT: #"-cpp-extra-args=-DLOGIC_CONSTANT" STDOPT: #"-cpp-extra-args=-DLOGIC_CONSTANT_OCTAL" STDOPT: #"-cpp-extra-args=-DEVA_UNROLL -eva" + STDOPT: #"-cpp-extra-args=-DCABS_DOWHILE" EXIT: 0 STDOPT: #"-cpp-extra-args=-DUNROLL_PRAGMA" */ @@ -79,6 +80,9 @@ int main() { //@ slevel 9999999999999999999; while (nondet); #endif +#ifdef CABS_DOWHILE + do { } while (09); +#endif #ifdef UNROLL_PRAGMA //@ loop pragma UNROLL 99999999999999999999; #endif