| 1 | OCXLOG1 ;SLC/RJS,CLA -  Rule Display (Expert System - Data Field Frequency in OCXLog Report) ;8/04/98  16:01
 | 
|---|
| 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 |  ;
 | 
|---|
| 7 |  K OCXTOTL,OCXPROG,OCXGETC,OCXGETN,OCXCOD2,OCXERR,OCXDF,OXCDFN
 | 
|---|
| 8 |  K OCXTOT,OCXNAM,OCXPARM,OCXPATH,OCXCON,OCXDPTR,OCXREC
 | 
|---|
| 9 |  K ^TMP("OCXDF",$J) S OCXWARN=0
 | 
|---|
| 10 |  S ^TMP("OCXDF",$J)=($P($H,",",2)+($H*86400)+(2*60*60))_" <- ^TMP ENTRY EXPIRATION DATE FOR ^OCXOPURG"
 | 
|---|
| 11 |  ;
 | 
|---|
| 12 |  W !!," Generating Data Navigation code..." D WAIT^DICD
 | 
|---|
| 13 |  ;
 | 
|---|
| 14 |  D  S OCXDFN="" F  S OCXDFN=$O(^OCXS(860.4,"B",OCXDFN)) Q:'$L(OCXDFN)  D  Q:OCXWARN
 | 
|---|
| 15 |  .Q  S OCXDF=0 F  S OCXDF=$O(^OCXS(860.4,"B",OCXDFN,OCXDF)) Q:'OCXDF  D  Q:OCXWARN
 | 
|---|
| 16 |  ..I $D(^OCXS(860.4,OCXDF,0)) K OCXREC(4) M OCXREC(4)=^OCXS(860.4,OCXDF)
 | 
|---|
| 17 |  ..E  Q
 | 
|---|
| 18 |  ..W:($X>60) ! W "."
 | 
|---|
| 19 |  ..S OCXCON=0 F  S OCXCON=$O(OCXREC(4,"LINK",OCXCON)) Q:'OCXCON  D  Q:OCXWARN
 | 
|---|
| 20 |  ...S OCXWARN=0
 | 
|---|
| 21 |  ...Q:$P($G(^OCXS(860.6,OCXCON,0)),U,3)
 | 
|---|
| 22 |  ...S OCXCONN=$P($G(^OCXS(860.6,OCXCON,0)),U,1) I '$L(OCXCONN) D WARN^OCXOCMPV("Data context IEN #"_(+OCXCON)_" not defined in Data Context file...",4,OCXDF,$P($T(+1)," ",1)) Q
 | 
|---|
| 23 |  ...S OCXCONA=$P($G(^OCXS(860.6,OCXCON,0)),U,2) I '$L(OCXCONA) D WARN^OCXOCMPV("Data context abbreviation for '"_OCXCONN_"' not defined in Data Context file...",4,OCXDF,$P($T(+1)," ",1)) Q
 | 
|---|
| 24 |  ...S OCXCONS=OCXCONA
 | 
|---|
| 25 |  ...S OCXTOTL(OCXCONS)=0
 | 
|---|
| 26 |  ...W:($X>60) ! W "."
 | 
|---|
| 27 |  ...;
 | 
|---|
| 28 |  ...N OCXATT,OCXDTYP,OCXDTYPN,OCXERR,OCXGETC,OCXLNK,OCXNAM,OCXPARM,OCXPATH
 | 
|---|
| 29 |  ...S OCXTOTL(OCXCONS,OCXDF)=0
 | 
|---|
| 30 |  ...S OCXNAM=$P($G(OCXREC(4,0)),U,1) Q:'$L(OCXNAM)
 | 
|---|
| 31 |  ...S OCXPATH=$G(OCXREC(4,"LINK",OCXCON,"DATAPATH")) I '$L(OCXPATH) D WARN^OCXOCMPV("Data Link-Path not defined",4,OCXDF,$P($T(+1)," ",1)) Q
 | 
|---|
| 32 |  ...S OCXLNK=$O(^OCXS(863.3,"B",OCXPATH,0)) I 'OCXLNK D WARN^OCXOCMPV("Data Link-Path '"_OCXPATH_"' not defined in Meta-Dictionary Link file...",4,OCXDF,$P($T(+1)," ",1)) Q
 | 
