VistA-FOIAVistA/r/TOOLKIT-AWCM-XD-XIN-XPAR-XQ.../XINDX3.m

91 lines
2.9 KiB
Mathematica

XINDX3 ;ISC/REL,GRK,RWF - PROCESS MERGE/SET/READ/KILL/NEW/OPEN COMMANDS ;10/23/2003 17:43
;;7.3;TOOLKIT;**20,27,61,68**;Apr 25, 1995
PEEK S Y=$G(LV(LV,LI+1)) Q
PEEK2 S Y=$G(LV(LV,LI+2)) Q
INC2 S LI=LI+1 ;Drop into INC
INC S LI=LI+1,S=$G(LV(LV,LI)),S1=$G(LV(LV,LI+1)),CH=$E(S) G ERR:$A(S)=10 Q
DN S LI(LV)=LI,LI(LV,1)=AC,LV=LV+1,LI=LI(LV),AC=NOA
Q
UP ;Inc LI as we save to skip the $C(10).
D PEEK S:$A(Y)=10 LI=LI+1 S LI(LV)=LI,LV=LV-1,LI=LI(LV),AC=LI(LV,1) Q
PEEKDN S Y=$G(LV(LV+1,LI(LV+1)+1)) Q
FIND F Y=LI:1:AC Q:L[$G(LV(LV,Y))
ERR D E^XINDX1(43) S (S,S1,CH)="" Q
Q
Q
S S ERR=10 G:ARG="" ^XINDX1 S STR=ARG,ARG="",RHS=0 D ^XINDX9
S2 S GK="" D INC I S="" D:'RHS E^XINDX1(10) Q
I CH="," S RHS=0 G S2
I CH="=" S RHS=1 D:","[S1 E^XINDX1(10) G S2
I CH="$",'RHS D D:% E^XINDX1(10)
. S %=1
. I "$E$P$X$Y"[$E(S,1,2) S %=0 Q
. I "$EC$ET$QS"[$E(S,1,3) S %=0 Q
. I "$ZE$ZT"[$E(S,1,3) D E^XINDX1(28) S %=0 Q ;Should not be used
. Q
I CH="^" D FL G S2
I CH="@" S Y=$$ASM(LV,LI,",") S:Y'["=" RHS=1 D INC,ARG^XINDX2 G S2
I CH="(" D MULT G S2
D FL G S2
MULT D INC S NOA=S I S'>0 S ERR=5 G ^XINDX1
D DN S AC=AC+LI F Q:AC'>LI S:'RHS GK="*" D INC,ARG^XINDX2
D UP Q
FL ;
S:'RHS GK="*" D ARG^XINDX2
Q
VLNF(X) ;Drop into VLN
VLN S ERR=0
Q:X?1.8UN
Q:X?1"%".7UN
I X'?1.8AN,X'?1"%".7AN D E^XINDX1(11)
D E^XINDX1(57) ;Must contain lowercase
;I X'?1.8UN,X'?1.8LN,X'?1"%".7UN,X'?1"%".7LN D E^XINDX1(ERR)
Q
VGN S ERR=0 I X'?1.8UN,X'?1"%".7UN D E^XINDX1(12)
Q
KL ;Process KILL
S STR=ARG,ARG(1)=ARG,ARG="" D ^XINDX9
A D INC Q:S="" G A:CH="," S LOC="L" D @$S(CH="@":"KL1",CH="^":"KL2",CH="(":"KL4",1:"KL3") G A
KL1 D INC,ARG^XINDX2 Q
KL2 S GK="!"
I S1'="(" S ERR=24 D ^XINDX1
G ARG^XINDX2
KL3 I "^DT^DTIME^DUZ^IOST^IOM^U^"[("^"_S_"^") S ERR=39,ERR(1)=S D ^XINDX1
I "IO"=S D:S1="(" PEEKDN S ERR=39,ERR(1)=S_$S(S1["(":S1_Y_")",1:"") D:S1'="(" ^XINDX1 I S1="(",("QC"'[$E(Y,2)) D ^XINDX1
KL5 S GK="!" D ARG^XINDX2 Q ;KILL SUBS
Q
KL4 S NOA=S1 D DN,ARGS^XINDX2,UP,INC2 Q
NE ;NEW
S ERR=$S("("[$E(ARG):26,1:0) I ERR G ^XINDX1 ;look for null or (
S STR=ARG D ^XINDX9
N2 D INC Q:S="" G N2:CH="," I CH?1P,("%@()"'[CH)&("$E"'[$E(S,1,2)) D E^XINDX1(11) G N2
S GK="~" D ARG^XINDX2 G N2
;
RD S STR=ARG D ^XINDX9 S ARG=""
RD1 D INC Q:S=""
;I (CH="!")!(CH=",")!(CH=Q)!(CH="#") G RD1
;I CH="^" S ERR=11 D ^XINDX1
I '((CH="%")!(CH?1A)!(CH="*")) D RD3 G RD1
S Y=$$ASM(LV,LI,",") I Y'[":" S ERR=33,RDTIME=1 D ^XINDX1
D RD2 G RD1
RD2 Q:","[CH
I "*#"[CH D E^XINDX1(41)
I "#:"[CH D INC,ARG^XINDX2,INC G RD2
I (CH="%")!(CH?1A) S LOC="L",GK="*" D ARG^XINDX2,INC G RD2
D INC G RD2
RD3 Q:","[CH I "!#?"[CH D INC G RD3
I (CH="%")!(CH?1A)!(CH="@") D ARG^XINDX2,INC G RD3
Q
O S STR=ARG,AC=99 D ^XINDX9,INC S ARG="" I S["@" D ARGS^XINDX2 Q
D ARG^XINDX2,INC D D INC,ARGS^XINDX2 Q
. F D INC Q:":"[S
. Q
Q
ERRCP S ERR=5 D ^XINDX1 Q
ST ;
S:'$D(V(LOC,S)) V(LOC,S)="" S:V(LOC,S)'[GK V(LOC,S)=V(LOC,S)_GK,GK="" Q
Q
ASM(WL,SI,L,SEP) ;
N %,CH,Y S SEP=$G(SEP),Y="" F %=SI:1 S CH=$G(LV(WL,%)) Q:L[CH S Y=Y_SEP_CH
Q Y