| 1 | OCXDI2 ;SLC/RJS,CLA - OCX PACKAGE DIAGNOSTIC UTILITY ROUTINE ;SEP 7,1999 at 10:30
 | 
|---|
| 2 |  ;;3.0;ORDER ENTRY/RESULTS REPORTING;**32**;Dec 17,1997
 | 
|---|
| 3 |  ;;  ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
 | 
|---|
| 4 |  ;
 | 
|---|
| 5 | S ;
 | 
|---|
| 6 |  ;  Record Utilities
 | 
|---|
| 7 |  Q
 | 
|---|
| 8 |  ;
 | 
|---|
| 9 | ADDREC(OCXCREF) ;
 | 
|---|
| 10 |  ;
 | 
|---|
| 11 |  ;
 | 
|---|
| 12 |  N QUIT,OCXDD,OCXDA,OCXGREF,OCXNAME
 | 
|---|
| 13 |  S OCXDD=$O(@OCXCREF@("")) Q:'OCXDD 0
 | 
|---|
| 14 |  Q:'OCXFLGC 0
 | 
|---|
| 15 |  I (OCXFLGA) S QUIT=$$READ("Y"," Do you want to add a local '"_$$FILENAME^OCXBDTD(+OCXDD)_"' record ?","YES") Q:'QUIT (QUIT[U)
 | 
|---|
| 16 |  ;
 | 
|---|
| 17 |  S OCXDA=0 D CREATE(OCXCREF,OCXDD,.OCXDA,0)
 | 
|---|
| 18 |  S OCXNAME=$G(@OCXCREF@(OCXDD,.01,"E")) S:$L(OCXNAME) ^TMP("OCXDIAG",$J,"A",+OCXDD,OCXNAME)=""
 | 
|---|
| 19 |  ;
 | 
|---|
| 20 |  Q 0
 | 
|---|
| 21 |  ;
 | 
|---|
| 22 | DELREC(OCXFILE,OCXDA) ;
 | 
|---|
| 23 |  ;
 | 
|---|
| 24 |  ;
 | 
|---|
| 25 |  N QUIT
 | 
|---|
| 26 |  Q:'OCXFLGC 0 Q:$G(OCXAUTO) 0
 | 
|---|
| 27 |  I (OCXFLGA) S QUIT=$$READ("Y"," Do you want to delete the local '"_$$FILENAME^OCXBDTD(+OCXFILE)_"' record ?","YES") Q:'QUIT (QUIT[U)
 | 
|---|
| 28 |  ;
 | 
|---|
| 29 |  W !,OCXFILE," ",OCXDA
 | 
|---|
| 30 |  D DIE(OCXFILE,$$FILE^OCXBDTD(OCXFILE,"GLOBAL NAME"),.01,"@",OCXDA,0)
 | 
|---|
| 31 |  W !!,"  deleted..."
 | 
|---|
| 32 |  ;
 | 
|---|
| 33 |  Q 0
 | 
|---|
| 34 |  ;
 | 
|---|
| 35 | DELDUP(OCXFILE,OCXNAME) ;
 | 
|---|
| 36 |  ;
 | 
|---|
| 37 |  ;
 | 
|---|
| 38 |  N OCXQUIT,OCXCGL,OCXOGL,OCXD0,RESP,OCXKEY,KEYLEN,OCXKEEP
 | 
|---|
| 39 |  ;
 | 
|---|
| 40 |  I (OCXFLGR) W !," There are duplicate copies of the '"_$$FILENAME^OCXBDTD(+OCXFILE)_":"_OCXNAME_"' record."
 | 
|---|
| 41 |  I '$G(OCXAUTO),'OCXFLGC Q 0
 | 
|---|
| 42 |  I (OCXFLGA) S RESP=$$READ("Y"," Do you want to purge duplicate copies of the '"_$$FILENAME^OCXBDTD(+OCXFILE)_":"_OCXNAME_"' record ?","YES") Q:'RESP 0 Q:(RESP[U) -10
 | 
|---|
| 43 |  ;
 | 
|---|
| 44 |  S OCXOGL=$$FILE^OCXBDTD(OCXFILE,"GLOBAL NAME")
 | 
|---|
| 45 |  S OCXCGL=$$CREF^DILF(OCXOGL)
 | 
|---|
| 46 |  F KEYLEN=$L(OCXNAME):-1:1 S OCXKEY=$E(OCXNAME,1,KEYLEN)  Q:$D(@OCXCGL@("B",OCXKEY))
 | 