|---|
| 33 |  ...S OCXATT=$P($G(^OCXS(863.3,OCXLNK,0)),U,5) I 'OCXATT D WARN^OCXOCMPV("Data Link-Attribute '"_OCXPATH_"' ("_OCXLNK_") not defined in Meta-Dictionary Attribute file...",4,OCXDF,$P($T(+1)," ",1)) Q
 | 
|---|
| 34 |  ...;
 | 
|---|
| 35 |  ...S $P(OCXREC(4,0),U,3)=""
 | 
|---|
| 36 |  ...F OCXPARM="OCXO EXTERNAL FUNCTION CALL","OCXO VARIABLE NAME","OCXO VT-BAR PIECE NUMBER","OCXO UP-ARROW PIECE NUMBER","OCXO SEMI-COLON PIECE NUMBER","OCXO HL7 SEGMENT ID","OCXO FILE POINTER" D
 | 
|---|
| 37 |  ....Q:'$O(^OCXS(863.8,"B",OCXPARM,0))
 | 
|---|
| 38 |  ....S OCXPARM(OCXPARM)=$$GETPARM(33,OCXPATH,OCXPARM)
 | 
|---|
| 39 |  ....I '$L(OCXPARM(OCXPARM)) K OCXPARM(OCXPARM)
 | 
|---|
| 40 |  ...S OCXDTYP=$$GETPARM(34,OCXATT,"DATA TYPE")
 | 
|---|
| 41 |  ...I '$L(OCXDTYP) D WARN^OCXOCMPV("Data Link-Attribute '"_OCXPATH_"' Data Type not defined in Meta-Dictionary Attribute file...",4,OCXDF,$P($T(+1)," ",1)) Q
 | 
|---|
| 42 |  ...S:'OCXDTYP OCXDTYP=$O(^OCXS(864.1,"B",OCXDTYP,0)) S OCXDTYPN=$P($G(^OCXS(864.1,+OCXDTYP,0)),U,1)
 | 
|---|
| 43 |  ...I '$L(OCXDTYPN) D WARN^OCXOCMPV("Data Link-Attribute '"_OCXPATH_"' Data Type '"_OCXDTYP_"' not defined in Meta-Dictionary Data Type file...",4,OCXDF,$P($T(+1)," ",1)) Q
 | 
|---|
| 44 |  ...;
 | 
|---|
| 45 |  ...Q:$G(OCXERR)  Q:OCXWARN
 | 
|---|
| 46 |  ...;
 | 
|---|
| 47 |  ...I '$L($G(OCXPARM("OCXO VARIABLE NAME"))) D  Q
 | 
|---|
| 48 |  ....D WARN^OCXOCMPV("Not enough information in the MetaDictionary link file to generate navigation code.",4,OCXDF,$P($T(+1)," ",1)) S OCXERR=1 Q
 | 
|---|
| 49 |  ...S OCXDFV=OCXPARM("OCXO VARIABLE NAME")
 | 
|---|
| 50 |  ...S OCXTOTL(OCXCONS,OCXDF,"VAR")=OCXDFV
 | 
|---|
| 51 |  ...S OCXGETC="$G("_OCXDFV_")"
 | 
|---|
| 52 |  ...;
 | 
|---|
| 53 |  ...Q:OCXWARN
 | 
|---|
| 54 |  ...;
 | 
|---|
| 55 |  ...S:$L($G(OCXPARM("OCXO VT-BAR PIECE NUMBER"))) OCXGETC="$P("_OCXGETC_",""|"","_(OCXPARM("OCXO VT-BAR PIECE NUMBER")+1)_")"
 | 
|---|
| 56 |  ...S:$G(OCXPARM("OCXO UP-ARROW PIECE NUMBER")) OCXGETC="$P("_OCXGETC_",""^"","_OCXPARM("OCXO UP-ARROW PIECE NUMBER")_")"
 | 
|---|
| 57 |  ...S:$G(OCXPARM("OCXO SEMI-COLON PIECE NUMBER")) OCXGETC="$P("_OCXGETC_","";"","_OCXPARM("OCXO SEMI-COLON PIECE NUMBER")_")"
 | 
|---|
| 58 |  ...;
 | 
|---|
| 59 |  ...Q:'$L(OCXGETC)
 | 
|---|
| 60 |  ...S OCXPROG(OCXCONS,OCXDF)=OCXGETC
 | 
|---|
| 61 |  ...;
 | 
|---|
| 62 |  ;
 | 
|---|
| 63 |  W !!," Scanning Data Log..." D WAIT^DICD
 | 
|---|
| 64 |  ;
 | 
|---|
| 65 |  ;
 | 
