annotate gcc/testsuite/gfortran.dg/goto_2.f90 @ 132:d34655255c78

update gcc-8.2
author mir3636
date Thu, 25 Oct 2018 10:21:07 +0900
parents 84e7813d76e9
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 ! { dg-do run }
kono
parents:
diff changeset
2 ! Checks for corrects warnings if branching to then end of a
kono
parents:
diff changeset
3 ! construct at various nesting levels
kono
parents:
diff changeset
4 subroutine check_if(i)
kono
parents:
diff changeset
5 goto 10 ! { dg-warning "Label at ... is not in the same block" }
kono
parents:
diff changeset
6 if (i > 0) goto 40
kono
parents:
diff changeset
7 if (i < 0) then
kono
parents:
diff changeset
8 goto 40
kono
parents:
diff changeset
9 10 end if ! { dg-warning "Label at ... is not in the same block" }
kono
parents:
diff changeset
10 if (i == 0) then
kono
parents:
diff changeset
11 i = i+1
kono
parents:
diff changeset
12 goto 20
kono
parents:
diff changeset
13 goto 40
kono
parents:
diff changeset
14 20 end if
kono
parents:
diff changeset
15 if (i == 1) then
kono
parents:
diff changeset
16 i = i+1
kono
parents:
diff changeset
17 if (i == 2) then
kono
parents:
diff changeset
18 goto 30
kono
parents:
diff changeset
19 end if
kono
parents:
diff changeset
20 goto 40
kono
parents:
diff changeset
21 30 end if
kono
parents:
diff changeset
22 return
kono
parents:
diff changeset
23 40 i = -1
kono
parents:
diff changeset
24 end subroutine check_if
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 subroutine check_select(i)
kono
parents:
diff changeset
27 goto 10 ! { dg-warning "Label at ... is not in the same block" }
kono
parents:
diff changeset
28 select case (i)
kono
parents:
diff changeset
29 case default
kono
parents:
diff changeset
30 goto 999
kono
parents:
diff changeset
31 10 end select ! { dg-warning "Label at ... is not in the same block" }
kono
parents:
diff changeset
32 select case (i)
kono
parents:
diff changeset
33 case (2)
kono
parents:
diff changeset
34 i = 1
kono
parents:
diff changeset
35 goto 20
kono
parents:
diff changeset
36 goto 999
kono
parents:
diff changeset
37 case default
kono
parents:
diff changeset
38 goto 999
kono
parents:
diff changeset
39 20 end select
kono
parents:
diff changeset
40 j = i
kono
parents:
diff changeset
41 select case (j)
kono
parents:
diff changeset
42 case default
kono
parents:
diff changeset
43 select case (i)
kono
parents:
diff changeset
44 case (1)
kono
parents:
diff changeset
45 i = 2
kono
parents:
diff changeset
46 goto 30
kono
parents:
diff changeset
47 end select
kono
parents:
diff changeset
48 goto 999
kono
parents:
diff changeset
49 30 end select
kono
parents:
diff changeset
50 return
kono
parents:
diff changeset
51 999 i = -1
kono
parents:
diff changeset
52 end subroutine check_select
kono
parents:
diff changeset
53
kono
parents:
diff changeset
54 i = 0
kono
parents:
diff changeset
55 call check_if (i)
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
56 if (i /= 2) STOP 1
111
kono
parents:
diff changeset
57 call check_select (i)
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
58 if (i /= 2) STOP 2
111
kono
parents:
diff changeset
59 end