GMRVFUT2 ;HIRMFO/RM-FILE UTILITIES FOR 120.52 FILE ;5/1/97
;;4.0;Vitals/Measurements;**1**;Apr 25, 1997
;
ACHR(GMRVSK,DA,X) ; CALLED FROM SET/KILL LOGIC OF ACHR XREF ON
; QUALIFIER (.01) FIELD OF GMRV VITAL QUALIFIER (120.52) FILE.
; THIS PROCEDURE SETS/KILLS THE FOLLOWING MUMPS INDICES: "AA".
; Input variables: GMRVSK=1 if called from SET, 2 if from KILL
; DA=DA array passed by reference.
; X=value being indexed.
;
S GMRVDA=DA N DA,GMRVY
S DA(1)=GMRVDA,DA=0
F S DA=$O(^GMRD(120.52,DA(1),1,DA)) Q:DA'>0 D
. S GMRVY=$G(^GMRD(120.52,DA(1),1,DA,0))
. D AA($P(GMRVY,"^"),$P(GMRVY,"^",2),X,.DA,GMRVSK)
. Q
K GMRVDA
Q
ATYP(GMRVSK,DA,X) ; CALLED FROM SET/KILL LOGIC OF ATYP XREF ON VITAL
; TYPE (.01) FIELD OF VITAL TYPE (120.521) SUB-FILE OF GMRV
; GMRV VITAL QUALIFIER (120.52) FILE. THIS PROCEDURE SETS/KILLS THE
; FOLLOWING MUMPS INDEX: "AA".
; Input variables: GMRVSK=1 if called from SET, 2 if from KILL
; DA=DA array passed by reference.
; X=value being indexed.
;
N GMRVX,GMRVY
S GMRVX=$P($G(^GMRD(120.52,DA(1),0)),"^"),GMRVY=$G(^GMRD(120.52,DA(1),1,DA,0))
D AA(X,$P(GMRVY,"^",2),$P(GMRVX,"^"),.DA,GMRVSK)
Q
ACAT(GMRVSK,DA,X) ; CALLED FROM SET/KILL LOGIC OF ACAT XREF ON CATEGORY
; (.02) FIELD OF VITAL TYPE (120.521) SUBFILE OF GMRV VITAL QUALIFIER
; (120.52) FILE. THIS PROCEDURE SETS/KILLS THE FOLLOWING MUMPS
; INDEX: "AA".
; Input variables: GMRVSK=1 if called from SET, 2 if from KILL
; DA=DA array passed by reference.
; X=value being indexed.
;
N GMRVX,GMRVY
S GMRVX=$G(^GMRD(120.52,DA(1),0)),GMRVY=$G(^GMRD(120.52,DA(1),1,DA,0))
D AA($P(GMRVY,"^"),X,$P(GMRVX,"^"),.DA,GMRVSK)
Q
AA(TYPE,CAT,CHAR,DA,SK) ; This procedure updates the "AA" index for the 120.52
; file. This index has the following format:
; ^GMRD(120.52,"AA",TYPE,CAT,CHAR,DA(1),DA)=""
; Input variables:
; TYPE=Vital Type (.01) field 120.521 sub-file.
; CAT=Category (.02) field of 120.521 sub-file.
; CHAR=Name (.01) field of 120.52 file.
; DA=Passed by reference will have entry in 120.52 sub-file, DA,
; and entry in 120.52 file, DA(1).
; SK=1 if set xref, 2 if kill xref.
;
Q:$G(TYPE)=""!($G(CAT)="")!($G(CHAR)="")!($G(DA(1))="")!($G(DA)="")
I $G(SK)=1 S ^GMRD(120.52,"AA",TYPE,CAT,CHAR,DA(1),DA)=""
I $G(SK)=2 K ^GMRD(120.52,"AA",TYPE,CAT,CHAR,DA(1),DA)
Q
SCR02(Y,DA) ; CALLED FROM INPUT TRANSFORM OF CATEGORY (.02) FIELD OF THE
; VITAL TYPE (120.521) SUB-FILE OF THE GMRV VITAL QUALIFIER
; (120.52) FILE. WILL CHECK TO SEE IF CATEGORY IS VALID FOR THIS
; VITAL TYPE.
; Input Variables: DA = DA arrary passed by reference from screen.
; Y = Entry in 120.53 file being validated.
;
N GMRVFXN,GMRVTYP S GMRVFXN=0
S GMRVTYP=$P($G(^GMRD(120.52,DA(1),1,DA,0)),"^")
I GMRVTYP>0,$D(^GMRD(120.53,"C",GMRVTYP,+Y)) S GMRVFXN=1
Q GMRVFXN
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HGMRVFUT2 3055 printed Dec 13, 2024@01:56:28 Page 2
GMRVFUT2 ;HIRMFO/RM-FILE UTILITIES FOR 120.52 FILE ;5/1/97
+1 ;;4.0;Vitals/Measurements;**1**;Apr 25, 1997
+2 ;
ACHR(GMRVSK,DA,X) ; CALLED FROM SET/KILL LOGIC OF ACHR XREF ON
+1 ; QUALIFIER (.01) FIELD OF GMRV VITAL QUALIFIER (120.52) FILE.
+2 ; THIS PROCEDURE SETS/KILLS THE FOLLOWING MUMPS INDICES: "AA".
+3 ; Input variables: GMRVSK=1 if called from SET, 2 if from KILL
+4 ; DA=DA array passed by reference.
+5 ; X=value being indexed.
+6 ;
+7 SET GMRVDA=DA
NEW DA,GMRVY
+8 SET DA(1)=GMRVDA
SET DA=0
+9 FOR
SET DA=$ORDER(^GMRD(120.52,DA(1),1,DA))
if DA'>0
QUIT
Begin DoDot:1
+10 SET GMRVY=$GET(^GMRD(120.52,DA(1),1,DA,0))
+11 DO AA($PIECE(GMRVY,"^"),$PIECE(GMRVY,"^",2),X,.DA,GMRVSK)
+12 QUIT
End DoDot:1
+13 KILL GMRVDA
+14 QUIT
ATYP(GMRVSK,DA,X) ; CALLED FROM SET/KILL LOGIC OF ATYP XREF ON VITAL
+1 ; TYPE (.01) FIELD OF VITAL TYPE (120.521) SUB-FILE OF GMRV
+2 ; GMRV VITAL QUALIFIER (120.52) FILE. THIS PROCEDURE SETS/KILLS THE
+3 ; FOLLOWING MUMPS INDEX: "AA".
+4 ; Input variables: GMRVSK=1 if called from SET, 2 if from KILL
+5 ; DA=DA array passed by reference.
+6 ; X=value being indexed.
+7 ;
+8 NEW GMRVX,GMRVY
+9 SET GMRVX=$PIECE($GET(^GMRD(120.52,DA(1),0)),"^")
SET GMRVY=$GET(^GMRD(120.52,DA(1),1,DA,0))
+10 DO AA(X,$PIECE(GMRVY,"^",2),$PIECE(GMRVX,"^"),.DA,GMRVSK)
+11 QUIT
ACAT(GMRVSK,DA,X) ; CALLED FROM SET/KILL LOGIC OF ACAT XREF ON CATEGORY
+1 ; (.02) FIELD OF VITAL TYPE (120.521) SUBFILE OF GMRV VITAL QUALIFIER
+2 ; (120.52) FILE. THIS PROCEDURE SETS/KILLS THE FOLLOWING MUMPS
+3 ; INDEX: "AA".
+4 ; Input variables: GMRVSK=1 if called from SET, 2 if from KILL
+5 ; DA=DA array passed by reference.
+6 ; X=value being indexed.
+7 ;
+8 NEW GMRVX,GMRVY
+9 SET GMRVX=$GET(^GMRD(120.52,DA(1),0))
SET GMRVY=$GET(^GMRD(120.52,DA(1),1,DA,0))
+10 DO AA($PIECE(GMRVY,"^"),X,$PIECE(GMRVX,"^"),.DA,GMRVSK)
+11 QUIT
AA(TYPE,CAT,CHAR,DA,SK) ; This procedure updates the "AA" index for the 120.52
+1 ; file. This index has the following format:
+2 ; ^GMRD(120.52,"AA",TYPE,CAT,CHAR,DA(1),DA)=""
+3 ; Input variables:
+4 ; TYPE=Vital Type (.01) field 120.521 sub-file.
+5 ; CAT=Category (.02) field of 120.521 sub-file.
+6 ; CHAR=Name (.01) field of 120.52 file.
+7 ; DA=Passed by reference will have entry in 120.52 sub-file, DA,
+8 ; and entry in 120.52 file, DA(1).
+9 ; SK=1 if set xref, 2 if kill xref.
+10 ;
+11 if $GET(TYPE)=""!($GET(CAT)="")!($GET(CHAR)="")!($GET(DA(1))="")!($GET(DA)="")
QUIT
+12 IF $GET(SK)=1
SET ^GMRD(120.52,"AA",TYPE,CAT,CHAR,DA(1),DA)=""
+13 IF $GET(SK)=2
KILL ^GMRD(120.52,"AA",TYPE,CAT,CHAR,DA(1),DA)
+14 QUIT
SCR02(Y,DA) ; CALLED FROM INPUT TRANSFORM OF CATEGORY (.02) FIELD OF THE
+1 ; VITAL TYPE (120.521) SUB-FILE OF THE GMRV VITAL QUALIFIER
+2 ; (120.52) FILE. WILL CHECK TO SEE IF CATEGORY IS VALID FOR THIS
+3 ; VITAL TYPE.
+4 ; Input Variables: DA = DA arrary passed by reference from screen.
+5 ; Y = Entry in 120.53 file being validated.
+6 ;
+7 NEW GMRVFXN,GMRVTYP
SET GMRVFXN=0
+8 SET GMRVTYP=$PIECE($GET(^GMRD(120.52,DA(1),1,DA,0)),"^")
+9 IF GMRVTYP>0
IF $DATA(^GMRD(120.53,"C",GMRVTYP,+Y))
SET GMRVFXN=1
+10 QUIT GMRVFXN