This is the mail archive of the
gcc-patches@gcc.gnu.org
mailing list for the GCC project.
test more libU77 routines and interfaces
- To: egcs-patches at egcs dot cygnus dot com
- Subject: test more libU77 routines and interfaces
- From: craig at jcb-sc dot com
- Date: 2 May 1999 05:34:39 -0000
- Cc: craig at jcb-sc dot com
Committed.
tq vm, (burley)
Sun May 2 01:13:37 1999 Craig Burley <craig@jcb-sc.com>
* libU77/u77-test.f (main): List libU77 intrinsics
not currently tested.
Add tests for TIME8, CTIME_subr, IARGC, TTYNAM_subr,
GETENV, FDATE_subr, DTIME_subr, ETIME_subr, DATE, ITIME,
FTELL_subr, MCLOCK, MCLOCK8, and CPU_TIME.
Trim blanks off the ends of some printed strings.
*** g77-e/libf2c/libU77/u77-test.f.~1~ Sun May 2 00:08:30 1999
--- g77-e/libf2c/libU77/u77-test.f Sun May 2 01:12:40 1999
***************
*** 4,7 ****
--- 4,30 ----
* starred messages.
*
+ * Currently not tested:
+ * ALARM
+ * CHDIR (func)
+ * CHMOD (func)
+ * FGET (func/subr)
+ * FGETC (func)
+ * FPUT (func/subr)
+ * FPUTC (func)
+ * FSTAT (subr)
+ * GETCWD (subr)
+ * HOSTNM (subr)
+ * IRAND
+ * KILL
+ * LINK (func)
+ * LSTAT (subr)
+ * RENAME (func/subr)
+ * SIGNAL (subr)
+ * SRAND
+ * STAT (subr)
+ * SYMLNK (func/subr)
+ * UMASK (func)
+ * UNLINK (func)
+ *
* NOTE! This is the libU77 version, so it should be a bit more
* "interactive" than the testsuite version, which is in
***************
*** 23,32 ****
+ pid, mask
real tarray1(2), tarray2(2), r1, r2
logical issum
! intrinsic getpid, getuid, getgid, ierrno, gerror,
! + fnum, isatty, getarg, access, unlink, fstat,
! + stat, lstat, getcwd, gmtime, etime, chmod,
+ chdir, fgetc, fputc, system_clock, second, idate, secnds,
! + time, ctime, fdate, ttynam, date_and_time
external lenstr, ctrlc
integer lenstr
--- 46,58 ----
+ pid, mask
real tarray1(2), tarray2(2), r1, r2
+ double precision d1
+ integer(kind=2) bigi
logical issum
! intrinsic getpid, getuid, getgid, ierrno, gerror, time8,
! + fnum, isatty, getarg, access, unlink, fstat, iargc,
! + stat, lstat, getcwd, gmtime, etime, chmod, itime, date,
+ chdir, fgetc, fputc, system_clock, second, idate, secnds,
! + time, ctime, fdate, ttynam, date_and_time, mclock, mclock8,
! + cpu_time, dtime
external lenstr, ctrlc
integer lenstr
***************
*** 34,38 ****
character gerr*80, c*1
character ctim*25, line*80, lognam*20, wd*100, line2*80, ddate*8,
! + ttime*10, zone*5
integer fstatb (13), statb (13)
integer *2 i2zero
--- 60,64 ----
character gerr*80, c*1
character ctim*25, line*80, lognam*20, wd*100, line2*80, ddate*8,
! + ttime*10, zone*5, ctim2*25
integer fstatb (13), statb (13)
integer *2 i2zero
***************
*** 40,45 ****
integer(kind=7) sigret
! ctim = ctime(time())
! WRITE (6,'(A/)') '1 GNU libU77 test at: ' // ctim
write (6,'(A,I3,'', '',I3)')
+ ' Logical units 5 and 6 correspond (FNUM) to'
--- 66,72 ----
integer(kind=7) sigret
! i = time ()
! ctim = ctime (i)
! WRITE (6,'(A/)') '1 GNU libU77 test at: ' // ctim(:lenstr (ctim))
write (6,'(A,I3,'', '',I3)')
+ ' Logical units 5 and 6 correspond (FNUM) to'
***************
*** 49,52 ****
--- 76,102 ----
call abort
end if
+
+ bigi = time8 ()
+
+ call ctime (ctim2, i)
+ if (ctim .ne. ctim2) then
+ write (6, *) '*** CALL CTIME disagrees with CTIME(): ',
+ + ctim2(:lenstr (ctim2)), ' vs. ', ctim(:lenstr (ctim))
+ call doabort
+ end if
+
+ j = time ()
+ if (i .gt. bigi .or. bigi .gt. j) then
+ write (6, *) '*** TIME/TIME8/TIME sequence failures: ',
+ + i, bigi, j
+ call doabort
+ end if
+
+ print *, 'Command-line arguments: ', iargc ()
+ do i = 0, iargc ()
+ call getarg (i, line)
+ print *, 'Arg ', i, ' is: ', line(:lenstr (line))
+ end do
+
l= isatty(6)
line2 = ttynam(6)
***************
*** 57,60 ****
--- 107,116 ----
end if
write (6,'(1X,A)') line(:lenstr(line))
+ call ttynam (line, 6)
+ if (line .ne. line2) then
+ print *, '*** CALL TTYNAM disagrees with TTYNAM: ',
+ + line(:lenstr (line))
+ call doabort
+ end if
* regression test for compiler crash fixed by JCB 1998-08-04 com.c
***************
*** 70,76 ****
CALL SYSTEM ('echo " " `id`')
call flush
lognam = 'blahblahblah'
call getlog (lognam)
! write (6,*) 'Login name (GETLOG): ', lognam
call umask(0, mask)
write(6,*) 'UMASK returns', mask
--- 126,138 ----
CALL SYSTEM ('echo " " `id`')
call flush
+
lognam = 'blahblahblah'
call getlog (lognam)
! write (6,*) 'Login name (GETLOG): ', lognam(:lenstr (lognam))
!
! wd = 'blahblahblah'
! call getenv ('LOGNAME', wd)
! write (6,*) 'Login name (GETENV of LOGNAME): ', wd(:lenstr (wd))
!
call umask(0, mask)
write(6,*) 'UMASK returns', mask
***************
*** 78,82 ****
ctim = fdate()
! write (6,*) 'FDATE returns: ', ctim
j=time()
call ltime (j, ltarray)
--- 140,147 ----
ctim = fdate()
! write (6,*) 'FDATE returns: ', ctim(:lenstr (ctim))
! call fdate (ctim)
! write (6,*) 'CALL FDATE returns: ', ctim(:lenstr (ctim))
!
j=time()
call ltime (j, ltarray)
***************
*** 84,90 ****
--- 149,157 ----
call gmtime (j, ltarray)
write (6,'(1x,a,9i4)') 'GMTIME returns:', ltarray
+
call system_clock(count) ! omitting optional args
call system_clock(count, rate, count_max)
write(6,*) 'SYSTEM_CLOCK returns: ', count, rate, count_max
+
call date_and_time(ddate) ! omitting optional args
call date_and_time(ddate, ttime, zone, values)
*************** c now try to get times to change enough
*** 123,130 ****
do j = 1,1000
end do
! r2 = dtime (tarray2)
if (tarray2(1) .ne. 0. .or. tarray2(2) .ne. 0.) exit
end do
! r1 = etime (tarray1)
if (.not. issum (r1, tarray1(1), tarray1(2))) then
write (6,*) '*** ETIME didn''t return sum of the array: ',
--- 190,197 ----
do j = 1,1000
end do
! call dtime (r2, tarray2)
if (tarray2(1) .ne. 0. .or. tarray2(2) .ne. 0.) exit
end do
! call etime (r1, tarray1)
if (.not. issum (r1, tarray1(1), tarray1(2))) then
write (6,*) '*** ETIME didn''t return sum of the array: ',
*************** c now try to get times to change enough
*** 153,163 ****
--- 220,240 ----
call doabort
end if
+
+ call date (ctim)
+ write (6,*) 'DATE (dd-mmm-yy): ', ctim(:lenstr (ctim))
+
+ call itime (idat)
+ write (6,*) 'ITIME (hour,minutes,seconds): ', idat
+
call time(line(:8))
print *, 'TIME: ', line(:8)
+
write (6,*) 'SECNDS(0.0) returns: ',secnds(0.0)
+
write (6,*) 'SECOND returns: ', second()
call dumdum(r1)
call second(r1)
write (6,*) 'CALL SECOND returns: ', r1
+
* compiler crash fixed by 1998-10-01 com.c change
if (rand(0).lt.0.0 .or. rand(0).gt.1.0) then
*************** c now try to get times to change enough
*** 165,168 ****
--- 242,246 ----
call doabort()
end if
+
i = getcwd(wd)
if (i.ne.0) then
*************** c now try to get times to change enough
*** 177,180 ****
--- 255,259 ----
call doabort
end if
+
i=hostnm(wd)
if(i.ne.0) then
*************** c now try to get times to change enough
*** 184,187 ****
--- 263,267 ----
write (6,*) 'Host name is ', wd(:lenstr(wd))
end if
+
i = access('/dev/null ', 'rw')
if (i.ne.0) write (6,*) '***Read/write ACCESS to /dev/null: ', i
*************** C the better to test with, my dear!
*** 214,217 ****
--- 294,302 ----
call doabort
end if
+ call ftell(3, i)
+ if (i.ne.1) then
+ write(6,*) '***CALL FTELL offset: ', i
+ call doabort
+ end if
call chmod ('foo', 'a+w',i)
if (i.ne.0) then
*************** C in case it exists already:
*** 270,273 ****
--- 355,359 ----
call doabort
end if
+
call gerror (gerr)
i = ierrno()
*************** C in case it exists already:
*** 279,282 ****
--- 365,375 ----
call perror (line (:lenstr (line)))
call unlink ('bar')
+
+ print *, 'MCLOCK returns ', mclock ()
+ print *, 'MCLOCK8 returns ', mclock8 ()
+
+ call cpu_time (d1)
+ print *, 'CPU_TIME returns ', d1
+
WRITE (6,*) 'You should see exit status 1'
CALL EXIT(1)