LAEKT7 ;SLC/RWF - KODAK EKTACHEM 700 ROUTINE ;7/20/90  08:11 ;
 ;;5.2;AUTOMATED LAB INSTRUMENTS;**18,21**;Sep 27, 1994
 ;CROSS LINK BY ID OR IDE
LA1 S:$D(ZTQUEUED) ZTREQ="@" S LANM=$T(+0),TSK=$O(^LAB(62.4,"C",LANM,0)) Q:TSK<1
 Q:'$D(^LA(TSK,"I",0))
 D ^LASET Q:'TSK  S X="TRAP^"_LANM,@^%ZOSF("TRAP"),(ID,IDE)=0 S:'$D(LALCT) LALCT="" Q:LALCT="N"
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
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
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)
DA2 I LALCT="U" F I=0:0 S I=$O(^TMP("LA",$J,I)) Q:I<1  D
 .I ^TMP("LA",$J,I,4)=NM&($D(^TMP("LA",$J,I,2))) X ^(2)
 .I ^TMP("LA",$J,I,4)=NM,V<99999.99 S @^TMP("LA",$J,I,1)=V ;Param 3 has the report name.
 I LALCT'="U" F I=0:0 S I=$O(TC(I)) Q:I<1  D
 .I TC(I,4)=NM&($D(TC(I,2))) X TC(I,2)
 .I TC(I,4)=NM,V<99999.99 S @TC(I,1)=V
 Q
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
LA3 Q:ID=""  X LAGEN
 F I=0:0 S I=$O(TV(I)) Q:I<1  S:TV(I,1)]"" ^LAH(LWL,1,ISQN,I)=TV(I,1)
 S ID="" K TV
 Q
QC ;QC TESTING HERE; S BAD=1 IF DONT STORE
 S IN="!"_$P(IN,"!",2)
 S LATYPE=$E(IN,5)
 Q
NUM S X="" F JJ=1:1:$L(V) S:$A(V,JJ)>32 X=X_$E(V,JJ)
 S V=X Q
