| [613] | 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
 | 
|---|