|---|
| 47 |  S OCXD0=0 F  S OCXD0=$O(@OCXCGL@("B",OCXKEY,OCXD0)) Q:'OCXD0  Q:($P($G(@OCXCGL@(OCXD0,0)),U,1)=OCXNAME)
 | 
|---|
| 48 |  W:OCXFLGR !,"Keep:   ",OCXFILE," ",OCXNAME," ",OCXD0
 | 
|---|
| 49 |  S OCXKEEP=OCXD0 F  S OCXD0=$O(@OCXCGL@("B",OCXKEY,OCXD0)) Q:'OCXD0  I ($P($G(@OCXCGL@(OCXD0,0)),U,1)=OCXNAME) D
 | 
|---|
| 50 |  .W:OCXFLGR !!,"Delete: ",OCXFILE," ",OCXNAME," ",OCXD0
 | 
|---|
| 51 |  .D DIE(OCXFILE,OCXOGL,.01,"@",OCXD0,0)
 | 
|---|
| 52 |  .W:OCXFLGR "  deleted..."
 | 
|---|
| 53 |  ;
 | 
|---|
| 54 |  I ($P($G(@OCXCGL@(OCXKEEP,0)),U,1)=OCXNAME) S ^TMP("OCXDIAG",$J,"A",FILE,OCXNAME)=""
 | 
|---|
| 55 |  ;
 | 
|---|
| 56 |  Q OCXKEEP
 | 
|---|
| 57 |  ;
 | 
|---|
| 58 | CREATE(OCXCREF,OCXDD,OCXDA,OCXLVL) ;
 | 
|---|
| 59 |  ;
 | 
|---|
| 60 |  N OCXFLD,OCXGREF,OCXKEY
 | 
|---|
| 61 |  ;
 | 
|---|
| 62 |  S OCXKEY=@OCXCREF@(OCXDD,.01,"E")
 | 
|---|
| 63 |  S OCXGREF=$$GETREF(+OCXDD,.OCXDA,OCXLVL) Q:'$L(OCXGREF)
 | 
|---|
| 64 |  I 'OCXDA D
 | 
|---|
| 65 |  .S OCXDA=$O(^TMP("OCXDIAG",$J,"B",+OCXDD,OCXKEY,0)) Q:OCXDA
 | 
