1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
|
/* Test C23 Checked Integer Arithmetic macros in <stdckdint.h>. */
/* { dg-do compile } */
/* { dg-options "-std=c23" } */
#include <stdckdint.h>
int
main ()
{
char a;
bool b;
enum E { E1, E2 } c = E1;
int d;
int *e;
float f;
double g;
long double h;
const int v = 42;
volatile const short w = 5;
ckd_add (&a, 1, 1);
ckd_sub (&a, 1, 1);
ckd_mul (&a, 1, 1);
ckd_add (&b, 1, 1); /* { dg-error "has pointer to boolean type" } */
ckd_sub (&b, 1, 1); /* { dg-error "has pointer to boolean type" } */
ckd_mul (&b, 1, 1); /* { dg-error "has pointer to boolean type" } */
ckd_add (&c, 1, 1); /* { dg-error "has pointer to enumerated type" } */
ckd_sub (&c, 1, 1); /* { dg-error "has pointer to enumerated type" } */
ckd_mul (&c, 1, 1); /* { dg-error "has pointer to enumerated type" } */
ckd_add (&d, (char) 1, 1);
ckd_sub (&d, (char) 1, 1);
ckd_mul (&d, (char) 1, 1);
ckd_add (&d, false, 1);
ckd_sub (&d, false, 1);
ckd_mul (&d, false, 1);
ckd_add (&d, true, 1);
ckd_sub (&d, true, 1);
ckd_mul (&d, true, 1);
ckd_add (&d, c, 1);
ckd_sub (&d, c, 1);
ckd_mul (&d, c, 1);
ckd_add (&d, 1, (char) 1);
ckd_sub (&d, 1, (char) 1);
ckd_mul (&d, 1, (char) 1);
ckd_add (&d, 1, false);
ckd_sub (&d, 1, false);
ckd_mul (&d, 1, false);
ckd_add (&d, 1, true);
ckd_sub (&d, 1, true);
ckd_mul (&d, 1, true);
ckd_add (&d, 1, c);
ckd_sub (&d, 1, c);
ckd_mul (&d, 1, c);
ckd_add (&e, 1, 1); /* { dg-error "does not have pointer to integral type" } */
ckd_sub (&e, 1, 1); /* { dg-error "does not have pointer to integral type" } */
ckd_mul (&e, 1, 1); /* { dg-error "does not have pointer to integral type" } */
ckd_add (&f, 1, 1); /* { dg-error "does not have pointer to integral type" } */
ckd_sub (&f, 1, 1); /* { dg-error "does not have pointer to integral type" } */
ckd_mul (&f, 1, 1); /* { dg-error "does not have pointer to integral type" } */
ckd_add (&g, 1, 1); /* { dg-error "does not have pointer to integral type" } */
ckd_sub (&g, 1, 1); /* { dg-error "does not have pointer to integral type" } */
ckd_mul (&g, 1, 1); /* { dg-error "does not have pointer to integral type" } */
ckd_add (&h, 1, 1); /* { dg-error "does not have pointer to integral type" } */
ckd_sub (&h, 1, 1); /* { dg-error "does not have pointer to integral type" } */
ckd_mul (&h, 1, 1); /* { dg-error "does not have pointer to integral type" } */
ckd_add (&d, 1.0f, 1); /* { dg-error "does not have integral type" } */
ckd_sub (&d, 1.0f, 1); /* { dg-error "does not have integral type" } */
ckd_mul (&d, 1.0f, 1); /* { dg-error "does not have integral type" } */
ckd_add (&d, 1.0, 1); /* { dg-error "does not have integral type" } */
ckd_sub (&d, 1.0, 1); /* { dg-error "does not have integral type" } */
ckd_mul (&d, 1.0, 1); /* { dg-error "does not have integral type" } */
ckd_add (&d, 1.0L, 1); /* { dg-error "does not have integral type" } */
ckd_sub (&d, 1.0L, 1); /* { dg-error "does not have integral type" } */
ckd_mul (&d, 1.0L, 1); /* { dg-error "does not have integral type" } */
ckd_add (&d, 1, 1.0f); /* { dg-error "does not have integral type" } */
ckd_sub (&d, 1, 1.0f); /* { dg-error "does not have integral type" } */
ckd_mul (&d, 1, 1.0f); /* { dg-error "does not have integral type" } */
ckd_add (&d, 1, 1.0); /* { dg-error "does not have integral type" } */
ckd_sub (&d, 1, 1.0); /* { dg-error "does not have integral type" } */
ckd_mul (&d, 1, 1.0); /* { dg-error "does not have integral type" } */
ckd_add (&d, 1, 1.0L); /* { dg-error "does not have integral type" } */
ckd_sub (&d, 1, 1.0L); /* { dg-error "does not have integral type" } */
ckd_mul (&d, 1, 1.0L); /* { dg-error "does not have integral type" } */
ckd_add (&d, (int *) 0, 1); /* { dg-error "does not have integral type" } */
ckd_sub (&d, (int *) 0, 1); /* { dg-error "does not have integral type" } */
ckd_mul (&d, (int *) 0, 1); /* { dg-error "does not have integral type" } */
ckd_add (&d, 1, (int *) 0); /* { dg-error "does not have integral type" } */
ckd_sub (&d, 1, (int *) 0); /* { dg-error "does not have integral type" } */
ckd_mul (&d, 1, (int *) 0); /* { dg-error "does not have integral type" } */
ckd_add (&v, 1, 1); /* { dg-error "has pointer to 'const' type" } */
ckd_sub (&v, 1, 1); /* { dg-error "has pointer to 'const' type" } */
ckd_mul (&v, 1, 1); /* { dg-error "has pointer to 'const' type" } */
ckd_add (&w, 1, 1); /* { dg-error "has pointer to 'const' type" } */
ckd_sub (&w, 1, 1); /* { dg-error "has pointer to 'const' type" } */
ckd_mul (&w, 1, 1); /* { dg-error "has pointer to 'const' type" } */
}
|