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

OCXDIAG.m

Go to the documentation of this file.
  1. OCXDIAG ;SLC/RJS,CLA - OCX PACKAGE DIAGNOSTIC UTILITY ROUTINE ;SEP 7,1999 at 10:30
  1. ;;3.0;ORDER ENTRY/RESULTS REPORTING;**32**;Dec 17,1997
  1. ;; ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
  1. ;
  1. S ;
  1. ;
  1. N QUIT,LINE,TEXT,REMOTE,LOCAL,D0,OPCODE,REF,OCXFLGA,OCXFLGC,OCXFLGR,OCXFLGD S QUIT=0
  1. ;
  1. D DOT
  1. I $L($T(VERSION^OCXOCMP)),($$VERSION^OCXOCMP="ORDER CHECK EXPERT version 1.01 released OCT 29,1998"),1
  1. E D Q
  1. .W !
  1. .W !,"Diagnostic aborted, version mismatch."
  1. .W !,"Current Local version: ",$$VERSION^OCXOCMP
  1. .W !," Diagnostic Version: ORDER CHECK EXPERT version 1.01 released OCT 29,1998"
  1. I '$D(DTIME) W !!,"DTIME not defined !!",!! Q
  1. W !!,"Order Check Expert System Diagnostic Tool"
  1. W !," Created: SEP 7,1999 at 10:30 in UCI: OEX,OER"
  1. W !," Current Date: ",$$NOW^OCXDI0," Current UCI: ",$$CUCI^OCXBDT,!!
  1. S LASTFILE=0 K ^TMP("OCXDIAG",$J)
  1. S ^TMP("OCXDIAG",$J)=($P($H,",",2)+($H*86400)+(4*60*60))_" <- ^TMP ENTRY EXPIRATION DATE FOR ^OCXOPURG"
  1. S (OCXFLGR,OCXFLGC,OCXFLGA)=1
  1. S OCXFLGC=$$READ^OCXDI2("Y"," Do you want ^OCXDIAG to fix differences ?","YES") Q:(OCXFLGC[U)
  1. I OCXFLGC S OCXFLGA=$$READ^OCXDI2("Y"," Do you want to stop and ask before each change ?","YES") Q:(OCXFLGA[U)
  1. S OCXFLGD=$$READ^OCXDI2("Y"," Do you want ^OCXDIAG to check for extra local records ?","NO") Q:(OCXFLGD[U)
  1. ;
  1. RUN ;
  1. ;
  1. ; OCXFLGR = 0-> NO REPORT 1-> REPORT
  1. ; OCXFLGA = 0-> NO ASK 1-> ASK
  1. ; OCXFLGC = 0-> NO CHANGE 1-> CHANGE
  1. ; OCXFLGD = 0-> NO CHECK FOR EXTRAS 1-> CHECK
  1. ;
  1. D MESG("Loading Data ") D ^OCXDI001
  1. ;
  1. S LINE=0 F S LINE=$O(^TMP("OCXDIAG",$J,LINE)) Q:'LINE D Q:QUIT
  1. .D:'(LINE#50) STATUS^OCXOPOST(LINE,$O(^TMP("OCXDIAG",$J," "),-1))
  1. .S TEXT=$G(^TMP("OCXDIAG",$J,LINE)) I $L(TEXT) D Q:QUIT
  1. ..S TEXT=$P(TEXT,";",2,999),OPCODE=$P(TEXT,U,1),TEXT=$P(TEXT,U,2,999)
  1. ..;
  1. ..I OPCODE="RTN" K RSUM S RSUM(0)=TEXT Q
  1. ..I OPCODE="RSUM" S RSUM($O(RSUM(""),-1)+1)=TEXT Q
  1. ..I OPCODE="RND" S QUIT=$$RTN^OCXDI0(.RSUM) Q
  1. ..I OPCODE="REND" K RSUM D MESG("Scanning Data Files ") Q
  1. ..I OPCODE="RSTRT" D MESG("Scanning Routines ") Q
  1. ..I OPCODE="KEY" D DOT S LOCAL="",D0=$$GETFILE^OCXDI0(+$P(TEXT,U,1),$P(TEXT,U,2),.LOCAL) S QUIT=(D0=(-10)) Q
  1. ..I OPCODE="R" S REF="REMOTE("_$P($P(TEXT,U,1),":",1)_":"_D0_$P($P(TEXT,U,1),":",2,99)_")" Q
  1. ..I OPCODE="D",$D(REF) S @REF=$P(TEXT,U,1,999) K REF Q
  1. ..;
  1. ..I OPCODE="EOR" S QUIT=$$COMPARE^OCXDI1(.LOCAL,.REMOTE) K LOCAL,REMOTE Q
  1. ..I OPCODE="EOF" S QUIT=$$LISTFILE^OCXDI0(U_$P(TEXT,U,1),(+$P(TEXT,U,2)&OCXFLGD)) K LOCAL,REMOTE Q
  1. ..I OPCODE="SOF" D MESG(" Scanning '"_(TEXT)_"' file ") S:(('OCXFLGA)&(+TEXT=101.41)) OCXFLGC=0 Q
  1. ..I OPCODE="ROOT" D Q
  1. ...N FILE,DATA
  1. ...S FILE=U_$P(TEXT,U,1),DATA=$P(TEXT,U,2,3)
  1. ...Q:$D(@FILE)
  1. ...S @FILE=DATA
  1. ...D MESG(" Restoring file #"_(+$P(DATA,U,2))_" zero node")
  1. ..;
  1. ..W !,"Unknown OpCode: ",OPCODE," in: ",TEXT S QUIT=$$PAUSE^OCXDI0 W !
  1. ;
  1. D MESG("Checking protocols ") Q:$$EN^OCXDI5
  1. ;
  1. K ^TMP("OCXDIAG",$J)
  1. ;
  1. D MESG("Diagnostic Finished...")
  1. ;
  1. Q
  1. ;
  1. AUTO ;
  1. ;
  1. N QUIT,LINE,TEXT,REMOTE,LOCAL,D0,OPCODE,REF,OCXFLGA,OCXFLGC,OCXFLGR,OCXFLGD S QUIT=0
  1. ;
  1. S LASTFILE=0 K ^TMP("OCXDIAG",$J)
  1. S ^TMP("OCXDIAG",$J)=($P($H,",",2)+($H*86400)+(4*60*60))_" <- ^TMP ENTRY EXPIRATION DATE FOR ^OCXOPURG"
  1. S (OCXFLGD,OCXFLGA,OCXFLGR)=0,(OCXAUTO,OCXFLGC)=1
  1. ;
  1. D MESG(" ")
  1. D MESG("Order Check Expert System Diagnostic Tool")
  1. D MESG(" Created: SEP 7,1999 at 10:30 in UCI: OEX,OER")
  1. D MESG(" Current Date: "_($$NOW^OCXDI0)_" Current UCI: "_($$CUCI^OCXBDT))
  1. D MESG(" ")
  1. D MESG(" ")
  1. ;
  1. D RUN
  1. ;
  1. Q
  1. ;
  1. MESG(X) ;
  1. ;
  1. I '$G(OCXAUTO) W !,X
  1. E D BMES^XPDUTL(.X)
  1. Q
  1. ;
  1. ;
  1. DOT Q:$G(OCXAUTO) W:($X>70) ! W " ." Q
  1. ;