LRSORC1 ;SLC/RWF/DALISC/JBM - CRITICAL VALUE REPORT ;JUL 06, 2010 3:14 PM;
;;5.2;LAB SERVICE;**153,344,1027**;NOV 01, 1997
EN ;
BUILD ;
S LRPDT=LREDT-.000001
F S LRPDT=$O(^LRO(69,LRPDT)) Q:('LRPDT)!(LRPDT>LRSDT)!(LREND=1) D
.S LRLLOC=""
.F S LRLLOC=$O(^LRO(69,LRPDT,1,"AN",LRLLOC)) Q:LRLLOC="" D
..S LRDFN=0
..F S LRDFN=$O(^LRO(69,LRPDT,1,"AN",LRLLOC,LRDFN)) Q:'LRDFN D LRIDT
Q
LRIDT ;
S LRIDT=0,LRSPEC=0
F S LRIDT=$O(^LRO(69,LRPDT,1,"AN",LRLLOC,LRDFN,LRIDT)) Q:'LRIDT D LOOK
Q
LOOK ;
N LR63RLO,LR63RHI,LR63CLO,LR63CHI,LR63TLO,LR63THI,LR63DAT,PC5,LRFLAG
K T S L0=$G(^LR(LRDFN,"CH",LRIDT,0)) Q:'$L(L0)
S LRSPEC=$P(L0,"^",5)
I LRAA S LRAAA=$P($P(L0,U,6)," ") Q:'$L(LRAAA) Q:'$D(LRAA(LRAAA))#2
S T=0,I=1
F S I=$O(^LR(LRDFN,"CH",LRIDT,I)) Q:LREND!(I<1) D
.I $P(^LR(LRDFN,"CH",LRIDT,I),U,2)["*" D
..S T=T+1,T(I)=^LR(LRDFN,"CH",LRIDT,I)
..I $G(LRFLAG)="" D
...I $G(^LR(LRDFN,"CH",LRIDT,"NPC"))>1,$P(T(I),U,5,12)'="" S LRFLAG=1 Q
...S LRFLAG=0
I T D
.S X=^LR(LRDFN,0)
.S LRDPF=$P(X,U,2),DFN=$P(X,U,3)
.I LRPTS Q:'$D(LRPTS(DFN))
.D PT^LRX
.S LRLOC=LRLLOC
.;S LRLOC=$S($D(^DPT(DFN,.1)):^(.1),1:LRLLOC)
.I LRLCS Q:'$D(LRLCS(LRLLOC))
.S LRDAT=$P(^LR(LRDFN,"CH",LRIDT,0),U),LRSPEC=$P(^(0),U,5)
.; S LRSUB1=$S(LRSRT="P":PNM_SSN,1:LRLOC)
.S LRSUB1=$S(LRSRT="P":PNM_HRCN,1:LRLOC) ;IHS/ANMC/CLS 08/18/96
.; S LRSUB2=$S(LRSRT="P":LRDAT,1:PNM_SSN)
.S LRSUB2=$S(LRSRT="P":LRDAT,1:PNM_HRCN) ;IHS/ANMC/CLS 08/18/96
.S LRSUB3=$S(LRSRT="P":LRLOC,1:LRDAT)
.S LRAN=$P(L0,U,6)
.K %DT S X=$P(L0,U),%DT="XT" D ^%DT,DD^LRX S LRSPDAT=Y
.; S ^TMP("LR",$J,LRSUB1,LRSUB2,LRSUB3,LRAN)=PNM_U_SSN_U_LRLOC_U_LRDPF_U_LRSPDAT_U_LRSPEC
.S ^TMP("LR",$J,LRSUB1,LRSUB2,LRSUB3,LRAN)=PNM_U_HRCN_U_LRLOC_U_LRDPF_U_LRSPDAT_U_LRSPEC ;IHS/ANMC/CLS 08/18/96
.S I=0
.F S I=$O(T(I)) Q:LREND!(I<1) D
..S LRTX=$O(^LAB(60,"C","CH;"_I_";1",0))
..I LRTX>0 D
...S LRTST=$P(^LAB(60,LRTX,0),U),LRTVAL=$P(T(I),U)
...S LRCRTFLG=$P(T(I),U,2)
...I $G(LRFLAG) D GET63
...S ^TMP("LR",$J,LRSUB1,LRSUB2,LRSUB3,LRAN,"TST",I)=LRTST_U_LRTVAL_U_LRCRTFLG_U_LRSPEC_U_LRTX_U_$G(LRFLAG)_$S($G(LRFLAG):LR63DAT,1:"")
.S C=0
.F S C=$O(^LR(LRDFN,"CH",LRIDT,1,C)) Q:'C D
..S ^TMP("LR",$J,LRSUB1,LRSUB2,LRSUB3,LRAN,"COM",C)=^LR(LRDFN,"CH",LRIDT,1,C,0)
Q
;
GET63 ; get ranges from file 63 (T(I)) if they are stored there
S PC5=$P(T(I),U,5)
S LR63RLO=$P(PC5,"!",2)
S LR63RHI=$P(PC5,"!",3)
S LR63CLO=$P(PC5,"!",4)
S LR63CHI=$P(PC5,"!",5)
S LR63TLO=$P(PC5,"!",11)
S LR63THI=$P(PC5,"!",12)
S LR63DAT=U_LR63RLO_U_LR63RHI_U_LR63CLO_U_LR63CHI_U_LR63TLO_U_LR63THI
Q
LRSORC1 ;SLC/RWF/DALISC/JBM - CRITICAL VALUE REPORT ;JUL 06, 2010 3:14 PM;
+1 ;;5.2;LAB SERVICE;**153,344,1027**;NOV 01, 1997
EN ;
BUILD ;
+1 SET LRPDT=LREDT-.000001
+2 FOR
SET LRPDT=$ORDER(^LRO(69,LRPDT))
IF ('LRPDT)!(LRPDT>LRSDT)!(LREND=1)
QUIT
Begin DoDot:1
+3 SET LRLLOC=""
+4 FOR
SET LRLLOC=$ORDER(^LRO(69,LRPDT,1,"AN",LRLLOC))
IF LRLLOC=""
QUIT
Begin DoDot:2
+5 SET LRDFN=0
+6 FOR
SET LRDFN=$ORDER(^LRO(69,LRPDT,1,"AN",LRLLOC,LRDFN))
IF 'LRDFN
QUIT
DO LRIDT
End DoDot:2
End DoDot:1
+7 QUIT
LRIDT ;
+1 SET LRIDT=0
SET LRSPEC=0
+2 FOR
SET LRIDT=$ORDER(^LRO(69,LRPDT,1,"AN",LRLLOC,LRDFN,LRIDT))
IF 'LRIDT
QUIT
DO LOOK
+3 QUIT
LOOK ;
+1 NEW LR63RLO,LR63RHI,LR63CLO,LR63CHI,LR63TLO,LR63THI,LR63DAT,PC5,LRFLAG
+2 KILL T
SET L0=$GET(^LR(LRDFN,"CH",LRIDT,0))
IF '$LENGTH(L0)
QUIT
+3 SET LRSPEC=$PIECE(L0,"^",5)
+4 IF LRAA
SET LRAAA=$PIECE($PIECE(L0,U,6)," ")
IF '$LENGTH(LRAAA)
QUIT
IF '$DATA(LRAA(LRAAA))#2
QUIT
+5 SET T=0
SET I=1
+6 FOR
SET I=$ORDER(^LR(LRDFN,"CH",LRIDT,I))
IF LREND!(I<1)
QUIT
Begin DoDot:1
+7 IF $PIECE(^LR(LRDFN,"CH",LRIDT,I),U,2)["*"
Begin DoDot:2
+8 SET T=T+1
SET T(I)=^LR(LRDFN,"CH",LRIDT,I)
+9 IF $GET(LRFLAG)=""
Begin DoDot:3
+10 IF $GET(^LR(LRDFN,"CH",LRIDT,"NPC"))>1
IF $PIECE(T(I),U,5,12)'=""
SET LRFLAG=1
QUIT
+11 SET LRFLAG=0
End DoDot:3
End DoDot:2
End DoDot:1
+12 IF T
Begin DoDot:1
+13 SET X=^LR(LRDFN,0)
+14 SET LRDPF=$PIECE(X,U,2)
SET DFN=$PIECE(X,U,3)
+15 IF LRPTS
IF '$DATA(LRPTS(DFN))
QUIT
+16 DO PT^LRX
+17 SET LRLOC=LRLLOC
+18 ;S LRLOC=$S($D(^DPT(DFN,.1)):^(.1),1:LRLLOC)
+19 IF LRLCS
IF '$DATA(LRLCS(LRLLOC))
QUIT
+20 SET LRDAT=$PIECE(^LR(LRDFN,"CH",LRIDT,0),U)
SET LRSPEC=$PIECE(^(0),U,5)
+21 ; S LRSUB1=$S(LRSRT="P":PNM_SSN,1:LRLOC)
+22 ;IHS/ANMC/CLS 08/18/96
SET LRSUB1=$SELECT(LRSRT="P":PNM_HRCN,1:LRLOC)
+23 ; S LRSUB2=$S(LRSRT="P":LRDAT,1:PNM_SSN)
+24 ;IHS/ANMC/CLS 08/18/96
SET LRSUB2=$SELECT(LRSRT="P":LRDAT,1:PNM_HRCN)
+25 SET LRSUB3=$SELECT(LRSRT="P":LRLOC,1:LRDAT)
+26 SET LRAN=$PIECE(L0,U,6)
+27 KILL %DT
SET X=$PIECE(L0,U)
SET %DT="XT"
DO ^%DT
DO DD^LRX
SET LRSPDAT=Y
+28 ; S ^TMP("LR",$J,LRSUB1,LRSUB2,LRSUB3,LRAN)=PNM_U_SSN_U_LRLOC_U_LRDPF_U_LRSPDAT_U_LRSPEC
+29 ;IHS/ANMC/CLS 08/18/96
SET ^TMP("LR",$JOB,LRSUB1,LRSUB2,LRSUB3,LRAN)=PNM_U_HRCN_U_LRLOC_U_LRDPF_U_LRSPDAT_U_LRSPEC
+30 SET I=0
+31 FOR
SET I=$ORDER(T(I))
IF LREND!(I<1)
QUIT
Begin DoDot:2
+32 SET LRTX=$ORDER(^LAB(60,"C","CH;"_I_";1",0))
+33 IF LRTX>0
Begin DoDot:3
+34 SET LRTST=$PIECE(^LAB(60,LRTX,0),U)
SET LRTVAL=$PIECE(T(I),U)
+35 SET LRCRTFLG=$PIECE(T(I),U,2)
+36 IF $GET(LRFLAG)
DO GET63
+37 SET ^TMP("LR",$JOB,LRSUB1,LRSUB2,LRSUB3,LRAN,"TST",I)=LRTST_U_LRTVAL_U_LRCRTFLG_U_LRSPEC_U_LRTX_U_$GET(LRFLAG)_$SELECT($GET(LRFLAG):LR63DAT,1:"")
End DoDot:3
End DoDot:2
+38 SET C=0
+39 FOR
SET C=$ORDER(^LR(LRDFN,"CH",LRIDT,1,C))
IF 'C
QUIT
Begin DoDot:2
+40 SET ^TMP("LR",$JOB,LRSUB1,LRSUB2,LRSUB3,LRAN,"COM",C)=^LR(LRDFN,"CH",LRIDT,1,C,0)
End DoDot:2
End DoDot:1
+41 QUIT
+42 ;
GET63 ; get ranges from file 63 (T(I)) if they are stored there
+1 SET PC5=$PIECE(T(I),U,5)
+2 SET LR63RLO=$PIECE(PC5,"!",2)
+3 SET LR63RHI=$PIECE(PC5,"!",3)
+4 SET LR63CLO=$PIECE(PC5,"!",4)
+5 SET LR63CHI=$PIECE(PC5,"!",5)
+6 SET LR63TLO=$PIECE(PC5,"!",11)
+7 SET LR63THI=$PIECE(PC5,"!",12)
+8 SET LR63DAT=U_LR63RLO_U_LR63RHI_U_LR63CLO_U_LR63CHI_U_LR63TLO_U_LR63THI
+9 QUIT