OCXOZ0E ;SLC/RJS,CLA - Order Check Scan ;JUL 23,2025 at 13:11
 ;;3.0;ORDER ENTRY/RESULTS REPORTING;**32,221,243**;Dec 17,1997;Build 242
 ;;  ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
 ;
 ; ***************************************************************
 ; ** Warning: This routine is automatically generated by the   **
 ; ** Rule Compiler (^OCXOCMP) and ANY changes to this routine  **
 ; ** will be lost the next time the rule compiler executes.    **
 ; ***************************************************************
 ;
 Q
 ;
CHK428 ; Look through the current environment for valid Event/Elements for this patient.
 ;  Called from CHK195+15^OCXOZ09.
 ;
 Q:$G(OCXOERR)
 ;
 ;    Local CHK428 Variables
 ; OCXDF(37) ---> Data Field: PATIENT IEN (NUMERIC)
 ; OCXDF(58) ---> Data Field: ABNORMAL RENAL BIOCHEM RESULTS (FREE TEXT)
 ; OCXDF(154) --> Data Field: RECENT CONTRAST MEDIA CREATININE DAYS (NUMERIC)
 ;
 ;      Local Extrinsic Functions
 ; ABREN( -----------> DETERMINE IF RENAL LAB RESULTS ARE ABNORMAL HIGH OR LOW
 ; FILE(DFN,130, ----> FILE DATA IN PATIENT ACTIVE DATA FILE  (Event/Element: CONTRAST MEDIA ORDER)
 ;
 S OCXDF(58)=$P($$ABREN(OCXDF(37)),"^",2),OCXDF(154)=$P($$CMCDAYS^ORKRA(OCXDF(37)),"^",1),OCXOERR=$$FILE(DFN,130,"58,154") Q:OCXOERR 
 Q
 ;
CHK433 ; Look through the current environment for valid Event/Elements for this patient.
 ;  Called from CHK1+36^OCXOZ02.
 ;
 Q:$G(OCXOERR)
 ;
 ;    Local CHK433 Variables
 ; OCXDF(12) ---> Data Field: LAB RESULT (FREE TEXT)
 ; OCXDF(34) ---> Data Field: ORDER NUMBER (NUMERIC)
 ; OCXDF(37) ---> Data Field: PATIENT IEN (NUMERIC)
 ; OCXDF(96) ---> Data Field: ORDERABLE ITEM NAME (FREE TEXT)
 ; OCXDF(113) --> Data Field: LAB TEST ID (NUMERIC)
 ; OCXDF(150) --> Data Field: LAB RESULT < THRESHOLD (BOOLEAN)
 ; OCXDF(151) --> Data Field: LAB RESULT > THRESHOLD (BOOLEAN)
 ; OCXDF(152) --> Data Field: LAB SPECIMEN ID (NUMERIC)
 ;
 ;      Local Extrinsic Functions
 ; LABTHRSB( --------> LAB THRESHOLD EXCEEDED BOOLEAN
 ; ORDITEM( ---------> GET ORDERABLE ITEM FROM ORDER NUMBER
 ;
 S OCXDF(151)=$P($$LABTHRSB(OCXDF(113),OCXDF(152),OCXDF(12),">"),"^",1) I $L(OCXDF(151)),(OCXDF(151)),$L(OCXDF(34)) S OCXDF(96)=$$ORDITEM(OCXDF(34)) I $L(OCXDF(37)) D CHK439
 S OCXDF(150)=$P($$LABTHRSB(OCXDF(113),OCXDF(152),OCXDF(12),"<"),"^",1) I $L(OCXDF(150)),(OCXDF(150)),$L(OCXDF(34)) S OCXDF(96)=$$ORDITEM(OCXDF(34)) I $L(OCXDF(37)) D CHK446
 Q
 ;
CHK439 ; Look through the current environment for valid Event/Elements for this patient.
 ;  Called from CHK433+19.
 ;
 Q:$G(OCXOERR)
 ;
 ;    Local CHK439 Variables
 ; OCXDF(37) ---> Data Field: PATIENT IEN (NUMERIC)
 ; OCXDF(147) --> Data Field: PATIENT LOCATION (FREE TEXT)
 ;
 ;      Local Extrinsic Functions
 ; FILE(DFN,131, ----> FILE DATA IN PATIENT ACTIVE DATA FILE  (Event/Element: GREATER THAN LAB THRESHOLD)
 ; PATLOC( ----------> PATIENT LOCATION
 ;
 S OCXDF(147)=$P($$PATLOC(OCXDF(37)),"^",2),OCXOERR=$$FILE(DFN,131,"12,37,96,113,147,152") Q:OCXOERR 
 Q
 ;
CHK446 ; Look through the current environment for valid Event/Elements for this patient.
 ;  Called from CHK433+20.
 ;
 Q:$G(OCXOERR)
 ;
 ;    Local CHK446 Variables
 ; OCXDF(37) ---> Data Field: PATIENT IEN (NUMERIC)
 ; OCXDF(147) --> Data Field: PATIENT LOCATION (FREE TEXT)
 ;
 ;      Local Extrinsic Functions
 ; FILE(DFN,132, ----> FILE DATA IN PATIENT ACTIVE DATA FILE  (Event/Element: LESS THAN LAB THRESHOLD)
 ; PATLOC( ----------> PATIENT LOCATION
 ;
 S OCXDF(147)=$P($$PATLOC(OCXDF(37)),"^",2),OCXOERR=$$FILE(DFN,132,"12,37,96,113,147,152") Q:OCXOERR 
 Q
 ;
CHK452 ; Look through the current environment for valid Event/Elements for this patient.
 ;  Called from CHK416+17^OCXOZ0D.
 ;
 Q:$G(OCXOERR)
 ;
 ;    Local CHK452 Variables
 ; OCXDF(37) ---> Data Field: PATIENT IEN (NUMERIC)
 ; OCXDF(58) ---> Data Field: ABNORMAL RENAL BIOCHEM RESULTS (FREE TEXT)
 ;
 ;      Local Extrinsic Functions
 ; ABREN( -----------> DETERMINE IF RENAL LAB RESULTS ARE ABNORMAL HIGH OR LOW
 ; FILE(DFN,133, ----> FILE DATA IN PATIENT ACTIVE DATA FILE  (Event/Element: NO CREAT RESULTS W/IN X DAYS)
 ;
 S OCXDF(58)=$P($$ABREN(OCXDF(37)),"^",2),OCXOERR=$$FILE(DFN,133,"58,154") Q:OCXOERR 
 Q
 ;
ABREN(DFN) ;  Compiler Function: DETERMINE IF RENAL LAB RESULTS ARE ABNORMAL HIGH OR LOW
 ;
 N OCXFLAG,OCXVAL,OCXLIST,OCXTEST,UNAV,OCXTLIST,OCXTERM,OCXSLIST,OCXSPEC
 S (OCXLIST,OCXTLIST)="",UNAV="0^<Unavailable>"
 S OCXSLIST="" Q:'$$TERMLKUP("SERUM SPECIMEN",.OCXSLIST) UNAV
 F OCXTERM="SERUM CREATININE","SERUM UREA NITROGEN" D  Q:($L(OCXLIST)>130)
 .Q:'$$TERMLKUP(OCXTERM,.OCXTLIST)
 .S OCXTEST=0 F  S OCXTEST=$O(OCXTLIST(OCXTEST)) Q:'OCXTEST  D  Q:($L(OCXLIST)>130)
 ..S OCXSPEC=0 F  S OCXSPEC=$O(OCXSLIST(OCXSPEC)) Q:'OCXSPEC  D  Q:($L(OCXLIST)>130)
 ...S OCXVAL=$$LOCL^ORQQLR1(DFN,OCXTEST,OCXSPEC),OCXFLAG=$P(OCXVAL,U,5)
 ...I $L(OCXVAL),((OCXFLAG["H")!(OCXFLAG["L")) D 
 ....N OCXY S OCXY=""
 ....S OCXY=$P(OCXVAL,U,2)_": "_$P(OCXVAL,U,3)_" "_$P(OCXVAL,U,4)
 ....S OCXY=OCXY_" "_$S($L(OCXFLAG):"["_OCXFLAG_"]",1:"")
 ....S OCXY=OCXY_" "_$$FMTE^XLFDT($P(OCXVAL,U,7),"2P")
 ....S:$L(OCXLIST) OCXLIST=OCXLIST_" " S OCXLIST=OCXLIST_OCXY
 Q:'$L(OCXLIST) UNAV  Q 1_U_OCXLIST
 ;  
 ;
FILE(DFN,OCXELE,OCXDFL) ;     This Local Extrinsic Function logs a validated event/element.
 ;
 N OCXTIMN,OCXTIML,OCXTIMT1,OCXTIMT2,OCXDATA,OCXPC,OCXPC,OCXVAL,OCXSUB,OCXDFI
 S DFN=+$G(DFN),OCXELE=+$G(OCXELE)
 ;
 Q:'DFN 1 Q:'OCXELE 1 K OCXDATA
 ;
 S OCXDATA(DFN,OCXELE)=1
 F OCXPC=1:1:$L(OCXDFL,",") S OCXDFI=$P(OCXDFL,",",OCXPC) I OCXDFI D
 .S OCXVAL=$G(OCXDF(+OCXDFI)),OCXDATA(DFN,OCXELE,+OCXDFI)=OCXVAL
 ;
 M ^TMP("OCXCHK",$J,DFN)=OCXDATA(DFN)
 ;
 Q 0
 ;
LABTHRSB(OCXLAB,OCXSPEC,OCXRSLT,OCXOP)       ;  Compiler Function: LAB THRESHOLD EXCEEDED BOOLEAN
 ;
 S OCXRSLT=$TR($G(OCXRSLT),"<>=","")
 Q:'$G(OCXLAB)!'$G(OCXSPEC)!'$G(OCXRSLT)!'$L($G(OCXOP)) 0
 ;
 N OCXX,OCXPENT,OCXERR,OCXLABSP,OCXPVAL,OCXEXCD
 S OCXEXCD=0,OCXLABSP=OCXLAB_";"_OCXSPEC
 D ENVAL^XPAR(.OCXX,"ORB LAB "_OCXOP_" THRESHOLD",OCXLABSP,.OCXERR)
 Q:+$G(ORERR)'=0 OCXEXCD
 Q:+$G(OCXX)=0 OCXEXCD
 S OCXPENT="" F  S OCXPENT=$O(OCXX(OCXPENT)) Q:'OCXPENT!OCXEXCD=1  D
 .S OCXPVAL=OCXX(OCXPENT,OCXLABSP)
 .I $L(OCXPVAL) D
 ..I $P(OCXPENT,";",2)="VA(200,",@((+OCXRSLT)_OCXOP_OCXPVAL) D
 ...S OCXEXCD=1
 Q OCXEXCD
 ;
ORDITEM(OIEN) ;  Compiler Function: GET ORDERABLE ITEM FROM ORDER NUMBER
 Q:'$G(OIEN) ""
 ;
 N OITXT,X S OITXT=$$OI^ORQOR2(OIEN) Q:'OITXT "No orderable item found."
 S X=$G(^ORD(101.43,+OITXT,0)) Q:'$L(X) "No orderable item found."
 Q $P(X,U,1)
 ;
PATLOC(DFN) ;  Compiler Function: PATIENT LOCATION
 ;
 N OCXP1,OCXP2
 S OCXP1=$G(^TMP("OCXSWAP",$J,"OCXODATA","PV1",2))
 S OCXP2=$P($G(^TMP("OCXSWAP",$J,"OCXODATA","PV1",3)),"^",1)
 I OCXP2 D
 .S OCXP2=$P($G(^SC(+OCXP2,0)),"^",1,2)
 .I $L($P(OCXP2,"^",2)) S OCXP2=$P(OCXP2,"^",2)
 .E  S OCXP2=$P(OCXP2,"^",1)
 .S:'$L(OCXP2) OCXP2="NO LOC"
 I $L(OCXP1),$L(OCXP2) Q OCXP1_"^"_OCXP2
 ;
 S OCXP2=$G(^DPT(+$G(DFN),.1))
 I $L(OCXP2) Q "I^"_OCXP2
 Q "O^OUTPT"
 ;
TERMLKUP(OCXTERM,OCXLIST) ;
 Q $$TERM^OCXOZ01(OCXTERM,.OCXLIST)
 ;
 
--- Routine Detail   --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HOCXOZ0E   7177     printed  Sep 23, 2025@20:02:17                                                                                                                                                                                                     Page 2
OCXOZ0E   ;SLC/RJS,CLA - Order Check Scan ;JUL 23,2025 at 13:11
 +1       ;;3.0;ORDER ENTRY/RESULTS REPORTING;**32,221,243**;Dec 17,1997;Build 242
 +2       ;;  ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
 +3       ;
 +4       ; ***************************************************************
 +5       ; ** Warning: This routine is automatically generated by the   **
 +6       ; ** Rule Compiler (^OCXOCMP) and ANY changes to this routine  **
 +7       ; ** will be lost the next time the rule compiler executes.    **
 +8       ; ***************************************************************
 +9       ;
 +10       QUIT 
 +11      ;
CHK428    ; Look through the current environment for valid Event/Elements for this patient.
 +1       ;  Called from CHK195+15^OCXOZ09.
 +2       ;
 +3        if $GET(OCXOERR)
               QUIT 
 +4       ;
 +5       ;    Local CHK428 Variables
 +6       ; OCXDF(37) ---> Data Field: PATIENT IEN (NUMERIC)
 +7       ; OCXDF(58) ---> Data Field: ABNORMAL RENAL BIOCHEM RESULTS (FREE TEXT)
 +8       ; OCXDF(154) --> Data Field: RECENT CONTRAST MEDIA CREATININE DAYS (NUMERIC)
 +9       ;
 +10      ;      Local Extrinsic Functions
 +11      ; ABREN( -----------> DETERMINE IF RENAL LAB RESULTS ARE ABNORMAL HIGH OR LOW
 +12      ; FILE(DFN,130, ----> FILE DATA IN PATIENT ACTIVE DATA FILE  (Event/Element: CONTRAST MEDIA ORDER)
 +13      ;
 +14       SET OCXDF(58)=$PIECE($$ABREN(OCXDF(37)),"^",2)
           SET OCXDF(154)=$PIECE($$CMCDAYS^ORKRA(OCXDF(37)),"^",1)
           SET OCXOERR=$$FILE(DFN,130,"58,154")
           if OCXOERR
               QUIT 
 +15       QUIT 
 +16      ;
CHK433    ; Look through the current environment for valid Event/Elements for this patient.
 +1       ;  Called from CHK1+36^OCXOZ02.
 +2       ;
 +3        if $GET(OCXOERR)
               QUIT 
 +4       ;
 +5       ;    Local CHK433 Variables
 +6       ; OCXDF(12) ---> Data Field: LAB RESULT (FREE TEXT)
 +7       ; OCXDF(34) ---> Data Field: ORDER NUMBER (NUMERIC)
 +8       ; OCXDF(37) ---> Data Field: PATIENT IEN (NUMERIC)
 +9       ; OCXDF(96) ---> Data Field: ORDERABLE ITEM NAME (FREE TEXT)
 +10      ; OCXDF(113) --> Data Field: LAB TEST ID (NUMERIC)
 +11      ; OCXDF(150) --> Data Field: LAB RESULT < THRESHOLD (BOOLEAN)
 +12      ; OCXDF(151) --> Data Field: LAB RESULT > THRESHOLD (BOOLEAN)
 +13      ; OCXDF(152) --> Data Field: LAB SPECIMEN ID (NUMERIC)
 +14      ;
 +15      ;      Local Extrinsic Functions
 +16      ; LABTHRSB( --------> LAB THRESHOLD EXCEEDED BOOLEAN
 +17      ; ORDITEM( ---------> GET ORDERABLE ITEM FROM ORDER NUMBER
 +18      ;
 +19       SET OCXDF(151)=$PIECE($$LABTHRSB(OCXDF(113),OCXDF(152),OCXDF(12),">"),"^",1)
           IF $LENGTH(OCXDF(151))
               IF (OCXDF(151))
                   IF $LENGTH(OCXDF(34))
                       SET OCXDF(96)=$$ORDITEM(OCXDF(34))
                       IF $LENGTH(OCXDF(37))
                           DO CHK439
 +20       SET OCXDF(150)=$PIECE($$LABTHRSB(OCXDF(113),OCXDF(152),OCXDF(12),"<"),"^",1)
           IF $LENGTH(OCXDF(150))
               IF (OCXDF(150))
                   IF $LENGTH(OCXDF(34))
                       SET OCXDF(96)=$$ORDITEM(OCXDF(34))
                       IF $LENGTH(OCXDF(37))
                           DO CHK446
 +21       QUIT 
 +22      ;
CHK439    ; Look through the current environment for valid Event/Elements for this patient.
 +1       ;  Called from CHK433+19.
 +2       ;
 +3        if $GET(OCXOERR)
               QUIT 
 +4       ;
 +5       ;    Local CHK439 Variables
 +6       ; OCXDF(37) ---> Data Field: PATIENT IEN (NUMERIC)
 +7       ; OCXDF(147) --> Data Field: PATIENT LOCATION (FREE TEXT)
 +8       ;
 +9       ;      Local Extrinsic Functions
 +10      ; FILE(DFN,131, ----> FILE DATA IN PATIENT ACTIVE DATA FILE  (Event/Element: GREATER THAN LAB THRESHOLD)
 +11      ; PATLOC( ----------> PATIENT LOCATION
 +12      ;
 +13       SET OCXDF(147)=$PIECE($$PATLOC(OCXDF(37)),"^",2)
           SET OCXOERR=$$FILE(DFN,131,"12,37,96,113,147,152")
           if OCXOERR
               QUIT 
 +14       QUIT 
 +15      ;
CHK446    ; Look through the current environment for valid Event/Elements for this patient.
 +1       ;  Called from CHK433+20.
 +2       ;
 +3        if $GET(OCXOERR)
               QUIT 
 +4       ;
 +5       ;    Local CHK446 Variables
 +6       ; OCXDF(37) ---> Data Field: PATIENT IEN (NUMERIC)
 +7       ; OCXDF(147) --> Data Field: PATIENT LOCATION (FREE TEXT)
 +8       ;
 +9       ;      Local Extrinsic Functions
 +10      ; FILE(DFN,132, ----> FILE DATA IN PATIENT ACTIVE DATA FILE  (Event/Element: LESS THAN LAB THRESHOLD)
 +11      ; PATLOC( ----------> PATIENT LOCATION
 +12      ;
 +13       SET OCXDF(147)=$PIECE($$PATLOC(OCXDF(37)),"^",2)
           SET OCXOERR=$$FILE(DFN,132,"12,37,96,113,147,152")
           if OCXOERR
               QUIT 
 +14       QUIT 
 +15      ;
CHK452    ; Look through the current environment for valid Event/Elements for this patient.
 +1       ;  Called from CHK416+17^OCXOZ0D.
 +2       ;
 +3        if $GET(OCXOERR)
               QUIT 
 +4       ;
 +5       ;    Local CHK452 Variables
 +6       ; OCXDF(37) ---> Data Field: PATIENT IEN (NUMERIC)
 +7       ; OCXDF(58) ---> Data Field: ABNORMAL RENAL BIOCHEM RESULTS (FREE TEXT)
 +8       ;
 +9       ;      Local Extrinsic Functions
 +10      ; ABREN( -----------> DETERMINE IF RENAL LAB RESULTS ARE ABNORMAL HIGH OR LOW
 +11      ; FILE(DFN,133, ----> FILE DATA IN PATIENT ACTIVE DATA FILE  (Event/Element: NO CREAT RESULTS W/IN X DAYS)
 +12      ;
 +13       SET OCXDF(58)=$PIECE($$ABREN(OCXDF(37)),"^",2)
           SET OCXOERR=$$FILE(DFN,133,"58,154")
           if OCXOERR
               QUIT 
 +14       QUIT 
 +15      ;
ABREN(DFN) ;  Compiler Function: DETERMINE IF RENAL LAB RESULTS ARE ABNORMAL HIGH OR LOW
 +1       ;
 +2        NEW OCXFLAG,OCXVAL,OCXLIST,OCXTEST,UNAV,OCXTLIST,OCXTERM,OCXSLIST,OCXSPEC
 +3        SET (OCXLIST,OCXTLIST)=""
           SET UNAV="0^<Unavailable>"
 +4        SET OCXSLIST=""
           if '$$TERMLKUP("SERUM SPECIMEN",.OCXSLIST)
               QUIT UNAV
 +5        FOR OCXTERM="SERUM CREATININE","SERUM UREA NITROGEN"
               Begin DoDot:1
 +6                if '$$TERMLKUP(OCXTERM,.OCXTLIST)
                       QUIT 
 +7                SET OCXTEST=0
                   FOR 
                       SET OCXTEST=$ORDER(OCXTLIST(OCXTEST))
                       if 'OCXTEST
                           QUIT 
                       Begin DoDot:2
 +8                        SET OCXSPEC=0
                           FOR 
                               SET OCXSPEC=$ORDER(OCXSLIST(OCXSPEC))
                               if 'OCXSPEC
                                   QUIT 
                               Begin DoDot:3
 +9                                SET OCXVAL=$$LOCL^ORQQLR1(DFN,OCXTEST,OCXSPEC)
                                   SET OCXFLAG=$PIECE(OCXVAL,U,5)
 +10                               IF $LENGTH(OCXVAL)
                                       IF ((OCXFLAG["H")!(OCXFLAG["L"))
                                           Begin DoDot:4
 +11                                           NEW OCXY
                                               SET OCXY=""
 +12                                           SET OCXY=$PIECE(OCXVAL,U,2)_": "_$PIECE(OCXVAL,U,3)_" "_$PIECE(OCXVAL,U,4)
 +13                                           SET OCXY=OCXY_" "_$SELECT($LENGTH(OCXFLAG):"["_OCXFLAG_"]",1:"")
 +14                                           SET OCXY=OCXY_" "_$$FMTE^XLFDT($PIECE(OCXVAL,U,7),"2P")
 +15                                           if $LENGTH(OCXLIST)
                                                   SET OCXLIST=OCXLIST_" "
                                               SET OCXLIST=OCXLIST_OCXY
                                           End DoDot:4
                               End DoDot:3
                               if ($LENGTH(OCXLIST)>130)
                                   QUIT 
                       End DoDot:2
                       if ($LENGTH(OCXLIST)>130)
                           QUIT 
               End DoDot:1
               if ($LENGTH(OCXLIST)>130)
                   QUIT 
 +16       if '$LENGTH(OCXLIST)
               QUIT UNAV
           QUIT 1_U_OCXLIST
 +17      ;  
 +18      ;
FILE(DFN,OCXELE,OCXDFL) ;     This Local Extrinsic Function logs a validated event/element.
 +1       ;
 +2        NEW OCXTIMN,OCXTIML,OCXTIMT1,OCXTIMT2,OCXDATA,OCXPC,OCXPC,OCXVAL,OCXSUB,OCXDFI
 +3        SET DFN=+$GET(DFN)
           SET OCXELE=+$GET(OCXELE)
 +4       ;
 +5        if 'DFN
               QUIT 1
           if 'OCXELE
               QUIT 1
           KILL OCXDATA
 +6       ;
 +7        SET OCXDATA(DFN,OCXELE)=1
 +8        FOR OCXPC=1:1:$LENGTH(OCXDFL,",")
               SET OCXDFI=$PIECE(OCXDFL,",",OCXPC)
               IF OCXDFI
                   Begin DoDot:1
 +9                    SET OCXVAL=$GET(OCXDF(+OCXDFI))
                       SET OCXDATA(DFN,OCXELE,+OCXDFI)=OCXVAL
                   End DoDot:1
 +10      ;
 +11       MERGE ^TMP("OCXCHK",$JOB,DFN)=OCXDATA(DFN)
 +12      ;
 +13       QUIT 0
 +14      ;
LABTHRSB(OCXLAB,OCXSPEC,OCXRSLT,OCXOP) ;  Compiler Function: LAB THRESHOLD EXCEEDED BOOLEAN
 +1       ;
 +2        SET OCXRSLT=$TRANSLATE($GET(OCXRSLT),"<>=","")
 +3        if '$GET(OCXLAB)!'$GET(OCXSPEC)!'$GET(OCXRSLT)!'$LENGTH($GET(OCXOP))
               QUIT 0
 +4       ;
 +5        NEW OCXX,OCXPENT,OCXERR,OCXLABSP,OCXPVAL,OCXEXCD
 +6        SET OCXEXCD=0
           SET OCXLABSP=OCXLAB_";"_OCXSPEC
 +7        DO ENVAL^XPAR(.OCXX,"ORB LAB "_OCXOP_" THRESHOLD",OCXLABSP,.OCXERR)
 +8        if +$GET(ORERR)'=0
               QUIT OCXEXCD
 +9        if +$GET(OCXX)=0
               QUIT OCXEXCD
 +10       SET OCXPENT=""
           FOR 
               SET OCXPENT=$ORDER(OCXX(OCXPENT))
               if 'OCXPENT!OCXEXCD=1
                   QUIT 
               Begin DoDot:1
 +11               SET OCXPVAL=OCXX(OCXPENT,OCXLABSP)
 +12               IF $LENGTH(OCXPVAL)
                       Begin DoDot:2
 +13                       IF $PIECE(OCXPENT,";",2)="VA(200,"
                               IF @((+OCXRSLT)_OCXOP_OCXPVAL)
                                   Begin DoDot:3
 +14                                   SET OCXEXCD=1
                                   End DoDot:3
                       End DoDot:2
               End DoDot:1
 +15       QUIT OCXEXCD
 +16      ;
ORDITEM(OIEN) ;  Compiler Function: GET ORDERABLE ITEM FROM ORDER NUMBER
 +1        if '$GET(OIEN)
               QUIT ""
 +2       ;
 +3        NEW OITXT,X
           SET OITXT=$$OI^ORQOR2(OIEN)
           if 'OITXT
               QUIT "No orderable item found."
 +4        SET X=$GET(^ORD(101.43,+OITXT,0))
           if '$LENGTH(X)
               QUIT "No orderable item found."
 +5        QUIT $PIECE(X,U,1)
 +6       ;
PATLOC(DFN) ;  Compiler Function: PATIENT LOCATION
 +1       ;
 +2        NEW OCXP1,OCXP2
 +3        SET OCXP1=$GET(^TMP("OCXSWAP",$JOB,"OCXODATA","PV1",2))
 +4        SET OCXP2=$PIECE($GET(^TMP("OCXSWAP",$JOB,"OCXODATA","PV1",3)),"^",1)
 +5        IF OCXP2
               Begin DoDot:1
 +6                SET OCXP2=$PIECE($GET(^SC(+OCXP2,0)),"^",1,2)
 +7                IF $LENGTH($PIECE(OCXP2,"^",2))
                       SET OCXP2=$PIECE(OCXP2,"^",2)
 +8               IF '$TEST
                       SET OCXP2=$PIECE(OCXP2,"^",1)
 +9                if '$LENGTH(OCXP2)
                       SET OCXP2="NO LOC"
               End DoDot:1
 +10       IF $LENGTH(OCXP1)
               IF $LENGTH(OCXP2)
                   QUIT OCXP1_"^"_OCXP2
 +11      ;
 +12       SET OCXP2=$GET(^DPT(+$GET(DFN),.1))
 +13       IF $LENGTH(OCXP2)
               QUIT "I^"_OCXP2
 +14       QUIT "O^OUTPT"
 +15      ;
TERMLKUP(OCXTERM,OCXLIST) ;
 +1        QUIT $$TERM^OCXOZ01(OCXTERM,.OCXLIST)
 +2       ;