aboutsummaryrefslogtreecommitdiff
path: root/src/slalib/wait.f_pcm
diff options
context:
space:
mode:
Diffstat (limited to 'src/slalib/wait.f_pcm')
-rw-r--r--src/slalib/wait.f_pcm66
1 files changed, 66 insertions, 0 deletions
diff --git a/src/slalib/wait.f_pcm b/src/slalib/wait.f_pcm
new file mode 100644
index 0000000..d79e78a
--- /dev/null
+++ b/src/slalib/wait.f_pcm
@@ -0,0 +1,66 @@
+ SUBROUTINE sla_WAIT (DELAY)
+*+
+* - - - - -
+* W A I T
+* - - - - -
+*
+* Interval wait
+*
+* !!! PC only - Microsoft Fortran specific !!!
+*
+* Given:
+* DELAY real delay in seconds
+*
+* A delay of up to 10000 seconds occurs.
+*
+* Called: GETTIM (Microsoft Fortran run-time library)
+*
+* P.T.Wallace Starlink 14 October 1991
+*
+* Copyright (C) 1995 Rutherford Appleton Laboratory
+*-
+
+ IMPLICIT NONE
+
+ REAL DELAY
+
+ INTEGER IDELAY,IH,IM,IS,I,IT,IT0,IDT
+ LOGICAL FIRST,LOOP
+
+
+
+
+* Convert requested delay to 0.01 second ticks
+ IDELAY=NINT(MAX(MIN(DELAY,1E4),0.0)*1E2)
+
+* Set "note start time" flag
+ FIRST=.TRUE.
+
+* Set "wait in progress" flag
+ LOOP=.TRUE.
+
+* Main loop
+ DO WHILE (LOOP)
+
+* Get the current time and convert to 0.01 second ticks
+ CALL GETTIM(IH,IM,IS,I)
+ IT=((IH*60+IM)*60+IS)*100+I
+
+* First time through the loop?
+ IF (FIRST) THEN
+
+* Yes: note the time and reset the flag
+ IT0=IT
+ FIRST=.FALSE.
+ ELSE
+
+* No: subtract the start time, handling 0 hours wrap
+ IDT=IT-IT0
+ IF (IDT.LT.0) IDT=IDT+8640000
+
+* If the requested delay has elapsed, stop looping
+ LOOP=IDT.LT.IDELAY
+ END IF
+ END DO
+
+ END