XBINTEG ; ROUTINE INTEGRITY CHECK
;;2.6;IHS UTILITIES;;JUN 28, 1993
;
; This routine calls ^%RSEL to select a set of routines and generates
; an integrity checking routine for the selected routines. The user
; is asked to enter the name of the generated routine.
;
START ;
NEW BYTE,COUNT,QUIT,RTDATE,RTN,RTNAME,VERSION
K ^UTILITY($J),^UTILITY("XBINTEG",$J)
D ^XBKVAR
;D ^%RSEL K QUIT
X ^%ZOSF("RSEL")
I $O(^UTILITY($J,""))="" D EOJ Q
S DIR(0)="F^5:8^K:X'?1U.U X",DIR("A")="Enter name of routine to be generated: ",DIR("?")="Example: APCDINTG" D ^DIR K DIR
I $D(DIRUT) D EOJ Q
S RTNAME=Y
D CHECKRTN
I 'Y D EOJ Q
S DIR(0)="F^1:5^K:'(X?1.2N!(X?1.2N1"".""1.2N)) X",DIR("A")="Enter version number",DIR("?")="Must be n or n.n where the length of n is 1-2" D ^DIR K DIR
I $D(DIRUT) D EOJ Q
S VERSION=" ;;"_X
S DIR(0)="FO^2:30",DIR("A")="Enter package name" D ^DIR K DIR
I $D(DTOUT)!($D(DUOUT)) D EOJ Q
S VERSION=VERSION_";"_X
S DIR(0)="D",DIR("A")="Enter date",DIR("B")="TODAY" D ^DIR K DIR
I $D(DIRUT) D EOJ Q
D DD^%DT
S RTDATE=Y
S VERSION=VERSION_";;"_Y
F %=1:1:11 S X=$P($T(@("LINE"_%)),";;",2,99),@("XBINTEG("_%_")=X")
F %=1:1:3 S X=$P($T(@("CODE"_%)),";;",2,99),@("XBINTEG(""CODE"_%_""")=X")
K %,X,Y
X XBINTEG(1)
Q
;
CHECKRTN ;
S Y=1
Q:'$D(^DD("OS"))#2
Q:'$D(^DD("OS",^DD("OS"),18))#2
S X=RTNAME X ^(18)
E Q
S DIR(0)="YO",DIR("A")="Routine already exists. Want to recreate it",DIR("B")="NO" D ^DIR K DIR
I $D(DIRUT) S Y=0 Q
Q
;
EOJ ;
K %,X,Y,XBINTEG,^UTILITY($J)
K DTOUT,DUOUT,DIRUT,DIROUT
Q
;
; The only good thing I can say about the following is that it works.
LINE1 ;;X XBINTEG(2),XBINTEG(6),XBINTEG(11)
LINE2 ;;S RTN="" F S RTN=$O(^UTILITY($J,RTN)) Q:RTN="" W !,RTN ZL @RTN S (BYTE,COUNT)=0 S X=$T(+1),X=$P(X," [ ",1) X XBINTEG(4),XBINTEG(3),XBINTEG(5)
LINE3 ;;F I=2:1 S X=$T(+I) Q:X="" X XBINTEG(4)
LINE4 ;;F J=1:1 S Y=$E(X,J) Q:Y="" S BYTE=BYTE+1,COUNT=COUNT+$A(Y)
LINE5 ;;S ^UTILITY("XBINTEG",$J,RTN)=BYTE_"^"_COUNT
LINE6 ;;ZR S X=RTNAME_" ;INTEGRITY CHECKER;"_RTDATE ZI X ZI VERSION ZI " ;" ZI "START ;" ZI " NEW BYTE,COUNT,RTN" ZI " K ^UTILITY($J)" X XBINTEG(7),XBINTEG(8),XBINTEG(9),XBINTEG(10) ZS @RTNAME
LINE7 ;;F I=1:1:3 S V="CODE"_I S Z=XBINTEG(V) Q:Z="" ZI Z
LINE8 ;;ZI " Q" ZI " ;" ZI "LINE1 ;;X XBINTEG(2),XBINTEG(6)" F I=2:1:4 S Z="LINE"_I_" ;;"_XBINTEG(I) ZI Z
LINE9 ;;ZI "LINE5 ;;S B=$P(^(RTN),""^"",1),C=$P(^(RTN),""^"",2) I B'=BYTE!(C'=COUNT) W "" has been modified""" ZI "LINE6 ;;K XBINTEG,B,C,I,J,R,X,Y" ZI " ;" ZI "LIST ;"
LINE10 ;;S RTN="" F S RTN=$O(^UTILITY("XBINTEG",$J,RTN)) Q:RTN="" S Z=^(RTN),Z=" ;;"_RTN_"^"_Z ZI Z
LINE11 ;;K %,XBINTEG,DTOUT,DUOUT,DIRUT,DIROUT,I,J,V,X,Y,Z,^UTILITY($J),^UTILITY("XBINTEG",$J)
CODE1 ;; F I=1:1 S X=$T(LIST+I) Q:X="" S X=$P(X,";;",2),R=$P(X,"^",1),B=$P(X,"^",2),C=$P(X,"^",3),^UTILITY($J,R)=B_"^"_C
CODE2 ;; F I=1:1:6 S X=$P($T(@("LINE"_I)),";;",2,99),@("XBINTEG("_I_")=X")
CODE3 ;; X XBINTEG(1)
XBINTEG ; ROUTINE INTEGRITY CHECK
+1 ;;2.6;IHS UTILITIES;;JUN 28, 1993
+2 ;
+3 ; This routine calls ^%RSEL to select a set of routines and generates
+4 ; an integrity checking routine for the selected routines. The user
+5 ; is asked to enter the name of the generated routine.
+6 ;
START ;
+1 NEW BYTE,COUNT,QUIT,RTDATE,RTN,RTNAME,VERSION
+2 KILL ^UTILITY($JOB),^UTILITY("XBINTEG",$JOB)
+3 DO ^XBKVAR
+4 ;D ^%RSEL K QUIT
+5 XECUTE ^%ZOSF("RSEL")
+6 IF $ORDER(^UTILITY($JOB,""))=""
DO EOJ
QUIT
+7 SET DIR(0)="F^5:8^K:X'?1U.U X"
SET DIR("A")="Enter name of routine to be generated: "
SET DIR("?")="Example: APCDINTG"
DO ^DIR
KILL DIR
+8 IF $DATA(DIRUT)
DO EOJ
QUIT
+9 SET RTNAME=Y
+10 DO CHECKRTN
+11 IF 'Y
DO EOJ
QUIT
+12 SET DIR(0)="F^1:5^K:'(X?1.2N!(X?1.2N1"".""1.2N)) X"
SET DIR("A")="Enter version number"
SET DIR("?")="Must be n or n.n where the length of n is 1-2"
DO ^DIR
KILL DIR
+13 IF $DATA(DIRUT)
DO EOJ
QUIT
+14 SET VERSION=" ;;"_X
+15 SET DIR(0)="FO^2:30"
SET DIR("A")="Enter package name"
DO ^DIR
KILL DIR
+16 IF $DATA(DTOUT)!($DATA(DUOUT))
DO EOJ
QUIT
+17 SET VERSION=VERSION_";"_X
+18 SET DIR(0)="D"
SET DIR("A")="Enter date"
SET DIR("B")="TODAY"
DO ^DIR
KILL DIR
+19 IF $DATA(DIRUT)
DO EOJ
QUIT
+20 DO DD^%DT
+21 SET RTDATE=Y
+22 SET VERSION=VERSION_";;"_Y
+23 FOR %=1:1:11
SET X=$PIECE($TEXT(@("LINE"_%)),";;",2,99)
SET @("XBINTEG("_%_")=X")
+24 FOR %=1:1:3
SET X=$PIECE($TEXT(@("CODE"_%)),";;",2,99)
SET @("XBINTEG(""CODE"_%_""")=X")
+25 KILL %,X,Y
+26 XECUTE XBINTEG(1)
+27 QUIT
+28 ;
CHECKRTN ;
+1 SET Y=1
+2 IF '$DATA(^DD("OS"))#2
QUIT
+3 IF '$DATA(^DD("OS",^DD("OS"),18))#2
QUIT
+4 SET X=RTNAME
XECUTE ^(18)
+5 IF '$TEST
QUIT
+6 SET DIR(0)="YO"
SET DIR("A")="Routine already exists. Want to recreate it"
SET DIR("B")="NO"
DO ^DIR
KILL DIR
+7 IF $DATA(DIRUT)
SET Y=0
QUIT
+8 QUIT
+9 ;
EOJ ;
+1 KILL %,X,Y,XBINTEG,^UTILITY($JOB)
+2 KILL DTOUT,DUOUT,DIRUT,DIROUT
+3 QUIT
+4 ;
+5 ; The only good thing I can say about the following is that it works.
LINE1 ;;X XBINTEG(2),XBINTEG(6),XBINTEG(11)
LINE2 ;;S RTN="" F S RTN=$O(^UTILITY($J,RTN)) Q:RTN="" W !,RTN ZL @RTN S (BYTE,COUNT)=0 S X=$T(+1),X=$P(X," [ ",1) X XBINTEG(4),XBINTEG(3),XBINTEG(5)
LINE3 ;;F I=2:1 S X=$T(+I) Q:X="" X XBINTEG(4)
LINE4 ;;F J=1:1 S Y=$E(X,J) Q:Y="" S BYTE=BYTE+1,COUNT=COUNT+$A(Y)
LINE5 ;;S ^UTILITY("XBINTEG",$J,RTN)=BYTE_"^"_COUNT
LINE6 ;;ZR S X=RTNAME_" ;INTEGRITY CHECKER;"_RTDATE ZI X ZI VERSION ZI " ;" ZI "START ;" ZI " NEW BYTE,COUNT,RTN" ZI " K ^UTILITY($J)" X XBINTEG(7),XBINTEG(8),XBINTEG(9),XBINTEG(10) ZS @RTNAME
LINE7 ;;F I=1:1:3 S V="CODE"_I S Z=XBINTEG(V) Q:Z="" ZI Z
LINE8 ;;ZI " Q" ZI " ;" ZI "LINE1 ;;X XBINTEG(2),XBINTEG(6)" F I=2:1:4 S Z="LINE"_I_" ;;"_XBINTEG(I) ZI Z
LINE9 ;;ZI "LINE5 ;;S B=$P(^(RTN),""^"",1),C=$P(^(RTN),""^"",2) I B'=BYTE!(C'=COUNT) W "" has been modified""" ZI "LINE6 ;;K XBINTEG,B,C,I,J,R,X,Y" ZI " ;" ZI "LIST ;"
LINE10 ;;S RTN="" F S RTN=$O(^UTILITY("XBINTEG",$J,RTN)) Q:RTN="" S Z=^(RTN),Z=" ;;"_RTN_"^"_Z ZI Z
LINE11 ;;K %,XBINTEG,DTOUT,DUOUT,DIRUT,DIROUT,I,J,V,X,Y,Z,^UTILITY($J),^UTILITY("XBINTEG",$J)
CODE1 ;; F I=1:1 S X=$T(LIST+I) Q:X="" S X=$P(X,";;",2),R=$P(X,"^",1),B=$P(X,"^",2),C=$P(X,"^",3),^UTILITY($J,R)=B_"^"_C
CODE2 ;; F I=1:1:6 S X=$P($T(@("LINE"_I)),";;",2,99),@("XBINTEG("_I_")=X")
CODE3 ;; X XBINTEG(1)