IN S CNT=^LA(TSK,"I",0)+1 IF '$D(^(CNT)) S TOUT=TOUT+1 Q:TOUT>9  H 5 G IN
 S ^LA(TSK,"I",0)=CNT,IN=^(CNT),TOUT=0
 S:IN["~" CTRL=$P(IN,"~",2),IN=$P(IN,"~",1)
 Q
QUIT LOCK ^LA(TSK) I (^LA(TSK,"I"))'=(^LA(TSK,"I",0)) S TOUT=0 L  G LA2
 H 1 K ^LA(TSK),^LA("LOCK",TSK),^TMP($J),^TMP("LA",$J) L
 Q
TRAP D ^LABERR S T=TSK D SET^LAB G @("LA2^"_LANM) ;ERROR TRAP
 
--- Routine Detail   --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HLAEKT7   1715     printed  Sep 23, 2025@19:18:18                                                                                                                                                                                                      Page 2
LAEKT7    ;SLC/RWF - KODAK EKTACHEM 700 ROUTINE ;7/20/90  08:11 ;
 +1       ;;5.2;AUTOMATED LAB INSTRUMENTS;**18,21**;Sep 27, 1994
 +2       ;CROSS LINK BY ID OR IDE
LA1        if $DATA(ZTQUEUED)
               SET ZTREQ="@"
           SET LANM=$TEXT(+0)
           SET TSK=$ORDER(^LAB(62.4,"C",LANM,0))
           if TSK<1
               QUIT 
 +1        if '$DATA(^LA(TSK,"I",0))
               QUIT 
 +2        DO ^LASET
           if 'TSK
               QUIT 
           SET X="TRAP^"_LANM
           SET @^%ZOSF("TRAP")
           SET (ID,IDE)=0
           if '$DATA(LALCT)
               SET LALCT=""
           if LALCT="N"
               QUIT 
LA2        SET TOUT=0
           DO IN
           if TOUT
               GOTO QUIT
           if IN'["!"
               GOTO LA2
           DO QC
           if LATYPE="a"
               DO HDR
           if LATYPE="f"
               DO DATA
           if LATYPE="g"
               DO CALC
           if LATYPE="h"
               DO LA3
           GOTO LA2
HDR        SET V=$EXTRACT(IN,30,44)
           DO NUM
           SET (ID,IDE)=+V
           SET V=$EXTRACT(IN,47,48)
           DO NUM
           SET CUP=+V
           SET V=$EXTRACT(IN,49,63)
           DO NUM
           SET TRAY=+V
           KILL TV
           QUIT 
DATA       SET V=$EXTRACT(IN,6,9)
           DO NUM
           SET NM=V
           SET V=$EXTRACT(IN,10,17)
           DO NUM
           if $EXTRACT(IN,26)>2&($EXTRACT(IN,26)<7)!($EXTRACT(IN,27)#2)
               QUIT 
DA2        IF LALCT="U"
               FOR I=0:0
                   SET I=$ORDER(^TMP("LA",$JOB,I))
                   if I<1
                       QUIT 
                   Begin DoDot:1
 +1                    IF ^TMP("LA",$JOB,I,4)=NM&($DATA(^TMP("LA",$JOB,I,2)))
                           XECUTE ^(2)
 +2       ;Param 3 has the report name.
                       IF ^TMP("LA",$JOB,I,4)=NM
                           IF V<99999.99
                               SET @^TMP("LA",$JOB,I,1)=V
                   End DoDot:1
 +3        IF LALCT'="U"
               FOR I=0:0
                   SET I=$ORDER(TC(I))
                   if I<1
                       QUIT 
                   Begin DoDot:1
 +4                    IF TC(I,4)=NM&($DATA(TC(I,2)))
                           XECUTE TC(I,2)
 +5                    IF TC(I,4)=NM
                           IF V<99999.99
                               SET @TC(I,1)=V
                   End DoDot:1
 +6        QUIT 
CALC       SET V=$EXTRACT(IN,6,9)
           DO NUM
           SET NM=V
           SET V=$EXTRACT(IN,10,18)
           DO NUM
           if $EXTRACT(IN,27)>2
               QUIT 
           GOTO DA2
LA3        if ID=""
               QUIT 
           XECUTE LAGEN
 +1        FOR I=0:0
               SET I=$ORDER(TV(I))
               if I<1
                   QUIT 
               if TV(I,1)]""
                   SET ^LAH(LWL,1,ISQN,I)=TV(I,1)
 +2        SET ID=""
           KILL TV
 +3        QUIT 
QC        ;QC TESTING HERE; S BAD=1 IF DONT STORE
 +1        SET IN="!"_$PIECE(IN,"!",2)
 +2        SET LATYPE=$EXTRACT(IN,5)
 +3        QUIT 
NUM        SET X=""
           FOR JJ=1:1:$LENGTH(V)
               if $ASCII(V,JJ)>32
                   SET X=X_$EXTRACT(V,JJ)
 +1        SET V=X
           QUIT 
IN         SET CNT=^LA(TSK,"I",0)+1
           IF '$DATA(^(CNT))
               SET TOUT=TOUT+1
               if TOUT>9
                   QUIT 
               HANG 5
               GOTO IN
 +1        SET ^LA(TSK,"I",0)=CNT
           SET IN=^(CNT)
           SET TOUT=0
 +2        if IN["~"
               SET CTRL=$PIECE(IN,"~",2)
               SET IN=$PIECE(IN,"~",1)
 +3        QUIT 
QUIT       LOCK ^LA(TSK)
           IF (^LA(TSK,"I"))'=(^LA(TSK,"I",0))
               SET TOUT=0
               LOCK 
               GOTO LA2
 +1        HANG 1
           KILL ^LA(TSK),^LA("LOCK",TSK),^TMP($JOB),^TMP("LA",$JOB)
           LOCK 
 +2        QUIT 
TRAP      ;ERROR TRAP
           DO ^LABERR
           SET T=TSK
           DO SET^LAB
           GOTO @("LA2^"_LANM)