1! Program to test the initialisation range of enumerators
2! and kind values check
3
4program main
5  implicit none
6
7  enum, bind (c)
8    enumerator :: red , yellow =255 , blue
9  end enum
10
11  enum, bind (c)
12    enumerator :: r , y = 32767, b
13  end enum
14
15  enum, bind (c)
16    enumerator :: aa , bb = 65535, cc
17  end enum
18
19  enum, bind (c)
20    enumerator :: m , n = 2147483645, o
21  end enum
22
23
24 if (red /= 0 ) STOP 1
25 if (yellow /= 255) STOP 2
26 if (blue /= 256) STOP 3
27
28 if (r /= 0 ) STOP 4
29 if (y /= 32767) STOP 5
30 if (b /= 32768) STOP 6
31
32 if (kind (red) /= 4) STOP 7
33 if (kind (yellow) /= 4) STOP 8
34 if (kind (blue) /= 4) STOP 9
35
36 if (kind(r) /= 4 ) STOP 10
37 if (kind(y) /= 4) STOP 11
38 if (kind(b) /= 4) STOP 12
39
40 if (aa /= 0 ) STOP 13
41 if (bb /= 65535) STOP 14
42 if (cc /= 65536) STOP 15
43
44 if (kind (aa) /= 4 ) STOP 16
45 if (kind (bb) /= 4) STOP 17
46 if (kind (cc) /= 4) STOP 18
47
48
49 if (m /= 0 ) STOP 19
50 if (n /= 2147483645) STOP 20
51 if (o /= 2147483646) STOP 21
52
53 if (kind (m) /= 4 ) STOP 22
54 if (kind (n) /= 4) STOP 23
55 if (kind (o) /= 4) STOP 24
56
57end program main
58