File: format-statement.f90

package info (click to toggle)
llvm-toolchain-19 1%3A19.1.7-3
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 1,998,520 kB
  • sloc: cpp: 6,951,680; ansic: 1,486,157; asm: 913,598; python: 232,024; f90: 80,126; objc: 75,281; lisp: 37,276; pascal: 16,990; sh: 10,009; ml: 5,058; perl: 4,724; awk: 3,523; makefile: 3,167; javascript: 2,504; xml: 892; fortran: 664; cs: 573
file content (65 lines) | stat: -rw-r--r-- 1,970 bytes parent folder | download | duplicates (11)
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
! RUN: bbc %s -o - | FileCheck %s

! CHECK-LABEL: func @_QPformatassign
subroutine formatAssign(flag1, flag2, flag3)
    real :: pi
    integer :: label
    logical :: flag1, flag2, flag3

    ! CHECK-DAG: %[[ONE:.*]] = arith.constant 100 : i32
    ! CHECK-DAG: %[[TWO:.*]] = arith.constant 200 : i32
    if (flag1) then
       assign 100 to label
    else
       assign 200 to label
    end if

    ! CHECK: cond_br %{{.*}}, ^bb[[BLK1:.*]], ^bb[[BLK2:.*]]
    ! CHECK: ^bb[[BLK1]]:
    ! CHECK: fir.store %[[ONE]]
    ! CHECK: br ^bb[[END_BLOCK:.*]]
    ! CHECK: ^bb[[BLK2]]:
    ! CHECK: fir.store %[[TWO]]
    ! CHECK: br ^bb[[END_BLOCK]]
    ! CHECK: ^bb[[END_BLOCK]]
    ! CHECK: fir.call @{{.*}}ReportFatalUserError
    ! CHECK: fir.unreachable
    ! CHECK: fir.call @{{.*}}BeginExternalFormattedOutput
    ! CHECK: fir.call @{{.*}}OutputAscii
    ! CHECK: fir.call @{{.*}}OutputReal32
    ! CHECK: fir.call @{{.*}}EndIoStatement
    pi = 3.141592653589
    write(*, label) " PI=", pi
    ! CHECK: fir.call @{{.*}}ReportFatalUserError
    ! CHECK: fir.unreachable
    ! CHECK: fir.call @{{.*}}BeginExternalFormattedOutput
    ! CHECK: fir.call @{{.*}}OutputAscii
    ! CHECK: fir.call @{{.*}}OutputReal32
    ! CHECK: fir.call @{{.*}}EndIoStatement
    if (flag2) write(*, label) "2PI=", 2*pi
    if (flag1 .and. flag2 .and. flag3) then
       assign 100 to label
    else
       assign 200 to label
    end if
    if (flag3) then
      ! CHECK: fir.call @{{.*}}ReportFatalUserError
      ! CHECK: fir.unreachable
      ! CHECK: fir.call @{{.*}}BeginExternalFormattedOutput
      ! CHECK: fir.call @{{.*}}OutputAscii
      ! CHECK: fir.call @{{.*}}OutputReal32
      ! CHECK: fir.call @{{.*}}EndIoStatement
      write(*, label) "3PI=", 3*pi
    endif

100 format (A, F10.3)
200 format (A,E8.1)
300 format (A, E4.2)

end subroutine

! CHECK-LABEL: func @_QQmain
  call formatAssign(.true., .true., .true.)
  print*
  call formatAssign(.true., .false., .true.)
end