diff options
author | upstream source tree <ports@midipix.org> | 2015-03-15 20:14:05 -0400 |
---|---|---|
committer | upstream source tree <ports@midipix.org> | 2015-03-15 20:14:05 -0400 |
commit | 554fd8c5195424bdbcabf5de30fdc183aba391bd (patch) | |
tree | 976dc5ab7fddf506dadce60ae936f43f58787092 /gcc/testsuite/gfortran.dg/intrinsics_kind_argument_1.f90 | |
download | cbb-gcc-4.6.4-554fd8c5195424bdbcabf5de30fdc183aba391bd.tar.bz2 cbb-gcc-4.6.4-554fd8c5195424bdbcabf5de30fdc183aba391bd.tar.xz |
obtained gcc-4.6.4.tar.bz2 from upstream website;upstream
verified gcc-4.6.4.tar.bz2.sig;
imported gcc-4.6.4 source tree from verified upstream tarball.
downloading a git-generated archive based on the 'upstream' tag
should provide you with a source tree that is binary identical
to the one extracted from the above tarball.
if you have obtained the source via the command 'git clone',
however, do note that line-endings of files in your working
directory might differ from line-endings of the respective
files in the upstream repository.
Diffstat (limited to 'gcc/testsuite/gfortran.dg/intrinsics_kind_argument_1.f90')
-rw-r--r-- | gcc/testsuite/gfortran.dg/intrinsics_kind_argument_1.f90 | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/gcc/testsuite/gfortran.dg/intrinsics_kind_argument_1.f90 b/gcc/testsuite/gfortran.dg/intrinsics_kind_argument_1.f90 new file mode 100644 index 000000000..0a3ca0791 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/intrinsics_kind_argument_1.f90 @@ -0,0 +1,56 @@ +! Test various intrinsics who take a kind argument since Fortran 2003 +! +! { dg-do compile } +! +program test + integer, parameter :: k = kind(0) + logical :: l_array(4,5) + character(len=1) :: s + character(len=20) :: t + + l_array = .true. + s = "u" + t = "bartutugee" + + call check (count(l_array, kind=k), 20) + if (any (count(l_array, 2, kind=k) /= 5)) call abort + if (any (count(l_array, kind=k, dim=2) /= 5)) call abort + + call check (iachar (s, k), 117) + call check (iachar (s, kind=k), 117) + call check (ichar (s, k), 117) + call check (ichar (s, kind=k), 117) + + if (achar(107) /= achar(107,1)) call abort + + call check (index (t, s, .true., k), 7) + call check (index (t, s, kind=k, back=.false.), 5) + + if (any (lbound (l_array, kind=k) /= 1)) call abort + call check (lbound (l_array, 1), 1) + call check (lbound (l_array, 1, kind=k), 1) + + if (any (ubound (l_array, kind=k) /= (/4, 5/))) call abort + call check (ubound (l_array, 1), 4) + call check (ubound (l_array, 1, kind=k), 4) + + call check (len(t, k), 20) + call check (len_trim(t, k), 10) + + call check (scan (t, s, .true., k), 7) + call check (scan (t, s, kind=k, back=.false.), 5) + + call check (size (l_array, 1, kind=k), 4) + call check (size (l_array, kind=k), 20) + + call check (verify (t, s, .true., k), 20) + call check (verify (t, s, kind=k, back=.false.), 1) + +contains + + subroutine check(x,y) + integer, intent(in) :: x, y + if (x /= y) call abort + end subroutine check + +end program test |