- OCXDI0 ;SLC/RJS,CLA - OCX PACKAGE DIAGNOSTIC UTILITY ROUTINE ;SEP 7,1999 at 10:30
- ;;3.0;ORDER ENTRY/RESULTS REPORTING;**32**;Dec 17,1997
- ;; ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
- ;
- S ;
- ;
- Q
- ;
- RTN(RSUM) ;
- ;
- D DOT^OCXDIAG
- ;
- N CHAR,CSUM,DASH,LINE,MSG,RNDX,RPC,RTN,TEXT,X,RCSM,RDIFF
- ;
- S RCSM(3)="",RTN=$P(RSUM(0),U,1)
- F RNDX=1:1 Q:'$D(RSUM(RNDX)) F RPC=1:1:$L(RSUM(RNDX),U) S RCSM($O(RCSM(""),-1)+1)=$P(RSUM(RNDX),U,RPC)
- K RCSM(3)
- ;
- S X=RTN X ^%ZOSF("TEST") E D WARN(RTN,"Routine not in local system") Q 0
- ;
- F LINE=4:1 S TEXT=$$TEXT(RTN,LINE) Q:'$L(TEXT) I '$D(RCSM(LINE)) S RDIFF(LINE)=""
- S LINE=0 F S LINE=$O(RCSM(LINE)) Q:'LINE S TEXT=$$TEXT(RTN,LINE) D
- .S CSUM=0 F CHAR=1:1:$L(TEXT) S CSUM=CSUM+($A(TEXT,CHAR)*CHAR)
- .I '(RCSM(LINE)=(+(CSUM_"."_$L(TEXT)_"1"))) S RDIFF(LINE)=""
- ;
- Q:'$O(RDIFF(0)) 0
- ;
- D WARN(RTN,"Checksums do not match",.RDIFF)
- ;
- Q 0
- ;
- WARN(RTN,MSG,LINES) ;
- ;
- Q:$G(OCXAUTO)
- ;
- N DASH,LINE,NLINE,PLINE
- ;
- S DASH="",$P(DASH,"-",(55-$L(MSG)-2))="-"
- W !!,"----WARNING-","--",MSG,DASH
- ;
- W !,RTN,?10,"[OEX,OER] -> [",$$CUCI^OCXBDT,"] Line"
- ;
- I $O(LINES($O(LINES(0)))) W "s: "
- E W ": "
- ;
- S LINE=0 F S LINE=$O(LINES(LINE)) Q:'LINE D
- .W:($X>60) !,?40
- .S NLINE=LINE F S PLINE=NLINE,NLINE=$O(LINES(NLINE)) Q:(NLINE-PLINE-1)
- .I (PLINE=LINE) W " ",LINE
- .E W " ",LINE,"-",PLINE S LINE=PLINE
- ;
- W ! Q
- ;
- TEXT(RTN,LINE) ;
- ;
- N TEXT X "S TEXT=$T(+"_(+LINE)_"^"_RTN_")" Q TEXT
- ;
- ;
- W !," Created: SEP 7,1999 at 10:30 in UCI: OEX,OER"
- W !," Current Date: ",$$NOW," Current UCI: ",$$CUCI^OCXBDT,!!
- S LASTFILE=0
- K ^TMP("OCXDIAG",$J)
- S ^TMP("OCXDIAG",$J)=($P($H,",",2)+($H*86400)+(1*60*60))_" <- ^TMP ENTRY EXPIRATION DATE FOR ^OCXOPURG"
- Q
- ;
- LISTFILE(GLREF,SCANDUP) ;
- ;
- Q:($L(GLREF)<2) 0
- N D0,NAME,FILE,QUIT,CNT,FILENUM
- S QUIT=0,FILE=$P($G(@GLREF@(0)),U,1),FILENUM=+$P($G(@GLREF@(0)),U,2)
- I '$L(FILE) W !!,"Cannot find File: ",GLREF Q $$PAUSE
- I SCANDUP S (QUIT,D0)=0 F CNT=0:1 S D0=$O(@GLREF@(D0)) Q:'D0 S NAME=$P($G(@GLREF@(D0,0)),U,1) D Q:QUIT
- .D DOT^OCXDIAG
- .I '$L(NAME) W !,GLREF," ",FILE," -> Record #",D0," does not have a name." S QUIT=$$PAUSE Q
- .I OCXFLGR,'$D(^TMP("OCXDIAG",$J,"A",FILENUM,NAME)) D
- ..W !!," Extra Record in (L) ",$$CUCI^OCXBDT," - ",FILE,": ",NAME,"."
- ..S QUIT=$$DELREC^OCXDI2(FILENUM,D0)
- Q QUIT
- ;
- GETFILE(FILE,RECNAME,ARRAY) ;
- ;
- N CHECK,GLNEXT,GLREF,LINES,REC,DD,FLD
- S REC=$$LOOKUP(FILE,RECNAME)
- I 'REC W:OCXFLGR !!,$$FILENAME^OCXBDTD(FILE),": ",RECNAME," not found." Q 0
- I (REC=-1) W:OCXFLGR !!,$$FILENAME^OCXBDTD(FILE),": ",RECNAME," duplicate local entries.",! S REC=$$DELDUP^OCXDI2(FILE,RECNAME)
- I (REC=-2) W:OCXFLGR !!,$$FILENAME^OCXBDTD(FILE)," (",FILE,") local file not found." W ! Q:$$PAUSE -10 Q REC
- I (REC<0) W:OCXFLGR !!,$$FILENAME^OCXBDTD(FILE),": ",RECNAME," unknown error." W ! Q:$$PAUSE -10 Q REC
- I (REC>0) D
- .S CHECK=0,LINES=0
- .D GETREC($$FILE^OCXBDTD(FILE,"GLOBAL NAME"),"ARRAY(",REC,.ARRAY)
- .S GLREF="ARRAY" F S GLREF=$Q(@GLREF) Q:'$L(GLREF) Q:'($E(GLREF,1,6)="ARRAY(") K:'$L(@GLREF) @GLREF
- ;
- Q REC
- ;
- LKUPARRY(DD,KEY,ARRAY) ;
- ;
- N D0 S D0=0 F S D0=$O(ARRAY(DD,D0)) Q:'D0 Q:($G(ARRAY(DD,D0,.01,"E"))=KEY)
- Q D0
- ;
- LOOKUP(FILE,KEY) ;
- I $O(^TMP("OCXDIAG",$J,"B",FILE,KEY,0)) Q 0
- N RECNAM,REC,D0,CNT,SHORT S (REC,CNT)=0
- S GL=$$FILE^OCXBDTD(FILE,"GLOBAL NAME") Q:'$L(GL) -2 S GL=$E(GL,1,$L(GL)-1)_")"
- S SHORT=$E(KEY,1,30),RECNAM=SHORT D F S RECNAM=$O(@GL@("B",RECNAM)) Q:'$L(RECNAM) Q:'($E(RECNAM,1,$L(SHORT))=SHORT) D
- .S D0=0 F S D0=$O(@GL@("B",RECNAM,D0)) Q:'D0 I ($P($G(@GL@(D0,0)),U,1)=KEY) S CNT=CNT+1,REC=D0_U_RECNAME
- Q:(CNT>1) -1
- S:$L($P(REC,U,2)) ^TMP("OCXDIAG",$J,"A",FILE,$P(REC,U,2))=""
- Q +REC
- ;
- GETREC(GL,PATH,D0,REM) ;
- ;
- Q:'($P($G(@(GL_"0)")),U,2))
- N S1,DATA,DD
- S DATA="" D DIQ(GL,D0,.DATA)
- S DD=$O(DATA(0)) Q:'DD
- ;
- I $L($$FILE^OCXBDTD(DD,"NAME")) S PATH=PATH_""""_DD_":"_D0_""""
- I '$L($$FILE^OCXBDTD(DD,"NAME")) S PATH=PATH_","""_DD_":"_D0_""""
- M @(PATH_")")=DATA(DD,D0)
- ;
- S S1="" F S S1=$O(@(GL_D0_","_$$SUB(S1)_")")) Q:'$L(S1) I ($D(@(GL_D0_","_$$SUB(S1)_")"))>3) D
- .N D1,GLREF S GLREF=GL_D0_","_$$SUB(S1)_","
- .S D1=0 F S D1=$O(@(GLREF_D1_")")) Q:'D1 D GETREC(GLREF,PATH,D1,.REM)
- ;
- Q
- ;
- SUB(X) Q:'(X=+X) """"_X_"""" Q X
- ;
- DIQ(DIC,DA,OCXARY) ;
- N DR,DIQ S DR=".01:99999",DIQ="OCXARY(",DIQ(0)="EN" D EN^DIQ1
- Q
- ;
- PAUSE() Q:'OCXFLGC 0 W " Press Enter " R X:DTIME W ! Q (X[U)
- ;
- NOW() N X,Y,%DT S X="N",%DT="T" D ^%DT S Y=$$DATE^OCXBDTD(Y) S:(Y["@") Y=$P(Y,"@",1)_" at "_$P(Y,"@",2) Q Y
- ;
- OCXDI0 ;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
- +2 ;; ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
- +3 ;
- S ;
- +1 ;
- +2 QUIT
- +3 ;
- RTN(RSUM) ;
- +1 ;
- +2 DO DOT^OCXDIAG
- +3 ;
- +4 NEW CHAR,CSUM,DASH,LINE,MSG,RNDX,RPC,RTN,TEXT,X,RCSM,RDIFF
- +5 ;
- +6 SET RCSM(3)=""
- SET RTN=$PIECE(RSUM(0),U,1)
- +7 FOR RNDX=1:1
- IF '$DATA(RSUM(RNDX))
- QUIT
- FOR RPC=1:1:$LENGTH(RSUM(RNDX),U)
- SET RCSM($ORDER(RCSM(""),-1)+1)=$PIECE(RSUM(RNDX),U,RPC)
- +8 KILL RCSM(3)
- +9 ;
- +10 SET X=RTN
- XECUTE ^%ZOSF("TEST")
- IF '$TEST
- DO WARN(RTN,"Routine not in local system")
- QUIT 0
- +11 ;
- +12 FOR LINE=4:1
- SET TEXT=$$TEXT(RTN,LINE)
- IF '$LENGTH(TEXT)
- QUIT
- IF '$DATA(RCSM(LINE))
- SET RDIFF(LINE)=""
- +13 SET LINE=0
- FOR
- SET LINE=$ORDER(RCSM(LINE))
- IF 'LINE
- QUIT
- SET TEXT=$$TEXT(RTN,LINE)
- Begin DoDot:1
- +14 SET CSUM=0
- FOR CHAR=1:1:$LENGTH(TEXT)
- SET CSUM=CSUM+($ASCII(TEXT,CHAR)*CHAR)
- +15 IF '(RCSM(LINE)=(+(CSUM_"."_$LENGTH(TEXT)_"1")))
- SET RDIFF(LINE)=""
- End DoDot:1
- +16 ;
- +17 IF '$ORDER(RDIFF(0))
- QUIT 0
- +18 ;
- +19 DO WARN(RTN,"Checksums do not match",.RDIFF)
- +20 ;
- +21 QUIT 0
- +22 ;
- WARN(RTN,MSG,LINES) ;
- +1 ;
- +2 IF $GET(OCXAUTO)
- QUIT
- +3 ;
- +4 NEW DASH,LINE,NLINE,PLINE
- +5 ;
- +6 SET DASH=""
- SET $PIECE(DASH,"-",(55-$LENGTH(MSG)-2))="-"
- +7 WRITE !!,"----WARNING-","--",MSG,DASH
- +8 ;
- +9 WRITE !,RTN,?10,"[OEX,OER] -> [",$$CUCI^OCXBDT,"] Line"
- +10 ;
- +11 IF $ORDER(LINES($ORDER(LINES(0))))
- WRITE "s: "
- +12 IF '$TEST
- WRITE ": "
- +13 ;
- +14 SET LINE=0
- FOR
- SET LINE=$ORDER(LINES(LINE))
- IF 'LINE
- QUIT
- Begin DoDot:1
- +15 IF ($X>60)
- WRITE !,?40
- +16 SET NLINE=LINE
- FOR
- SET PLINE=NLINE
- SET NLINE=$ORDER(LINES(NLINE))
- IF (NLINE-PLINE-1)
- QUIT
- +17 IF (PLINE=LINE)
- WRITE " ",LINE
- +18 IF '$TEST
- WRITE " ",LINE,"-",PLINE
- SET LINE=PLINE
- End DoDot:1
- +19 ;
- +20 WRITE !
- QUIT
- +21 ;
- TEXT(RTN,LINE) ;
- +1 ;
- +2 NEW TEXT
- XECUTE "S TEXT=$T(+"_(+LINE)_"^"_RTN_")"
- QUIT TEXT
- +3 ;
- +1 ;
- +2 WRITE !," Created: SEP 7,1999 at 10:30 in UCI: OEX,OER"
- +3 WRITE !," Current Date: ",$$NOW," Current UCI: ",$$CUCI^OCXBDT,!!
- +4 SET LASTFILE=0
- +5 KILL ^TMP("OCXDIAG",$JOB)
- +6 SET ^TMP("OCXDIAG",$JOB)=($PIECE($HOROLOG,",",2)+($HOROLOG*86400)+(1*60*60))_" <- ^TMP ENTRY EXPIRATION DATE FOR ^OCXOPURG"
- +7 QUIT
- +8 ;
- LISTFILE(GLREF,SCANDUP) ;
- +1 ;
- +2 IF ($LENGTH(GLREF)<2)
- QUIT 0
- +3 NEW D0,NAME,FILE,QUIT,CNT,FILENUM
- +4 SET QUIT=0
- SET FILE=$PIECE($GET(@GLREF@(0)),U,1)
- SET FILENUM=+$PIECE($GET(@GLREF@(0)),U,2)
- +5 IF '$LENGTH(FILE)
- WRITE !!,"Cannot find File: ",GLREF
- QUIT $$PAUSE
- +6 IF SCANDUP
- SET (QUIT,D0)=0
- FOR CNT=0:1
- SET D0=$ORDER(@GLREF@(D0))
- IF 'D0
- QUIT
- SET NAME=$PIECE($GET(@GLREF@(D0,0)),U,1)
- Begin DoDot:1
- +7 DO DOT^OCXDIAG
- +8 IF '$LENGTH(NAME)
- WRITE !,GLREF," ",FILE," -> Record #",D0," does not have a name."
- SET QUIT=$$PAUSE
- QUIT
- +9 IF OCXFLGR
- IF '$DATA(^TMP("OCXDIAG",$JOB,"A",FILENUM,NAME))
- Begin DoDot:2
- +10 WRITE !!," Extra Record in (L) ",$$CUCI^OCXBDT," - ",FILE,": ",NAME,"."
- +11 SET QUIT=$$DELREC^OCXDI2(FILENUM,D0)
- End DoDot:2
- End DoDot:1
- IF QUIT
- QUIT
- +12 QUIT QUIT
- +13 ;
- GETFILE(FILE,RECNAME,ARRAY) ;
- +1 ;
- +2 NEW CHECK,GLNEXT,GLREF,LINES,REC,DD,FLD
- +3 SET REC=$$LOOKUP(FILE,RECNAME)
- +4 IF 'REC
- IF OCXFLGR
- WRITE !!,$$FILENAME^OCXBDTD(FILE),": ",RECNAME," not found."
- QUIT 0
- +5 IF (REC=-1)
- IF OCXFLGR
- WRITE !!,$$FILENAME^OCXBDTD(FILE),": ",RECNAME," duplicate local entries.",!
- SET REC=$$DELDUP^OCXDI2(FILE,RECNAME)
- +6 IF (REC=-2)
- IF OCXFLGR
- WRITE !!,$$FILENAME^OCXBDTD(FILE)," (",FILE,") local file not found."
- WRITE !
- IF $$PAUSE
- QUIT -10
- QUIT REC
- +7 IF (REC<0)
- IF OCXFLGR
- WRITE !!,$$FILENAME^OCXBDTD(FILE),": ",RECNAME," unknown error."
- WRITE !
- IF $$PAUSE
- QUIT -10
- QUIT REC
- +8 IF (REC>0)
- Begin DoDot:1
- +9 SET CHECK=0
- SET LINES=0
- +10 DO GETREC($$FILE^OCXBDTD(FILE,"GLOBAL NAME"),"ARRAY(",REC,.ARRAY)
- +11 SET GLREF="ARRAY"
- FOR
- SET GLREF=$QUERY(@GLREF)
- IF '$LENGTH(GLREF)
- QUIT
- IF '($EXTRACT(GLREF,1,6)="ARRAY(")
- QUIT
- IF '$LENGTH(@GLREF)
- KILL @GLREF
- End DoDot:1
- +12 ;
- +13 QUIT REC
- +14 ;
- LKUPARRY(DD,KEY,ARRAY) ;
- +1 ;
- +2 NEW D0
- SET D0=0
- FOR
- SET D0=$ORDER(ARRAY(DD,D0))
- IF 'D0
- QUIT
- IF ($GET(ARRAY(DD,D0,.01,"E"))=KEY)
- QUIT
- +3 QUIT D0
- +4 ;
- LOOKUP(FILE,KEY) ;
- +1 IF $ORDER(^TMP("OCXDIAG",$JOB,"B",FILE,KEY,0))
- QUIT 0
- +2 NEW RECNAM,REC,D0,CNT,SHORT
- SET (REC,CNT)=0
- +3 SET GL=$$FILE^OCXBDTD(FILE,"GLOBAL NAME")
- IF '$LENGTH(GL)
- QUIT -2
- SET GL=$EXTRACT(GL,1,$LENGTH(GL)-1)_")"
- +4 SET SHORT=$EXTRACT(KEY,1,30)
- SET RECNAM=SHORT
- Begin DoDot:1
- +5 SET D0=0
- FOR
- SET D0=$ORDER(@GL@("B",RECNAM,D0))
- IF 'D0
- QUIT
- IF ($PIECE($GET(@GL@(D0,0)),U,1)=KEY)
- SET CNT=CNT+1
- SET REC=D0_U_RECNAME
- End DoDot:1
- FOR
- SET RECNAM=$ORDER(@GL@("B",RECNAM))
- IF '$LENGTH(RECNAM)
- QUIT
- IF '($EXTRACT(RECNAM,1,$LENGTH(SHORT))=SHORT)
- QUIT
- Begin DoDot:1
- End DoDot:1
- +6 IF (CNT>1)
- QUIT -1
- +7 IF $LENGTH($PIECE(REC,U,2))
- SET ^TMP("OCXDIAG",$JOB,"A",FILE,$PIECE(REC,U,2))=""
- +8 QUIT +REC
- +9 ;
- GETREC(GL,PATH,D0,REM) ;
- +1 ;
- +2 IF '($PIECE($GET(@(GL_"0)")),U,2))
- QUIT
- +3 NEW S1,DATA,DD
- +4 SET DATA=""
- DO DIQ(GL,D0,.DATA)
- +5 SET DD=$ORDER(DATA(0))
- IF 'DD
- QUIT
- +6 ;
- +7 IF $LENGTH($$FILE^OCXBDTD(DD,"NAME"))
- SET PATH=PATH_""""_DD_":"_D0_""""
- +8 IF '$LENGTH($$FILE^OCXBDTD(DD,"NAME"))
- SET PATH=PATH_","""_DD_":"_D0_""""
- +9 MERGE @(PATH_")")=DATA(DD,D0)
- +10 ;
- +11 SET S1=""
- FOR
- SET S1=$ORDER(@(GL_D0_","_$$SUB(S1)_")"))
- IF '$LENGTH(S1)
- QUIT
- IF ($DATA(@(GL_D0_","_$$SUB(S1)_")"))>3)
- Begin DoDot:1
- +12 NEW D1,GLREF
- SET GLREF=GL_D0_","_$$SUB(S1)_","
- +13 SET D1=0
- FOR
- SET D1=$ORDER(@(GLREF_D1_")"))
- IF 'D1
- QUIT
- DO GETREC(GLREF,PATH,D1,.REM)
- End DoDot:1
- +14 ;
- +15 QUIT
- +16 ;
- SUB(X) IF '(X=+X)
- QUIT """"_X_""""
- QUIT X
- +1 ;
- DIQ(DIC,DA,OCXARY) ;
- +1 NEW DR,DIQ
- SET DR=".01:99999"
- SET DIQ="OCXARY("
- SET DIQ(0)="EN"
- DO EN^DIQ1
- +2 QUIT
- +3 ;
- PAUSE() IF 'OCXFLGC
- QUIT 0
- WRITE " Press Enter "
- READ X:DTIME
- WRITE !
- QUIT (X[U)
- +1 ;
- NOW() NEW X,Y,%DT
- SET X="N"
- SET %DT="T"
- DO ^%DT
- SET Y=$$DATE^OCXBDTD(Y)
- IF (Y["@")
- SET Y=$PIECE(Y,"@",1)_" at "_$PIECE(Y,"@",2)
- QUIT Y
- +1 ;