Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: LR7OF4

LR7OF4.m

Go to the documentation of this file.
  1. LR7OF4 ;slc/dcm - Process messages from OE/RR ;8/11/97
  1. ;;5.2T9;LR;**1018**;Nov 17, 2004
  1. ;;5.2;LAB SERVICE;**121,187**;Sep 27, 1994
  1. PURG ;Process Purge request for OBR Segment
  1. N TST,X,LRODT,LRSN,LRORD,LRORIFN,STARTDT,LRDUZ,PROV,REASON,QUANT,LREND
  1. S LREND=0
  1. D GET^LR7OF2(.LRXORC,LRXORC) Q:LREND
  1. I 'LRVERZ S LRODT=0 F S LRODT=$O(^LRO(69,"C",LRORD,LRODT)) Q:LRODT<1 S LRSN=0 F S LRSN=$O(^LRO(69,"C",LRORD,LRODT,LRSN)) Q:LRSN<1 D Q
  1. . S X=$P($P(LRXMSG,"|",5),"^",4) I X S TST=$O(^LRO(69,LRODT,1,LRSN,2,"B",X,0)) I TST D P1(LRODT,LRSN,TST) Q:LREND
  1. I LRVERZ,$D(^LRO(69,LRODT,1,LRSN,0)) S X=$P($P(LRXMSG,"|",5),"^",4) I X S TST=$O(^LRO(69,LRODT,1,LRSN,2,"B",X,0)) I TST D P1(LRODT,LRSN,TST) Q:LREND
  1. I LREND D ACK^LR7OF0("ZU",LRXORC) Q
  1. D ACK^LR7OF0("ZR",LRXORC)
  1. Q
  1. P1(LRODT,LRSN,TST) ;Check to purge
  1. N X
  1. I '$D(^LRO(69,LRODT,1,LRSN,0)) Q
  1. S X=+^LRO(69,LRODT,1,LRSN,0) I $D(^LR(X,0)),$P(X,"^",2)'=2 G P2
  1. I '$D(^LRO(69,LRODT,1,LRSN,1)) S LREND=1 Q
  1. I $D(^LRO(69,LRODT,1,LRSN,3)),'$L($P(^(3),"^",2)) S LREND=1 Q
  1. P2 S:$D(^LRO(69,LRODT,1,LRSN,2,TST,0)) $P(^(0),"^",7)="P" ;P=flag for purged
  1. Q
  1. PURG1 ;Process Purge request for ORC Segment
  1. N X,I,STOP S X=$P(LRXORC,"|",4),STOP=0
  1. S I=LINE F S I=$O(MSG(I)) Q:I<1 I $P(MSG(I),"|")="OBR" S STOP=1 Q
  1. Q:STOP
  1. I $L(X,"^")>5 D ACK^LR7OF0("ZR",LRXORC) Q ;Old unreleased 2.5 order
  1. I +X#1 D ACK^LR7OF0("ZR",LRXORC) Q ;Old ORGY 2.5
  1. I +X,$P(X,"^",2),$P(X,"^",3) D ACK^LR7OF0("ZR",LRXORC) Q ;Old unconverted 2.5
  1. I +X,$P(X,"^",2)="LRCH" D PURG Q ;3.0 order with no tests (early tuscaloosa days)
  1. I 'X D ACK^LR7OF0("ZR",LRXORC) Q ;Order with no lab pointers
  1. D ACK^LR7OF0("DE",LRXORC,"Unrecognized ID's :"_$P(LRXORC,"|",4))
  1. Q