sypopc |
Table of contents
ProcedureSYPOPC ( Pop a value from a particular symbol ) SUBROUTINE SYPOPC ( NAME, TABSYM, TABPTR, TABVAL, VALUE, FOUND ) AbstractPop a value associated with a particular symbol in a character symbol table. The first value associated with the symbol is removed, and subsequent values are moved forward. Required_ReadingSYMBOLS KeywordsSYMBOLS DeclarationsIMPLICIT NONE INTEGER LBCELL PARAMETER ( LBCELL = -5 ) CHARACTER*(*) NAME CHARACTER*(*) TABSYM ( LBCELL:* ) INTEGER TABPTR ( LBCELL:* ) CHARACTER*(*) TABVAL ( LBCELL:* ) CHARACTER*(*) VALUE LOGICAL FOUND Brief_I/OVARIABLE I/O DESCRIPTION -------- --- -------------------------------------------------- NAME I Name of the symbol whose associated value is to be popped. TABSYM, TABPTR, TABVAL I-O Components of the symbol table. VALUE O Value that was popped. FOUND O .TRUE. if the symbol exists, .FALSE. otherwise. Detailed_InputNAME is the name of the symbol whose associated value is to be popped. TABSYM, TABPTR, TABVAL are the components of a character symbol table. Detailed_OutputTABSYM, TABPTR, TABVAL are the components of a character symbol table. On output, the value is removed from the symbol table, and the remaining values associated with the symbol are moved forward in the value table. If no other values are associated with the symbol, the symbol is removed from the symbol table. VALUE is the value that was popped. This value was the first value in the symbol table that was associated with the symbol NAME. FOUND is .TRUE. if NAME is in the symbol table, otherwise it is .FALSE. ParametersNone. ExceptionsNone. FilesNone. ParticularsIf there are no remaining values associated with the symbol after VALUE has been popped, the symbol is removed from the symbol table. ExamplesThe contents of the symbol table are: BOHR --> HYDROGEN ATOM EINSTEIN --> SPECIAL RELATIVITY PHOTOELECTRIC EFFECT BROWNIAN MOTION FERMI --> NUCLEAR FISSION The call, CALL SYPOPC ( 'EINSTEIN', TABSYM, TABPTR, TABVAL, . VALUE, FOUND ) modifies the contents of the symbol table to be: BOHR --> HYDROGEN ATOM EINSTEIN --> PHOTOELECTRIC EFFECT BROWNIAN MOTION FERMI --> NUCLEAR FISSION FOUND is .TRUE., and VALUE is 'SPECIAL RELATIVITY'. The next call, CALL SYPOPC ( 'FERMI', TABSYM, TABPTR, TABVAL, VALUE, FOUND ) modifies the contents of the symbol table to be: BOHR --> HYDROGEN ATOM EINSTEIN --> SPECIAL RELATIVITY PHOTOELECTRIC EFFECT BROWNIAN MOTION FOUND is .TRUE., and VALUE is 'NUCLEAR FISSION'. Note that because "FERMI" had only one value associated with it, it was removed from the symbol table. RestrictionsNone. Literature_ReferencesNone. Author_and_InstitutionJ. Diaz del Rio (ODC Space) H.A. Neilan (JPL) W.L. Taber (JPL) I.M. Underwood (JPL) VersionSPICELIB Version 1.1.0, 08-APR-2021 (JDR) Added IMPLICIT NONE statement. Edited the header to comply with NAIF standard. SPICELIB Version 1.0.1, 10-MAR-1992 (WLT) Comment section for permuted index source lines was added following the header. SPICELIB Version 1.0.0, 31-JAN-1990 (IMU) (HAN) |
Fri Dec 31 18:37:00 2021