|---|
| 66 |  S OCXD0=0 F  S OCXD0=$O(^OCXD(861,OCXD0)) Q:'OCXD0  D
 | 
|---|
| 67 |  .I $D(^OCXD(861,OCXD0,0)) K OCXREC M OCXREC=^OCXD(861,OCXD0)
 | 
|---|
| 68 |  .E  Q
 | 
|---|
| 69 |  .W:($X>60) !,"...",+OCXREC(0),"..." W:'(OCXD0#10) "."
 | 
|---|
| 70 |  .S OCXCONS=$G(OCXREC("SOURCE")) Q:'$L(OCXCONS)
 | 
|---|
| 71 |  .;
 | 
|---|
| 72 |  .Q:'(OCXCONS="OEPS")
 | 
|---|
| 73 |  .;
 | 
|---|
| 74 |  .D  I (OCXCONS="HL7") S OCXD0=0 F  S OCXD0=$O(^OCXD(861,OCXCONS,OCXD0)) Q:'OCXD0  D
 | 
|---|
| 75 |  ..Q  N OCXODATA
 | 
|---|
| 76 |  ..S OCXTOT=$G(OCXTOT)+1
 | 
|---|
| 77 |  ..S OCXTOTL(OCXCONS)=$G(OCXTOTL(OCXCONS))+1
 | 
|---|
| 78 |  ..K OCXODATA M OCXODATA=^OCXD(861,OCXCONS,OCXD0) D CONV(.OCXODATA)
 | 
|---|
| 79 |  ..S OCXDF=0 F  S OCXDF=$O(OCXPROG(OCXCONS,OCXDF)) Q:'OCXDF  D
 | 
|---|
| 80 |  ...X "S OCXX="_OCXPROG(OCXCONS,OCXDF)
 | 
|---|
| 81 |  ...I $L(OCXX) S OCXTOTL(OCXCONS,OCXDF)=$G(OCXTOTL(OCXCONS,OCXDF))+1
 | 
|---|
| 82 |  ...;
 | 
|---|
| 83 |  .;
 | 
|---|
| 84 |  .I '(OCXCONS="HL7") S OCXD0=0 F  S OCXD0=$O(OCXREC("DATA",OCXD0)) Q:'OCXD0  D
 | 
|---|
| 85 |  ..N OCXVAR,OCXVAL
 | 
|---|
| 86 |  ..S OCXTOT=$G(OCXTOT)+1
 | 
|---|
| 87 |  ..S OCXTOTL(OCXCONS)=$G(OCXTOTL(OCXCONS))+1
 | 
|---|
| 88 |  ..S OCXVAR=$P($G(OCXREC("DATA",OCXD0,0)),"=",1)
 | 
|---|
| 89 |  ..S OCXVAL=$P($G(OCXREC("DATA",OCXD0,0)),"=",2,999)
 | 
|---|
| 90 |  ..W !,?10,OCXVAR," = ",OCXVAL R XXX:60 Q
 | 
|---|
| 91 |  ..S @OCXVAR=OCXVAL
 | 
|---|
| 92 |  ..S OCXDF=0 F  S OCXDF=$O(OCXPROG(OCXCONS,OCXDF)) Q:'OCXDF  D
 | 
|---|
| 93 |  ...X "S OCXX="_OCXPROG(OCXCONS,OCXDF)
 | 
|---|
| 94 |  ...I $L(OCXX) S OCXTOTL(OCXCONS,OCXDF)=$G(OCXTOTL(OCXCONS,OCXDF))+1
 | 
|---|
| 95 |  ..K @OCXVAR
 | 
|---|
| 96 |  ;
 | 
|---|
| 97 |  K IOP D ^%ZIS
 | 
|---|
| 98 |  ;
 | 
|---|
| 99 |  U IO D  W *12 D ^%ZISC
 | 
|---|
| 100 |  .S OCXCONS="" F  S OCXCONS=$O(OCXTOTL(OCXCONS)) Q:'$L(OCXCONS)  D  Q:$$PAUSE
 | 
|---|
| 101 |  ..W !!,OCXCONS," Data Field Frequency in OCXLog  (",OCXTOTL(OCXCONS)," entries)",!
 | 
|---|
| 102 |  ..S OCXDFN="" F  S OCXDFN=$O(^OCXS(860.4,"B",OCXDFN)) Q:'$L(OCXDFN)  D
 | 
