blob: c79b4a6edc3788a9526a3ac25cbcab5b23274e4e [file] [log] [blame]
! We want to check that ISHFT evaluates its arguments only once
!
! { dg-do run }
! { dg-options "-fdump-tree-original" }
program test
if (ishft (foo(), 2) /= 4) STOP 1
if (ishft (foo(), -1) /= 1) STOP 2
if (ishft (1, foo()) /= 8) STOP 3
if (ishft (16, -foo()) /= 1) STOP 4
if (ishftc (bar(), 2) /= 4) STOP 5
if (ishftc (bar(), -1) /= 1) STOP 6
if (ishftc (1, bar()) /= 8) STOP 7
if (ishftc (16, -bar()) /= 1) STOP 8
contains
integer function foo ()
integer, save :: i = 0
i = i + 1
foo = i
end function
integer function bar ()
integer, save :: i = 0
i = i + 1
bar = i
end function
end program
! The regexp "foo ()" should be seen once in the dump:
! -- once in the function definition itself
! -- plus as many times as the function is called
!
! { dg-final { scan-tree-dump-times "foo *\\\(\\\)" 5 "original" } }
! { dg-final { scan-tree-dump-times "bar *\\\(\\\)" 5 "original" } }