Cloned SEACAS for EXODUS library with extra build files for internal package management.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

67 lines
1.9 KiB

2 years ago
C Copyright(C) 1999-2020 National Technology & Engineering Solutions
C of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with
C NTESS, the U.S. Government retains certain rights in this software.
C
C See packages/seacas/LICENSE for details
C=======================================================================
SUBROUTINE GRIKEY (PROMPT, DX, DY, KEY, *)
C=======================================================================
C --*** GRIKEY *** (GRPLIB) Position cursor and wait for a key (PLT)
C -- Written by Amy Gilkey - revised 04/28/88
C --
C --GRIKEY positions a cursor and waits until a key is pressed.
C --A message may be output before the cursor is positioned. The
C --cursor position and the key are returned.
C --
C --The first time this routine is called, a warning message is output.
C --
C --Parameters:
C -- PROMPT - IN - prompt for key if non-blank
C -- DX, DY - IN/OUT - the device coordinates of cursor
C -- KEY - OUT - returned key pressed; upper-case
C -- * - the alternate return if cancel requested or cursor input error
C --Routines Called:
C -- PLTCRS - (PLTLIB) Select cursor position
C -- PLTFLU - (PLTLIB) Flush buffer
C -- LENSTR - (STRLIB) Find string length
CHARACTER*(*) PROMPT
REAL DX, DY
CHARACTER KEY
LOGICAL FIRST
SAVE FIRST
DATA FIRST / .TRUE. /
CALL PLTFLU
IF (FIRST) THEN
WRITE (*, 10000)
FIRST = .FALSE.
END IF
IF (PROMPT .NE. ' ') THEN
WRITE (*, '(1X, A)') PROMPT(:LENSTR(PROMPT))
END IF
CALL PLTCRS (DX, DY, KEY)
IF ((DX .LT. 0.0) .OR. (DX .GT. 1.0)
& .OR. (DY .LT. 0.0) .OR. (DY .GT. 1.0)) THEN
WRITE (*, 10010)
RETURN 1
END IF
CALL EXUPCS (KEY)
RETURN
10000 FORMAT (/,
& 15X,'*** Press SPACE or a letter to pick a point ***', /)
10010 FORMAT (/,
& ' *** ERROR on cursor input ***', /)
END