aboutsummaryrefslogtreecommitdiffstats
path: root/gcc-4.9/gcc/testsuite/gfortran.dg/array_reference_1.f90
blob: 6de09919f17c41e59be442e47f36c08fc0723d6d (plain)
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
! { dg-do run }
! Tests the fix for PR31994, aka 31867, in which the offset
! of 'a' in both subroutines was being evaluated incorrectly.
! The testcase for PR31867 is char_length_5.f90
!
! Contributed by Elizabeth Yip <elizabeth.l.yip@boeing.com>
!            and Francois-Xavier Coudert <fxcoudert@gcc.gnu.org>
!
program main
  call PR31994
  call PR31994_comment6
contains
  subroutine PR31994
    implicit none
    complex (kind=4), dimension(2,2) :: a, b, c
    a(1,1) = (1.,1.)
    a(2,1) = (2.,2.)
    a(1,2) = (3.,3.)
    a(2,2) = (4.,4.)
    b=conjg (transpose (a))
    c=transpose (a)
    c=conjg (c)
    if (any (b .ne. c)) call abort ()
  end subroutine PR31994
  subroutine PR31994_comment6
    implicit none
    real ,dimension(2,2)::a
    integer ,dimension(2,2) :: b, c
    a = reshape ((/1.,2.,3.,4./), (/2,2/))
    b=int (transpose(a))
    c = int (a)
    c = transpose (c)
    if (any (b .ne. c)) call abort ()
  end subroutine PR31994_comment6
END program main