69 lines
3.2 KiB
Mathematica
69 lines
3.2 KiB
Mathematica
|
XBSUMBLD ; IHS/ADC/GTH - ROUTINE INTEGRITY CHECK GENERATOR ; [ 10/29/2002 7:42 AM ]
|
||
|
;;4.0;XB;;Jul 20, 2009;Build 2
|
||
|
; XB*3*9 IHS/SET/GTH XB*3*9 10/29/2002 Cache' mods.
|
||
|
;
|
||
|
; This routine requests the user 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.
|
||
|
;
|
||
|
; The VA's equivalent routine is XTSUMBLD, which will also create
|
||
|
; integrity checking routine(s).
|
||
|
;
|
||
|
START ;
|
||
|
W !,"NOTE: The VA's equivalent routine is XTSUMBLD, which"
|
||
|
W !," will also create integrity checking routine(s).",!!
|
||
|
Q:'$$DIR^XBDIR("E")
|
||
|
NEW BYTE,COUNT,QUIT,RTDATE,RTN,RTNAME,VERSION
|
||
|
KILL ^UTILITY($J),^TMP("XBSUMBLD",$J)
|
||
|
D ^XBKVAR
|
||
|
X ^%ZOSF("RSEL")
|
||
|
I $O(^UTILITY($J,""))="" D EOJ Q
|
||
|
S RTNAME=$$DIR^XBDIR("F^5:8^K:X'?1U.U X","Enter name of routine to be generated: ","","","Example: APCDINTG")
|
||
|
I $D(DIRUT) D EOJ Q
|
||
|
D CHECKRTN
|
||
|
I 'Y D EOJ Q
|
||
|
S VERSION=" ;;"_$$DIR^XBDIR("F^1:5^K:'(X?1.2N!(X?1.2N1"".""1.2N)) X","Enter version number","","","Must be n or n.n where the length of n is 1-2")
|
||
|
I $D(DIRUT) D EOJ Q
|
||
|
S VERSION=VERSION_";"_$$DIR^XBDIR("FO^2:30","Enter package name")
|
||
|
I $D(DTOUT)!($D(DUOUT)) D EOJ Q
|
||
|
; begin Y2K fix block
|
||
|
;S Y=$$DIR^XBDIR("D","Enter date","TODAY")
|
||
|
S Y=$$DIR^XBDIR("D^::E","Enter date","TODAY") ;Y2000
|
||
|
; end Y2K fix block
|
||
|
I $D(DIRUT) D EOJ Q
|
||
|
D DD^%DT
|
||
|
S RTDATE=Y,VERSION=VERSION_";;"_Y
|
||
|
F %=1:1:11 S X=$P($T(@("LINE"_%)),";;",2,99),@("XBSUMBLD("_%_")=X")
|
||
|
F %=1:1:3 S X=$P($T(@("CODE"_%)),";;",2,99),@("XBSUMBLD(""CODE"_%_""")=X")
|
||
|
KILL %,X,Y
|
||
|
X XBSUMBLD(1)
|
||
|
Q
|
||
|
;
|
||
|
CHECKRTN ;
|
||
|
S Y=1,X=RTNAME
|
||
|
X ^%ZOSF("TEST")
|
||
|
E Q
|
||
|
S Y=$$DIR^XBDIR("YO","Routine already exists. Want to recreate it","NO")
|
||
|
I $D(DIRUT) S Y=0
|
||
|
Q
|
||
|
;
|
||
|
EOJ ;
|
||
|
KILL %,DTOUT,DUOUT,DIRUT,DIROUT,X,XBSUMBLD,Y,^UTILITY($J)
|
||
|
Q
|
||
|
;IHS/SET/GTH XB*3*9 10/29/2002 LINE2 mod'd seed of RTN from "" to 0.
|
||
|
; The only good thing I can say about the following is that it works.
|
||
|
LINE1 ;;X XBSUMBLD(2),XBSUMBLD(6),XBSUMBLD(11)
|
||
|
LINE2 ;;S RTN=0 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 XBSUMBLD(4),XBSUMBLD(3),XBSUMBLD(5)
|
||
|
LINE3 ;;F I=2:1 S X=$T(+I) Q:X="" X XBSUMBLD(4)
|
||
|
LINE4 ;;F J=1:1 S Y=$E(X,J) Q:Y="" S BYTE=BYTE+1,COUNT=COUNT+$A(Y)
|
||
|
LINE5 ;;S ^TMP("XBSUMBLD",$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 XBSUMBLD(7),XBSUMBLD(8),XBSUMBLD(9),XBSUMBLD(10) ZS @RTNAME
|
||
|
LINE7 ;;F I=1:1:3 S V="CODE"_I S Z=XBSUMBLD(V) Q:Z="" ZI Z
|
||
|
LINE8 ;;ZI " Q" ZI " ;" ZI "LINE1 ;;X XBSUMBLD(2),XBSUMBLD(6)" F I=2:1:4 S Z="LINE"_I_" ;;"_XBSUMBLD(I) ZI Z
|
||
|
LINE9 ;;ZI "LINE5 ;;S B=$P(^UTILITY($J,RTN),""^"",1),C=$P(^(RTN),""^"",2) I B'=BYTE!(C'=COUNT) W "" has been modified""" ZI "LINE6 ;;K XBSUMBLD,B,C,I,J,R,X,Y" ZI " ;" ZI "LIST ;"
|
||
|
LINE10 ;;S RTN="" F S RTN=$O(^TMP("XBSUMBLD",$J,RTN)) Q:RTN="" S Z=^(RTN),Z=" ;;"_RTN_"^"_Z ZI Z
|
||
|
LINE11 ;;K %,XBSUMBLD,DTOUT,DUOUT,DIRUT,DIROUT,I,J,V,X,Y,Z,^UTILITY($J),^TMP("XBSUMBLD",$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),@("XBSUMBLD("_I_")=X")
|
||
|
CODE3 ;; X XBSUMBLD(1)
|