| [613] | 1 | LAEKT7 ;SLC/RWF - KODAK EKTACHEM 700 ROUTINE ;7/20/90  08:11 ;
 | 
|---|
 | 2 |  ;;5.2;AUTOMATED LAB INSTRUMENTS;**18,21**;Sep 27, 1994
 | 
|---|
 | 3 |  ;CROSS LINK BY ID OR IDE
 | 
|---|
 | 4 | LA1 S:$D(ZTQUEUED) ZTREQ="@" S LANM=$T(+0),TSK=$O(^LAB(62.4,"C",LANM,0)) Q:TSK<1
 | 
|---|
 | 5 |  Q:'$D(^LA(TSK,"I",0))
 | 
|---|
 | 6 |  D ^LASET Q:'TSK  S X="TRAP^"_LANM,@^%ZOSF("TRAP"),(ID,IDE)=0 S:'$D(LALCT) LALCT="" Q:LALCT="N"
 | 
|---|
 | 7 | LA2 S TOUT=0 D IN G QUIT:TOUT,LA2:IN'["!" D QC,HDR:LATYPE="a",DATA:LATYPE="f",CALC:LATYPE="g",LA3:LATYPE="h" G LA2
 | 
|---|
 | 8 | HDR S V=$E(IN,30,44) D NUM S (ID,IDE)=+V,V=$E(IN,47,48) D NUM S CUP=+V,V=$E(IN,49,63) D NUM S TRAY=+V K TV Q
 | 
|---|
 | 9 | DATA S V=$E(IN,6,9) D NUM S NM=V,V=$E(IN,10,17) D NUM Q:$E(IN,26)>2&($E(IN,26)<7)!($E(IN,27)#2)
 | 
|---|
 | 10 | DA2 I LALCT="U" F I=0:0 S I=$O(^TMP("LA",$J,I)) Q:I<1  D
 | 
|---|
 | 11 |  .I ^TMP("LA",$J,I,4)=NM&($D(^TMP("LA",$J,I,2))) X ^(2)
 | 
|---|
 | 12 |  .I ^TMP("LA",$J,I,4)=NM,V<99999.99 S @^TMP("LA",$J,I,1)=V ;Param 3 has the report name.
 | 
|---|
 | 13 |  I LALCT'="U" F I=0:0 S I=$O(TC(I)) Q:I<1  D
 | 
|---|
 | 14 |  .I TC(I,4)=NM&($D(TC(I,2))) X TC(I,2)
 | 
|---|
 | 15 |  .I TC(I,4)=NM,V<99999.99 S @TC(I,1)=V
 | 
|---|
 | 16 |  Q
 | 
|---|
 | 17 | CALC S V=$E(IN,6,9) D NUM S NM=V,V=$E(IN,10,18) D NUM Q:$E(IN,27)>2  G DA2
 | 
|---|
 | 18 | LA3 Q:ID=""  X LAGEN
 | 
|---|
 | 19 |  F I=0:0 S I=$O(TV(I)) Q:I<1  S:TV(I,1)]"" ^LAH(LWL,1,ISQN,I)=TV(I,1)
 | 
|---|
 | 20 |  S ID="" K TV
 | 
|---|
 | 21 |  Q
 | 
|---|
 | 22 | QC ;QC TESTING HERE; S BAD=1 IF DONT STORE
 | 
|---|
 | 23 |  S IN="!"_$P(IN,"!",2)
 | 
|---|
 | 24 |  S LATYPE=$E(IN,5)
 | 
|---|
 | 25 |  Q
 | 
|---|
 | 26 | NUM S X="" F JJ=1:1:$L(V) S:$A(V,JJ)>32 X=X_$E(V,JJ)
 | 
|---|
 | 27 |  S V=X Q
 | 
|---|
 | 28 | IN S CNT=^LA(TSK,"I",0)+1 IF '$D(^(CNT)) S TOUT=TOUT+1 Q:TOUT>9  H 5 G IN
 | 
|---|
 | 29 |  S ^LA(TSK,"I",0)=CNT,IN=^(CNT),TOUT=0
 | 
|---|
 | 30 |  S:IN["~" CTRL=$P(IN,"~",2),IN=$P(IN,"~",1)
 | 
|---|
 | 31 |  Q
 | 
|---|
 | 32 | QUIT LOCK ^LA(TSK) I (^LA(TSK,"I"))'=(^LA(TSK,"I",0)) S TOUT=0 L  G LA2
 | 
|---|
 | 33 |  H 1 K ^LA(TSK),^LA("LOCK",TSK),^TMP($J),^TMP("LA",$J) L
 | 
|---|
 | 34 |  Q
 | 
|---|
 | 35 | TRAP D ^LABERR S T=TSK D SET^LAB G @("LA2^"_LANM) ;ERROR TRAP
 | 
|---|