- ORY2212 ;SLC/RJS,CLA - OCX PACKAGE RULE TRANSPORT ROUTINE (Delete after Install of OR*3*221) ;AUG 30,2005 at 11:41
- ;;3.0;ORDER ENTRY/RESULTS REPORTING;**221**;Dec 17,1997
- ;; ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
- ;
- S ;
- ; Record Utilities
- Q
- ;
- ADDREC(OCXCREF) ;
- ;
- N QUIT,OCXDD,OCXDA,OCXGREF,OCXNAME
- S OCXDD=$O(@OCXCREF@("")) Q:'OCXDD 0
- S OCXNAME=$G(@OCXCREF@(OCXDD,.01,"E"))
- ;
- W " record missing..."
- I (OCXFLAG["D") Q 0
- ;
- S OCXDA=0 D CREATE(OCXCREF,OCXDD,.OCXDA,0)
- S:$L(OCXNAME) ^TMP("OCXRULE",$J,"A",+OCXDD,OCXNAME)=""
- ;
- Q 0
- ;
- CREATE(OCXCREF,OCXDD,OCXDA,OCXLVL) ;
- ;
- N OCXFLD,OCXGREF,OCXKEY
- ;
- I $L(OCXDA),'(OCXDA=+OCXDA) W !!,"Unresolved subscript." Q
- ;
- S OCXKEY=@OCXCREF@(OCXDD,.01,"E")
- S OCXGREF=$$GETREF(+OCXDD,.OCXDA,OCXLVL) Q:'$L(OCXGREF)
- I 'OCXDA D
- .S OCXDA=$O(^TMP("OCXRULE",$J,"B",+OCXDD,OCXKEY,0)) Q:OCXDA
- .S OCXDA=$O(@(OCXGREF_""" "")"),-1)+1
- .F OCXDA=OCXDA:1 Q:'$D(@(OCXGREF_OCXDA_",0)"))
- .I $D(@(OCXGREF_OCXDA_",0)")) S OCXDA=0
- ;
- I 'OCXDA W !!,"Error adding record..." Q
- ;
- I '$D(@(OCXGREF_"0)")) S @(OCXGREF_"0)")=U_$$FILEHDR^OCXSENDD(+OCXDD)_U_U
- ;
- S OCXFLD=0 F S OCXFLD=$O(@OCXCREF@(OCXDD,OCXFLD)) Q:'OCXFLD Q:(OCXFLD[":") I '$$EXFLD^ORY2211(+OCXDD,OCXFLD) D
- .I $L($G(@OCXCREF@(OCXDD,OCXFLD,"E"))) D DIE(OCXDD,OCXGREF,OCXFLD,@OCXCREF@(OCXDD,OCXFLD,"E"),.OCXDA,OCXLVL)
- .I $O(@OCXCREF@(OCXDD,OCXFLD,0)) D WORD(OCXDD,OCXGREF,OCXFLD,.OCXDA,OCXCREF)
- ;
- D PUSH(.OCXDA)
- S OCXFLD="" F S OCXFLD=$O(@OCXCREF@(OCXDD,OCXFLD)) Q:'$L(OCXFLD) I (OCXFLD[":") D
- .S OCXDA=$P(OCXFLD,":",2) W ! D CREATE($$APPEND(OCXCREF,OCXDD),OCXFLD,.OCXDA,OCXLVL+1)
- D POP(.OCXDA)
- Q
- ;
- LOADWORD(RREF,OCXDD,OCXFLD,OCXSUB) ;
- ;
- N QUIT,DDPATH,INDEX,OCXDA,OCXGREF
- S DDPATH=$P($P($$APPEND(RREF,OCXDD),"(",2),")",1)
- F INDEX=1:1:$L(DDPATH,",") S OCXDA($L(DDPATH,",")-INDEX)=+$P($P(DDPATH,",",INDEX),":",2)
- S OCXDA=$G(OCXDA(0)) K OCXDA(0)
- Q:(OCXFLAG["D") 0
- I (OCXFLAG["A") S QUIT=$$READ("Y"," Do you want to reload the local '"_$$FIELD^OCXSENDD(+OCXDD,+OCXFLD,"LABEL")_"' field ?","YES") Q:'QUIT (QUIT[U)
- S OCXGREF=$$GETREF(+OCXDD,.OCXDA,$L(DDPATH,",")-1) Q:'$L(OCXGREF)
- D WORD(OCXDD,OCXGREF,OCXFLD,.OCXDA,RREF)
- Q 0
- ;
- GETREF(OCXDD,OCXDA,OCXLVL) ;
- ;
- Q:'OCXDD ""
- ;
- N OCXIENS,OCXERR,OCXX
- S OCXIENS=$$IENS^DILF(.OCXDA),OCXERR=""
- S OCXX=$$ROOT^DILFD(OCXDD,OCXIENS,0,OCXERR)
- Q OCXX
- ;
- WORD(DD,GREF,FLD,DA,RREF) ;
- ;
- N SUB,GLROOT,LINE
- S SUB=$P($$FIELD^OCXSENDD(+DD,FLD,"GLOBAL SUBSCRIPT LOCATION"),";",1) S:'(SUB=+SUB) SUB=""""_SUB_""""
- S GLROOT=GREF_DA_","_SUB_")" K @GLROOT
- S LINE=0 F S LINE=$O(@RREF@(DD,FLD,LINE)) Q:'LINE D
- .S @GLROOT@($O(@GLROOT@(""),-1)+1,0)=@RREF@(DD,FLD,LINE)
- S LINE=$O(@GLROOT@(""),-1),@GLROOT@(0)=U_U_LINE_U_LINE_U_$$DATE("T")_U
- ;
- Q
- ;
- DATE(X) N %DT,Y S %DT="" D ^%DT Q +Y
- ;
- DIE(OCXDD,OCXDIC,OCXFLD,OCXVAL,OCXDA,OCXLVL) ;
- ;
- N DIC,DIE,X,Y,DR,DA,OCXDVAL,OCXPTR,OCXGREF,D0,OCXSCR
- S (D0,DA)=OCXDA,(DIC,DIE)=OCXDIC,DR=""
- S:OCXLVL D0=OCXDA(1),DR="S DA(1)="_(+D0)_",D0="_(+D0)_";"
- S:OCXVAL="?" OCXVAL="? " S DR=DR_OCXFLD_"///^S X=OCXVAL"
- I '(OCXVAL="@") W !,?(OCXLVL*5),$$FIELD^OCXSENDD(+OCXDD,OCXFLD,"LABEL"),": ",OCXVAL
- ;
- I '(OCXVAL="@") D
- .N OCXIEN,SHORT
- .S OCXPTR=+$P($$FIELD^OCXSENDD(+OCXDD,OCXFLD,"SPECIFIER"),"P",2)
- .Q:'OCXPTR
- .S OCXGREF="^"_$$FIELD^OCXSENDD(+OCXDD,OCXFLD,"POINTER")
- .I '($E(OCXGREF,1,4)="^OCX"),'(OCXGREF="^ORD(100.9,"),'(OCXGREF="^ORD(100.8,") Q
- .Q:$$DIC(OCXGREF,OCXVAL,0)
- .S OCXIEN=$$DIC(OCXGREF,OCXVAL,1)
- .S ^TMP("OCXRULE",$J,"B",OCXPTR,OCXVAL,OCXIEN)=""
- ;
- S OCXSCR=1
- D ^DIE
- ;
- ; I $D(Y) -> DIE FILER ERROR
- I $D(Y) W " ^DIE filer data error..." S OCXDIER=$G(OCXDIER)+1
- I '$D(Y) W " ...Correct data Filed"
- ;
- Q
- ;
- DIC(DIC,X,OCXADD) N OCXSCR S DIC(0)="",OCXSCR=1 S:OCXADD DIC(0)="L" D ^DIC Q:(+Y>0) +Y Q 0
- ;
- PUSH(OCXDA) ;
- N OCXSUB S OCXSUB="" F S OCXSUB=$O(OCXDA(OCXSUB),-1) Q:'OCXSUB S OCXDA(OCXSUB+1)=OCXDA(OCXSUB)
- S OCXDA(1)=OCXDA,OCXDA=0
- Q
- ;
- POP(OCXDA) ;
- N OCXSUB S OCXSUB="" F S OCXSUB=$O(OCXDA(OCXSUB)) Q:'OCXSUB S OCXDA(OCXSUB)=$G(OCXDA(OCXSUB+1))
- S OCXDA=OCXDA(1) K OCXDA($O(OCXDA(""),-1))
- Q
- ;
- APPEND(ARRAY,OCXSUB) ;
- S:'(OCXSUB=+OCXSUB) OCXSUB=""""_OCXSUB_""""
- Q:'(ARRAY["(") ARRAY_"("_OCXSUB_")"
- Q $E(ARRAY,1,$L(ARRAY)-1)_","_OCXSUB_")"
- ;
- READ(OCXZ0,OCXZA,OCXZB,OCXZL) ;
- N OCXLINE,DIR,DTOUT,DUOUT,DIRUT,DIROUT
- Q:'$L($G(OCXZ0)) U
- S DIR(0)=OCXZ0
- S:$L($G(OCXZA)) DIR("A")=OCXZA
- S:$L($G(OCXZB)) DIR("B")=OCXZB
- F OCXLINE=1:1:($G(OCXZL)-1) W !
- D ^DIR
- I $D(DTOUT)!$D(DUOUT)!$D(DIRUT)!$D(DIROUT) Q U
- Q Y
- ;
- PAUSE() W " Press Enter " R X:DTIME W ! Q (X[U)
- ;
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HORY2212 4659 printed Jan 18, 2025@03:40:38 Page 2
- ORY2212 ;SLC/RJS,CLA - OCX PACKAGE RULE TRANSPORT ROUTINE (Delete after Install of OR*3*221) ;AUG 30,2005 at 11:41
- +1 ;;3.0;ORDER ENTRY/RESULTS REPORTING;**221**;Dec 17,1997
- +2 ;; ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
- +3 ;
- S ;
- +1 ; Record Utilities
- +2 QUIT
- +3 ;
- ADDREC(OCXCREF) ;
- +1 ;
- +2 NEW QUIT,OCXDD,OCXDA,OCXGREF,OCXNAME
- +3 SET OCXDD=$ORDER(@OCXCREF@(""))
- if 'OCXDD
- QUIT 0
- +4 SET OCXNAME=$GET(@OCXCREF@(OCXDD,.01,"E"))
- +5 ;
- +6 WRITE " record missing..."
- +7 IF (OCXFLAG["D")
- QUIT 0
- +8 ;
- +9 SET OCXDA=0
- DO CREATE(OCXCREF,OCXDD,.OCXDA,0)
- +10 if $LENGTH(OCXNAME)
- SET ^TMP("OCXRULE",$JOB,"A",+OCXDD,OCXNAME)=""
- +11 ;
- +12 QUIT 0
- +13 ;
- CREATE(OCXCREF,OCXDD,OCXDA,OCXLVL) ;
- +1 ;
- +2 NEW OCXFLD,OCXGREF,OCXKEY
- +3 ;
- +4 IF $LENGTH(OCXDA)
- IF '(OCXDA=+OCXDA)
- WRITE !!,"Unresolved subscript."
- QUIT
- +5 ;
- +6 SET OCXKEY=@OCXCREF@(OCXDD,.01,"E")
- +7 SET OCXGREF=$$GETREF(+OCXDD,.OCXDA,OCXLVL)
- if '$LENGTH(OCXGREF)
- QUIT
- +8 IF 'OCXDA
- Begin DoDot:1
- +9 SET OCXDA=$ORDER(^TMP("OCXRULE",$JOB,"B",+OCXDD,OCXKEY,0))
- if OCXDA
- QUIT
- +10 SET OCXDA=$ORDER(@(OCXGREF_""" "")"),-1)+1
- +11 FOR OCXDA=OCXDA:1
- if '$DATA(@(OCXGREF_OCXDA_",0)"))
- QUIT
- +12 IF $DATA(@(OCXGREF_OCXDA_",0)"))
- SET OCXDA=0
- End DoDot:1
- +13 ;
- +14 IF 'OCXDA
- WRITE !!,"Error adding record..."
- QUIT
- +15 ;
- +16 IF '$DATA(@(OCXGREF_"0)"))
- SET @(OCXGREF_"0)")=U_$$FILEHDR^OCXSENDD(+OCXDD)_U_U
- +17 ;
- +18 SET OCXFLD=0
- FOR
- SET OCXFLD=$ORDER(@OCXCREF@(OCXDD,OCXFLD))
- if 'OCXFLD
- QUIT
- if (OCXFLD["
- QUIT
- IF '$$EXFLD^ORY2211(+OCXDD,OCXFLD)
- Begin DoDot:1
- +19 IF $LENGTH($GET(@OCXCREF@(OCXDD,OCXFLD,"E")))
- DO DIE(OCXDD,OCXGREF,OCXFLD,@OCXCREF@(OCXDD,OCXFLD,"E"),.OCXDA,OCXLVL)
- +20 IF $ORDER(@OCXCREF@(OCXDD,OCXFLD,0))
- DO WORD(OCXDD,OCXGREF,OCXFLD,.OCXDA,OCXCREF)
- End DoDot:1
- +21 ;
- +22 DO PUSH(.OCXDA)
- +23 SET OCXFLD=""
- FOR
- SET OCXFLD=$ORDER(@OCXCREF@(OCXDD,OCXFLD))
- if '$LENGTH(OCXFLD)
- QUIT
- IF (OCXFLD[":")
- Begin DoDot:1
- +24 SET OCXDA=$PIECE(OCXFLD,":",2)
- WRITE !
- DO CREATE($$APPEND(OCXCREF,OCXDD),OCXFLD,.OCXDA,OCXLVL+1)
- End DoDot:1
- +25 DO POP(.OCXDA)
- +26 QUIT
- +27 ;
- LOADWORD(RREF,OCXDD,OCXFLD,OCXSUB) ;
- +1 ;
- +2 NEW QUIT,DDPATH,INDEX,OCXDA,OCXGREF
- +3 SET DDPATH=$PIECE($PIECE($$APPEND(RREF,OCXDD),"(",2),")",1)
- +4 FOR INDEX=1:1:$LENGTH(DDPATH,",")
- SET OCXDA($LENGTH(DDPATH,",")-INDEX)=+$PIECE($PIECE(DDPATH,",",INDEX),":",2)
- +5 SET OCXDA=$GET(OCXDA(0))
- KILL OCXDA(0)
- +6 if (OCXFLAG["D")
- QUIT 0
- +7 IF (OCXFLAG["A")
- SET QUIT=$$READ("Y"," Do you want to reload the local '"_$$FIELD^OCXSENDD(+OCXDD,+OCXFLD,"LABEL")_"' field ?","YES")
- if 'QUIT
- QUIT (QUIT[U)
- +8 SET OCXGREF=$$GETREF(+OCXDD,.OCXDA,$LENGTH(DDPATH,",")-1)
- if '$LENGTH(OCXGREF)
- QUIT
- +9 DO WORD(OCXDD,OCXGREF,OCXFLD,.OCXDA,RREF)
- +10 QUIT 0
- +11 ;
- GETREF(OCXDD,OCXDA,OCXLVL) ;
- +1 ;
- +2 if 'OCXDD
- QUIT ""
- +3 ;
- +4 NEW OCXIENS,OCXERR,OCXX
- +5 SET OCXIENS=$$IENS^DILF(.OCXDA)
- SET OCXERR=""
- +6 SET OCXX=$$ROOT^DILFD(OCXDD,OCXIENS,0,OCXERR)
- +7 QUIT OCXX
- +8 ;
- WORD(DD,GREF,FLD,DA,RREF) ;
- +1 ;
- +2 NEW SUB,GLROOT,LINE
- +3 SET SUB=$PIECE($$FIELD^OCXSENDD(+DD,FLD,"GLOBAL SUBSCRIPT LOCATION"),";",1)
- if '(SUB=+SUB)
- SET SUB=""""_SUB_""""
- +4 SET GLROOT=GREF_DA_","_SUB_")"
- KILL @GLROOT
- +5 SET LINE=0
- FOR
- SET LINE=$ORDER(@RREF@(DD,FLD,LINE))
- if 'LINE
- QUIT
- Begin DoDot:1
- +6 SET @GLROOT@($ORDER(@GLROOT@(""),-1)+1,0)=@RREF@(DD,FLD,LINE)
- End DoDot:1
- +7 SET LINE=$ORDER(@GLROOT@(""),-1)
- SET @GLROOT@(0)=U_U_LINE_U_LINE_U_$$DATE("T")_U
- +8 ;
- +9 QUIT
- +10 ;
- DATE(X) NEW %DT,Y
- SET %DT=""
- DO ^%DT
- QUIT +Y
- +1 ;
- DIE(OCXDD,OCXDIC,OCXFLD,OCXVAL,OCXDA,OCXLVL) ;
- +1 ;
- +2 NEW DIC,DIE,X,Y,DR,DA,OCXDVAL,OCXPTR,OCXGREF,D0,OCXSCR
- +3 SET (D0,DA)=OCXDA
- SET (DIC,DIE)=OCXDIC
- SET DR=""
- +4 if OCXLVL
- SET D0=OCXDA(1)
- SET DR="S DA(1)="_(+D0)_",D0="_(+D0)_";"
- +5 if OCXVAL="?"
- SET OCXVAL="? "
- SET DR=DR_OCXFLD_"///^S X=OCXVAL"
- +6 IF '(OCXVAL="@")
- WRITE !,?(OCXLVL*5),$$FIELD^OCXSENDD(+OCXDD,OCXFLD,"LABEL"),": ",OCXVAL
- +7 ;
- +8 IF '(OCXVAL="@")
- Begin DoDot:1
- +9 NEW OCXIEN,SHORT
- +10 SET OCXPTR=+$PIECE($$FIELD^OCXSENDD(+OCXDD,OCXFLD,"SPECIFIER"),"P",2)
- +11 if 'OCXPTR
- QUIT
- +12 SET OCXGREF="^"_$$FIELD^OCXSENDD(+OCXDD,OCXFLD,"POINTER")
- +13 IF '($EXTRACT(OCXGREF,1,4)="^OCX")
- IF '(OCXGREF="^ORD(100.9,")
- IF '(OCXGREF="^ORD(100.8,")
- QUIT
- +14 if $$DIC(OCXGREF,OCXVAL,0)
- QUIT
- +15 SET OCXIEN=$$DIC(OCXGREF,OCXVAL,1)
- +16 SET ^TMP("OCXRULE",$JOB,"B",OCXPTR,OCXVAL,OCXIEN)=""
- End DoDot:1
- +17 ;
- +18 SET OCXSCR=1
- +19 DO ^DIE
- +20 ;
- +21 ; I $D(Y) -> DIE FILER ERROR
- +22 IF $DATA(Y)
- WRITE " ^DIE filer data error..."
- SET OCXDIER=$GET(OCXDIER)+1
- +23 IF '$DATA(Y)
- WRITE " ...Correct data Filed"
- +24 ;
- +25 QUIT
- +26 ;
- DIC(DIC,X,OCXADD) NEW OCXSCR
- SET DIC(0)=""
- SET OCXSCR=1
- if OCXADD
- SET DIC(0)="L"
- DO ^DIC
- if (+Y>0)
- QUIT +Y
- QUIT 0
- +1 ;
- PUSH(OCXDA) ;
- +1 NEW OCXSUB
- SET OCXSUB=""
- FOR
- SET OCXSUB=$ORDER(OCXDA(OCXSUB),-1)
- if 'OCXSUB
- QUIT
- SET OCXDA(OCXSUB+1)=OCXDA(OCXSUB)
- +2 SET OCXDA(1)=OCXDA
- SET OCXDA=0
- +3 QUIT
- +4 ;
- POP(OCXDA) ;
- +1 NEW OCXSUB
- SET OCXSUB=""
- FOR
- SET OCXSUB=$ORDER(OCXDA(OCXSUB))
- if 'OCXSUB
- QUIT
- SET OCXDA(OCXSUB)=$GET(OCXDA(OCXSUB+1))
- +2 SET OCXDA=OCXDA(1)
- KILL OCXDA($ORDER(OCXDA(""),-1))
- +3 QUIT
- +4 ;
- APPEND(ARRAY,OCXSUB) ;
- +1 if '(OCXSUB=+OCXSUB)
- SET OCXSUB=""""_OCXSUB_""""
- +2 if '(ARRAY["(")
- QUIT ARRAY_"("_OCXSUB_")"
- +3 QUIT $EXTRACT(ARRAY,1,$LENGTH(ARRAY)-1)_","_OCXSUB_")"
- +4 ;
- READ(OCXZ0,OCXZA,OCXZB,OCXZL) ;
- +1 NEW OCXLINE,DIR,DTOUT,DUOUT,DIRUT,DIROUT
- +2 if '$LENGTH($GET(OCXZ0))
- QUIT U
- +3 SET DIR(0)=OCXZ0
- +4 if $LENGTH($GET(OCXZA))
- SET DIR("A")=OCXZA
- +5 if $LENGTH($GET(OCXZB))
- SET DIR("B")=OCXZB
- +6 FOR OCXLINE=1:1:($GET(OCXZL)-1)
- WRITE !
- +7 DO ^DIR
- +8 IF $DATA(DTOUT)!$DATA(DUOUT)!$DATA(DIRUT)!$DATA(DIROUT)
- QUIT U
- +9 QUIT Y
- +10 ;
- PAUSE() WRITE " Press Enter "
- READ X:DTIME
- WRITE !
- QUIT (X[U)
- +1 ;