|---|
| 66 |  .S OCXDA=$O(@(OCXGREF_""" "")"),-1)+1
 | 
|---|
| 67 |  .F OCXDA=OCXDA:1 Q:'$D(@(OCXGREF_OCXDA_",0)"))
 | 
|---|
| 68 |  .I $D(@(OCXGREF_OCXDA_",0)")) S OCXDA=0
 | 
|---|
| 69 |  ;
 | 
|---|
| 70 |  I 'OCXDA W !!,"Error adding record..." Q
 | 
|---|
| 71 |  ;
 | 
|---|
| 72 |  I '$D(@(OCXGREF_"0)")) S @(OCXGREF_"0)")=U_$$FILEHDR^OCXBDTD(+OCXDD)_U_U
 | 
|---|
| 73 |  ;
 | 
|---|
| 74 |  S OCXFLD=0 F  S OCXFLD=$O(@OCXCREF@(OCXDD,OCXFLD)) Q:'OCXFLD  Q:(OCXFLD[":")  I '$$EXFLD^OCXDI1(+OCXDD,OCXFLD) D
 | 
|---|
| 75 |  .I $L($G(@OCXCREF@(OCXDD,OCXFLD,"E"))) D DIE(OCXDD,OCXGREF,OCXFLD,@OCXCREF@(OCXDD,OCXFLD,"E"),.OCXDA,OCXLVL)
 | 
|---|
| 76 |  .I $O(@OCXCREF@(OCXDD,OCXFLD,0)) D WORD(OCXDD,OCXGREF,OCXFLD,.OCXDA,OCXCREF)
 | 
|---|
| 77 |  ;
 | 
|---|
| 78 |  D PUSH(.OCXDA)
 | 
|---|
| 79 |  S OCXFLD="" F  S OCXFLD=$O(@OCXCREF@(OCXDD,OCXFLD)) Q:'$L(OCXFLD)  I (OCXFLD[":") D
 | 
|---|
| 80 |  .S OCXDA=$P(OCXFLD,":",2) W:OCXFLGR ! D CREATE($$APPEND(OCXCREF,OCXDD),OCXFLD,.OCXDA,OCXLVL+1)
 | 
|---|
| 81 |  D POP(.OCXDA)
 | 
|---|
| 82 |  Q
 | 
|---|
| 83 |  ;
 | 
|---|
| 84 | LOADWORD(RREF,OCXDD,OCXFLD,OCXSUB) ;
 | 
|---|
| 85 |  ;
 | 
|---|
| 86 |  N QUIT,DDPATH,INDEX,OCXDA,OCXGREF
 | 
|---|
| 87 |  S DDPATH=$P($P($$APPEND(RREF,OCXDD),"(",2),")",1)
 | 
|---|
| 88 |  F INDEX=1:1:$L(DDPATH,",") S OCXDA($L(DDPATH,",")-INDEX)=+$P($P(DDPATH,",",INDEX),":",2)
 | 
|---|
| 89 |  S OCXDA=$G(OCXDA(0)) K OCXDA(0)
 | 
|---|
| 90 |  Q:'OCXFLGC 0 I OCXFLGA S QUIT=$$READ("Y"," Do you want to reload the local '"_$$FIELD^OCXBDTD(+OCXDD,+OCXFLD,"LABEL")_"' field ?","YES") Q:'QUIT (QUIT[U)
 | 
|---|
| 91 |  S OCXGREF=$$GETREF(+OCXDD,.OCXDA,$L(DDPATH,",")-1) Q:'$L(OCXGREF)
 | 
|---|
| 92 |  D WORD(OCXDD,OCXGREF,OCXFLD,.OCXDA,RREF)
 | 
|---|
| 93 |  Q 0
 | 
|---|
| 94 |  ;
 | 
|---|
| 95 | GETREF(OCXDD,OCXDA,OCXLVL) ;
 | 
|---|
| 96 |  ;
 | 
|---|
| 97 |  Q:'OCXDD ""
 | 
|---|
| 98 |  ;
 | 
|---|
| 99 |  N OCXIENS,OCXERR,OCXX
 | 
|---|
| 100 |  S OCXIENS=$$IENS^DILF(.OCXDA),OCXERR=""
 | 
|---|
| 101 |  S OCXX=$$ROOT^DILFD(OCXDD,OCXIENS,0,OCXERR)
 | 
|---|
| 102 |  Q OCXX
 | 
|---|
| 103 |  ;
 | 
|---|
| 104 | WORD(DD,GREF,FLD,DA,RREF) ;
 | 
|---|
| 105 |  ;
 | 
|---|
| 106 |  N SUB,GLROOT,LINE
 | 
|---|
| 107 |  S SUB=$P($$FIELD^OCXBDTD(+DD,FLD,"GLOBAL SUBSCRIPT LOCATION"),";",1) S:'(SUB=+SUB) SUB=""""_SUB_""""
 | 
|---|
| 108 |  S GLROOT=GREF_DA_","_SUB_")" K @GLROOT
 | 
|---|
| 109 |  S LINE=0 F  S LINE=$O(@RREF@(DD,FLD,LINE)) Q:'LINE  D
 | 
|---|
| 110 |  .S @GLROOT@($O(@GLROOT@(""),-1)+1,0)=@RREF@(DD,FLD,LINE)
 | 
|---|
| 111 |  S LINE=$O(@GLROOT@(""),-1),@GLROOT@(0)=U_U_LINE_U_LINE_U_$$DATE("T")_U
 | 
|---|
| 112 |  ;
 | 
|---|
| 113 |  Q
 | 
|---|
| 114 |  ;
 | 
|---|
| 115 | DATE(X) N %DT,Y S %DT="" D ^%DT Q +Y
 | 
|---|
| 116 |  ;
 | 
|---|
| 117 | DIE(OCXDD,OCXDIC,OCXFLD,OCXVAL,OCXDA,OCXLVL) ;
 | 
|---|
| 118 |  ;
 | 
|---|
| 119 |  N DIC,DIE,X,Y,DR,DA,OCXDVAL,OCXPTR,OCXGREF,D0
 | 
|---|
| 120 |  S (D0,DA)=OCXDA,(DIC,DIE)=OCXDIC,DR=""
 | 
|---|
| 121 |  S:OCXLVL D0=OCXDA(1),DR="S DA(1)="_(+D0)_",D0="_(+D0)_";"
 | 
|---|
| 122 |  S:OCXVAL="?" OCXVAL="? "
 | 
|---|
| 123 |  ;
 | 
|---|
| 124 |  I '(OCXVAL="@"),OCXFLGR W !,?(OCXLVL*5),$$FIELD^OCXBDTD(+OCXDD,OCXFLD,"LABEL"),": ",OCXVAL
 | 
|---|
| 125 |  ;
 | 
|---|
| 126 |  I '(OCXVAL="@") D
 | 
|---|
| 127 |  .N OCXIEN,SHORT
 | 
|---|
| 128 |  .S OCXPTR=+$P($$FIELD^OCXBDTD(+OCXDD,OCXFLD,"SPECIFIER"),"P",2)
 | 
|---|
| 129 |  .I 'OCXPTR S DR=DR_OCXFLD_"///^S X=OCXVAL" Q
 | 
|---|
| 130 |  .S OCXGREF="^"_$$FIELD^OCXBDTD(+OCXDD,OCXFLD,"POINTER")
 | 
|---|
| 131 |  .I '($E(OCXGREF,1,4)="^OCX"),'(OCXGREF="^ORD(100.9,"),'(OCXGREF="^ORD(100.8,") Q
 | 
|---|
| 132 |  .S OCXIEN=$$DIC(OCXGREF,OCXVAL,0)
 | 
|---|
| 133 |  .S:'OCXIEN OCXIEN=$$DIC(OCXGREF,OCXVAL,1),^TMP("OCXDIAG",$J,"B",OCXPTR,OCXVAL,OCXIEN)=""
 | 
|---|
| 134 |  .S DR=DR_OCXFLD_"///`"_(+OCXIEN)
 | 
|---|
| 135 |  ;
 | 
|---|
| 136 |  I (OCXVAL="@") S DR=DR_OCXFLD_"///^S X=OCXVAL"
 | 
|---|
| 137 |  S OCXSCR=1
 | 
|---|
| 138 |  D ^DIE
 | 
|---|
| 139 |  ;
 | 
|---|
| 140 |  ; I $D(Y) -> DIE FILER ERROR
 | 
|---|
| 141 |  ;
 | 
|---|
| 142 |  Q
 | 
|---|
| 143 |  ;
 | 
|---|
| 144 | DIC(DIC,X,OCXADD) S DIC(0)="MX",OCXSCR=1 S:OCXADD DIC(0)="MXL" D ^DIC Q:(+Y>0) +Y Q 0
 | 
|---|
| 145 |  ;
 | 
|---|
| 146 | PUSH(OCXDA) ;
 | 
|---|
| 147 |  N OCXSUB S OCXSUB="" F  S OCXSUB=$O(OCXDA(OCXSUB),-1) Q:'OCXSUB  S OCXDA(OCXSUB+1)=OCXDA(OCXSUB)
 | 
|---|
| 148 |  S OCXDA(1)=OCXDA,OCXDA=0
 | 
|---|
| 149 |  Q
 | 
|---|
| 150 |  ;
 | 
|---|
| 151 | POP(OCXDA) ;
 | 
|---|
| 152 |  N OCXSUB S OCXSUB="" F  S OCXSUB=$O(OCXDA(OCXSUB)) Q:'OCXSUB  S OCXDA(OCXSUB)=$G(OCXDA(OCXSUB+1))
 | 
|---|
| 153 |  S OCXDA=OCXDA(1) K OCXDA($O(OCXDA(""),-1))
 | 
|---|
| 154 |  Q
 | 
|---|
| 155 |  ;
 | 
|---|
| 156 | APPEND(ARRAY,OCXSUB) ;
 | 
|---|
| 157 |  S:'(OCXSUB=+OCXSUB) OCXSUB=""""_OCXSUB_""""
 | 
|---|
| 158 |  Q:'(ARRAY["(") ARRAY_"("_OCXSUB_")"
 | 
|---|
| 159 |  Q $E(ARRAY,1,$L(ARRAY)-1)_","_OCXSUB_")"
 | 
|---|
| 160 |  ;
 | 
|---|
| 161 | READ(OCXZ0,OCXZA,OCXZB,OCXZL) ;
 | 
|---|
| 162 |  N OCXLINE,DIR,DTOUT,DUOUT,DIRUT,DIROUT
 | 
|---|
| 163 |  Q:'$L($G(OCXZ0)) U
 | 
|---|
| 164 |  S DIR(0)=OCXZ0
 | 
|---|
| 165 |  S:$L($G(OCXZA)) DIR("A")=OCXZA
 | 
|---|
| 166 |  S:$L($G(OCXZB)) DIR("B")=OCXZB
 | 
|---|
| 167 |  F OCXLINE=1:1:($G(OCXZL)-1) W !
 | 
|---|
| 168 |  D ^DIR
 | 
|---|
| 169 |  I $D(DTOUT)!$D(DUOUT)!$D(DIRUT)!$D(DIROUT) Q U
 | 
|---|
| 170 |  Q Y
 | 
|---|
| 171 |  ;
 | 
|---|
| 172 | PAUSE() Q:'OCXFLGC 0 W "  Press Enter " R X:DTIME W ! Q (X[U)
 | 
|---|
| 173 |  ;
 | 
|---|