|---|
| 103 |  ...S OCXDF=0 F  S OCXDF=$O(^OCXS(860.4,"B",OCXDFN,OCXDF)) Q:'OCXDF  I $D(OCXTOTL(OCXCONS,OCXDF)) D
 | 
|---|
| 104 |  ....W !,$J(OCXTOTL(OCXCONS,OCXDF),5)," ",OCXDFN," [",OCXDF,"]   ",$G(OCXPROG(OCXCONS,OCXDF))
 | 
|---|
| 105 |  .W !!,$J(OCXTOT,5),"  Total arrays scanned"
 | 
|---|
| 106 |  .;
 | 
|---|
| 107 |  Q
 | 
|---|
| 108 |  ;
 | 
|---|
| 109 | ARCNT(SUB) ;
 | 
|---|
| 110 |  I '$G(^OCXD(861,SUB)) Q 0
 | 
|---|
| 111 |  Q (+$G(^OCXD(861,OCXCONS))-$O(^OCXD(861,OCXCONS,0)))+1
 | 
|---|
| 112 |  ;
 | 
|---|
| 113 | UDEFPARM(PARM) ;
 | 
|---|
| 114 |  Q:$D(OCXPARM(PARM)) 0
 | 
|---|
| 115 |  D WARN^OCXOCMPV(" '"_PARM_"' parameter missing,  in MetaDictionary link file.",4,OCXDF,$P($T(+1)," ",1)) Q 1
 | 
|---|
| 116 |  ;
 | 
|---|
| 117 | GETPARM(FILE,INST,PARM) ;
 | 
|---|
| 118 |  Q:'$L(FILE) "" Q:'$L(INST) "" Q:'$L(PARM) ""
 | 
|---|
| 119 |  N OCXP,OCXP1,OCXI,OCXTEMP,OCXGL
 | 
|---|
| 120 |  S OCXGL="^OCXS" S:(FILE=1) OCXGL="^OCXD" S:(FILE=7) OCXGL="^OCXD" S:(FILE=10) OCXGL="^OCXD"
 | 
|---|
| 121 |  S FILE=FILE/10+860
 | 
|---|
| 122 |  Q:'$D(@OCXGL@(+FILE,0)) ""
 | 
|---|
| 123 |  I (PARM=+PARM),$D(^OCXS(863.8,PARM,0)) S OCXP=PARM
 | 
|---|
| 124 |  E  S OCXP=$O(^OCXS(863.8,"B",PARM,0))
 | 
|---|
| 125 |  Q:'OCXP ""
 | 
|---|
| 126 |  I (INST=+INST),$D(@OXCGL@(FILE,INST,0)) S OCXI=INST
 | 
|---|
| 127 |  E  S OCXI=$O(@OCXGL@(FILE,"B",INST,0))
 | 
|---|
| 128 |  Q:'OCXI ""
 | 
|---|
| 129 |  M OCXTEMP=@OCXGL@(FILE,OCXI)
 | 
|---|
| 130 |  S OCXP1=$O(OCXTEMP("PAR","B",OCXP,0)) Q:'OCXP1 ""
 | 
|---|
| 131 |  Q $G(OCXTEMP("PAR",OCXP1,"VAL"))
 | 
|---|
| 132 |  ;
 | 
|---|
| 133 | PAUSE() Q:'($E(IOST,1)="C") 0
 | 
|---|
| 134 |  N ANS
 | 
|---|
| 135 |  W !,"  Press <return> to continue... " R ANS:DTIME E  Q 1
 | 
|---|
| 136 |  Q (ANS[U)
 | 
|---|
| 137 |  ;
 | 
|---|
| 138 | CONV(ARRAY) ;
 | 
|---|
| 139 |  ;
 | 
|---|
| 140 |  N TEMP,INDEX
 | 
|---|
| 141 |  M TEMP=ARRAY K ARRAY
 | 
|---|
| 142 |  K TEMP("TIMELOG"),TEMP(0)
 | 
|---|
| 143 |  S INDEX=0 F  S INDEX=$O(TEMP(INDEX)) Q:'INDEX  D
 | 
|---|
| 144 |  .N PC,SEG
 | 
|---|
| 145 |  .S SEG=$P(TEMP(INDEX),"|",1)
 | 
|---|
| 146 |  .F PC=2:1:$L(TEMP(INDEX),"|") S ARRAY(SEG,PC-1)=$P(TEMP(INDEX),"|",PC)
 | 
|---|
| 147 |  Q
 | 
|---|
| 148 |  ;
 | 
|---|