1 | LAXSYM ;MLD/ABBOTT/SLC/RAF - TEMPLATE ROUTINE FOR AUTOMATED DATA ;6/13/96 0900 ;
|
---|
2 | ;;5.2;AUTOMATED LAB INSTRUMENTS;**11,19**;Sep 27, 1994
|
---|
3 | ;CROSS LINK BY ID OR IDE
|
---|
4 | ;
|
---|
5 | LAPX ; orig routine name, copied to LAXSYM (for Abbott AxSYM) 5/3/94 /mld
|
---|
6 | ;
|
---|
7 | N FR,LANM,TSK,LANM,A,I,X,Y,TC,TV,V1,TOUT,BAD,ID,IDE,TRAY,CUP,LANOCTL1,TP
|
---|
8 | N LATEST,RMK,DATE,CNT,LAGEN,RESCOM,RESTYPE,HCNT,DFN,HTYPE,IN,OUT,D
|
---|
9 | N LALCT,LAZZ,LINK,LOG,LRDFN,LROVER,LWL,METH,NOW,WL,ALPHA,TST60,TSK
|
---|
10 | N ISQN,LADT
|
---|
11 | ;
|
---|
12 | LA1 ; Init vars/arrays
|
---|
13 | S LANM=$T(+0),TSK=$O(^LAB(62.4,"C",LANM,0)) Q:TSK<1
|
---|
14 | K LATOP D ^LASET Q:'TSK
|
---|
15 | D LA1INIT^LAXSYMU ; init vars in util routine
|
---|
16 | ;
|
---|
17 | LA2 ; Begin here to parse out data
|
---|
18 | K TV,Y
|
---|
19 | S (TST60,TOUT)=0,(A,TRAY)=1,(CUP,ID,IDE,RMK)="",D="|"
|
---|
20 | D IN ; get data
|
---|
21 | G QUIT:TOUT,LA2:IN=""!(V1'="H") ; 'H' is start of packet
|
---|
22 | G:$F("HPORLCQMS",V1)<2 LA2 ; frame hdr = line tag
|
---|
23 | I V1="H" S HCNT=CNT-1 ; get hdr count for error trapping
|
---|
24 | D @V1 ; get hdr info
|
---|
25 | ;
|
---|
26 | ; loop thru single packet, L=end of packet
|
---|
27 | F A=2:1 D IN Q:TOUT!(V1="L") I $F("ORLCQMS",V1)>1 D @V1 ; bypass HP
|
---|
28 | ;
|
---|
29 | LA3 ; Now process the packet
|
---|
30 | G:'$G(ID) LA2 ; not valid or incomplete record
|
---|
31 | X LAGEN G LA2:'ISQN ; Can be changed by the cross-link code
|
---|
32 | F I=0:0 S I=$O(TV(I)) Q:I<1 S:TV(I,1)]"" ^LAH(LWL,1,ISQN,I)=TV(I,1)
|
---|
33 | I RMK]"" D RMK^LASET
|
---|
34 | G LA2
|
---|
35 | ;
|
---|
36 | H ; Header node TYPE: P=pt, Q=qc
|
---|
37 | S HTYPE=$P(IN,D,12)
|
---|
38 | Q
|
---|
39 | ;
|
---|
40 | P ; Patient node
|
---|
41 | S DFN=$P($P(IN,D,5),U)
|
---|
42 | Q
|
---|
43 | ;
|
---|
44 | O ; Order node.
|
---|
45 | N SPECID,TNUM,PTYPE,X,AN,L
|
---|
46 | S SPECID=$P(IN,D,4),AN=$P(SPECID,U),L=$L(AN)
|
---|
47 | ; AN is the numeric value of the last 4 characters of SID field!
|
---|
48 | S AN=+$TR($E(AN,(L-4),L),ALPHA) ; just the #
|
---|
49 | S TNUM=+$P($P(IN,D,5),U,4)
|
---|
50 | Q:'TNUM Q:'AN ; no AxSYM test or Accn Num
|
---|
51 | S TST60=$$ACCN ; get file 60 test num (TST60)
|
---|
52 | Q:'TST60 ; invalid test
|
---|
53 | S PTYPE=$P(IN,D,12) ; ""=pt, Q=QC
|
---|
54 | Q:$P(IN,D,26)'="F" ; 'F'inal, X=could not run tst
|
---|
55 | S (ID,IDE)=AN ; should be OK
|
---|
56 | Q
|
---|
57 | ;
|
---|
58 | R ; Results node
|
---|
59 | Q:'ID ; no accn to put results to!
|
---|
60 | N TST,TNUM,TRES,V,DEC,FLAG
|
---|
61 | S FLAG=$P(IN,D,7) Q:FLAG="<" Q:FLAG=">" ; test out of range
|
---|
62 | ;
|
---|
63 | S TST=$P(IN,D,3) ; eg., TST = "^^^211^GLUCOSE^UNDILUTED"
|
---|
64 | S TNUM=+$P(TST,U,4) ; AxSYM's internal test number
|
---|
65 | Q:'$D(LATEST(TNUM,TST60)) ; invalid AxSYM/DHCP test match
|
---|
66 | ;
|
---|
67 | S TRES=$P(TST,U,8),V=$P(IN,D,4)
|
---|
68 | I TRES="X" S ^LA(INST,"ERX",$H)=IN Q ; Xception results (error msg)
|
---|
69 | Q:"F"'[TRES ; type result should be "F"inal or NULL
|
---|
70 | Q:V="" ; no result!
|
---|
71 | ;
|
---|
72 | S DEC=TC(+LATEST(TNUM,TST60),3)
|
---|
73 | I $L(DEC) S V=$J(V,1,DEC) ; # dec'mls (Param 2)
|
---|
74 | X:$L(TC(+LATEST(TNUM,TST60),2)) TC(+LATEST(TNUM,TST60),2) ; use param 1
|
---|
75 | S @TC(+LATEST(TNUM,TST60),1)=V ; save to TV array
|
---|
76 | Q
|
---|
77 | ;
|
---|
78 | L ; Packet termination node
|
---|
79 | Q
|
---|
80 | ;
|
---|
81 | C ; Comments node. type = G if result comment, = I if Exception string
|
---|
82 | S (RMK,RESCOM)=$P(IN,D,4),RESTYPE=$P(IN,D,5)
|
---|
83 | Q
|
---|
84 | ;
|
---|
85 | Q ; Set-up Query node
|
---|
86 | N LRAN,LRAA,LRDT,LRNAME,SSN,LRFRM,BAD,LRAD,INST
|
---|
87 | S LRAA=WL,(LRDT,LRAD)=LADT,LRNAME="",LRFRM=0,BAD=0,INST=TSK
|
---|
88 | S LRAN=$P($P(IN,D,3),U,2)
|
---|
89 | D PNM^LAXSYMBL
|
---|
90 | ; chk for valid request
|
---|
91 | I LRNAME=""!('$F(IN,"^^ALL")) S $P(IN,"|",13)="X",BAD=1
|
---|
92 | D HQSET^LAXSYMHQ ; builds H/Q/L frames for downloading
|
---|
93 | S X="TRAP^"_LANM,@^%ZOSF("TRAP") ; reset error trap
|
---|
94 | Q
|
---|
95 | ;
|
---|
96 | M ; Manufacturer node
|
---|
97 | Q
|
---|
98 | ;
|
---|
99 | S ; Scientific (not used)
|
---|
100 | Q
|
---|
101 | ;
|
---|
102 | ACCN() ; Chk file 68 for Accn'd test (file 60)
|
---|
103 | N I,J,N S (I,J,N)=0
|
---|
104 | F S I=$O(LATEST(TNUM,I)) Q:'I I $D(^LRO(68,WL,1,LADT,1,AN,4,I)) Q
|
---|
105 | I 'I F S J=$O(^LRO(68,WL,1,LADT,1,AN,4,J)) Q:'J S I=0 D I N S I=N Q
|
---|
106 | .F S I=$O(^LAB(60,J,2,I)) Q:'I I $D(LATEST(TNUM,^(I,0))) S N=^(0) Q
|
---|
107 | Q +I
|
---|
108 | ;
|
---|
109 | NUM ;- not used here - IN+3,4 replaces this (slower) code /mld
|
---|
110 | S X="" F JJ=1:1:$L(V) S:$A(V,JJ)>32 X=X_$E(V,JJ)
|
---|
111 | S V=X
|
---|
112 | Q
|
---|
113 | ;
|
---|
114 | IN S CNT=^LA(TSK,"I",0)+1 IF '$D(^(CNT)) S TOUT=TOUT+1 Q:TOUT>5 H 5 G IN
|
---|
115 | S ^LA(TSK,"I",0)=CNT,IN=^(CNT),TOUT=0
|
---|
116 | ; strip contl chars, get FRame num and hdr node (H,P,O,R,L)
|
---|
117 | ; NOTE: $TR(IN,LANOCTL1) replaces 'D NUM' code in template routine /mld
|
---|
118 | S IN=$TR(IN,LANOCTL1),FR=+IN,V1=$TR($P(IN,D),FR)
|
---|
119 | Q
|
---|
120 | ;
|
---|
121 | QUIT L +^LA(TSK,"I")
|
---|
122 | K ^LA(TSK,"I"),^LA("LOCK",TSK),^TMP($J),^TMP("LA",$J)
|
---|
123 | I $D(ZTSK) D KILL^%ZTLOAD K ZTSK
|
---|
124 | L -^LA(TSK,"I")
|
---|
125 | Q
|
---|
126 | ;
|
---|
127 | TRAP ; Process errors
|
---|
128 | D ^LABERR S T=TSK
|
---|
129 | S ^LA(TSK,"I",0)=+$G(HCNT) ; keeps last HDR frame location
|
---|
130 | D SET^LAB G LA2
|
---|