summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/implied_do_io_4.f90
blob: 4b484d7d5000579c72e92ab6a12a384dc88eb05e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
! { dg-do  run }
! { dg-additional-options "-ffrontend-optimize -fdump-tree-original" }
! PR fortran/35339  - make sure that I/O of an implied DO loop
! of allocatable character arrays a) works and b) is converted
! to a transfer_array
program main
    implicit none
    integer:: i
    integer, parameter:: N = 10
    character(len=:), dimension(:),allocatable:: ca
    allocate(character(len=N):: ca(3))
    open(unit=10,status="scratch")
    ca(1) = "foo"
    ca(2) = "bar"
    ca(3) = "xyzzy"
    write (10, '(3A10)') (ca(i),i=1,3)
    rewind (10)
    ca(:) = ''
    read (10, '(3A10)') (ca(i),i=1,3)
    if (ca(1) /= 'foo' .or. ca(2) /= 'bar' .or. ca(3) /= 'xyzzy') call abort
end program
! { dg-final { scan-tree-dump-times "_gfortran_transfer_array" 2 "original" } }