VistA-WorldVistAEHR/r/TOOLKIT-AWCM-XD-XIN-XPAR-XQ.../XTSUMBLD.m

110 lines
5.0 KiB
Mathematica

XTSUMBLD ;SF/RWF - BUILD PACKAGE INTEG ROUTINE ; 3/21/06 2:50MP
;;7.3;TOOLKIT;**11,20,66,70,94,100**;Apr 25, 1995;Build 4
A ;
K ^UTILITY($J),DIR D MSG
S DIR(0)="SM^P:Package;B:Build",DIR("A")="Build from" D ^DIR K DIR Q:X[U
G PKG:Y="P",BUILD:Y="B" Q
PKG W !!,"This will build a checksum routine for a package from the package file",!
S DIC=9.4,DIC(0)="AEMQZ" D ^DIC G EXIT:Y'>0
D NAME($P(Y(0),U,2)) G EXIT:'$D(XTRNAME)
X ^%ZOSF("RSEL") G EXIT:$O(^UTILITY($J,""))=""
G BLD
;
BUILD W !!,"This will build a checksum routine from the BUILD file."
S DIC="^XPD(9.6,",DIC(0)="AEMQZ" D ^DIC G EXIT:Y'>0 S BLDA=+Y
I $P(Y(0),U,2)'>0 W !!,"There isn't a package file pointer." G EXIT
S X=$P(^DIC(9.4,+$P(Y(0),U,2),0),U,2) D NAME(X) G EXIT:'$D(XTRNAME)
F IX=0:0 S IX=$O(^XPD(9.6,BLDA,"KRN",9.8,"NM",IX)) Q:IX'>0 S X=^(IX,0) S:'$P(X,U,3) ^UTILITY($J,$P(X,U))=""
F IX="INI","INIT","PRE" S X=$G(^XPD(9.6,BLDA,IX)) I X]"" S ^UTILITY($J,$S(X[U:$P(X,U,2),1:X))=""
G EXIT:$O(^UTILITY($J,""))=""
G BLD
;
NAME(Y) S XTRNAME=Y_"NTEG" W !,"I will create a routine ",XTRNAME
S X=XTRNAME X ^%ZOSF("TEST") I $T S DIR(0)="YA",DIR("A")="But you already have one on file! OK to replace? ",DIR("B")="NO" D ^DIR I Y'=1 K XTRNAME
Q
;
BLD S X=XTRNAME F I=0:0 K ^UTILITY($J,X) S X=$O(^UTILITY($J,X)) Q:X'[XTRNAME
I $O(^UTILITY($J,""))="" W !,"Routine list is empty" G EXIT
W !,"Calculating check-sums" S XTDT=$$NOW^XLFDT()
S X=" " F I=0:0 S X=$O(^UTILITY($J,X)) Q:X="" D
. W !,X X ^%ZOSF("TEST") I '$T W ?10,"Routine not in this UCI." Q
. X ^%ZOSF("RSUM") S ^UTILITY($J,X)=Y Q
W !,"Building routine" S RN=" ",XTRNCNT=0
B K ^UTILITY($J,0) S XTSIZE=0,XCN=0,DIE="^UTILITY($J,0,",XTRNEXT=$E(XTRNAME,1,7)_XTRNCNT,XTRNCNT=XTRNCNT+1
F I=1:1 S XT=$P($T(ROU+I),";;",2,99) D ADD Q:$E(XT,1,3)="ROU"
S @(DIE_"1,0)")=XTRNAME_$P($T(ROU+1),";;",2)_XTDT,@(DIE_"3,0)")=" ;;"_$P($T(+2),";",3)_";"_XTDT
F I=0:0 S RN=$O(^UTILITY($J,RN)) Q:RN="" S %=^(RN),XT=RN_" ;;"_% D ADD Q:XTSIZE>3700
I RN]"" S @(DIE_"6,0)")=" G CONT^"_XTRNEXT
S XCN=0,X=XTRNAME W !!,"Filing routine ",XTRNAME X ^%ZOSF("SAVE") S XTRNAME=XTRNEXT G:RN]"" B
W !," DONE",!
EXIT K ^UTILITY($J),DIC,DIR,XCN,XTRNAME,XTRNCNT,XU1,XTSIZE,XTDT,DIE,XTRNEXT,XT,X,Y
Q
ADD S XCN=XCN+1,XTSIZE=XTSIZE+$L(XT)+2,@(DIE_XCN_",0)")=XT Q
Q
CHECK ;Print the values of a set of routines.
N XPCH,X,DIR D MSG
S DIR(0)="SM^P:Package;B:Build",DIR("A")="Build from" D ^DIR K DIR Q:X[U
G CHKPKG:Y="P",CHKBLD:Y="B" Q
CHKPKG W !! K ^UTILITY($J) X ^%ZOSF("RSEL") I $O(^UTILITY($J,0))']"" W !!,"NO SELECTED ROUTINES" G EXIT
CHK2 S X=" " F XU1=0:0 S X=$O(^UTILITY($J,X)) Q:X']"" D
. W !,X,?10 X ^%ZOSF("TEST") I '$T W "Routine not in this UCI." Q
. I $G(XUCHFLG)=1 X ^%ZOSF("RSUM1") W "value = ",Y
. E X ^%ZOSF("RSUM") W "value = ",Y
. I $D(XPCH) X XPCH
. Q
W !,"done" G EXIT
CHKBLD W !!,"This will check the routines from a BUILD file."
S DIC="^XPD(9.6,",DIC(0)="AEMQZ" D ^DIC G EXIT:Y'>0
S BLDA=+Y,X=$P(Y,"^",2)
I X["*" S XPCH="S L=$T(+2^@X) I $P(L,"";"",5)'?.E1P1"""_$P(X,"*",3)_"""1P.E W ?30,""Missing patch number"""
F IX=0:0 S IX=$O(^XPD(9.6,BLDA,"KRN",9.8,"NM",IX)) Q:IX'>0 S X=^(IX,0) S:'$P(X,U,3) ^UTILITY($J,$P(X,U))=""
F IX="INI","INIT","PRE" S X=$G(^XPD(9.6,BLDA,IX)) I X]"" S ^UTILITY($J,$S(X[U:$P(X,U,2),1:X))=""
G EXIT:$O(^UTILITY($J,""))=""
G CHK2
;
MSG W !!,"This option determines the current checksum of selected routine(s)."
W !,"The Checksum of the routine is determined as follows:",!
W !,"1. Any comment line with a single semi-colon is presumed to be"
W !," followed by comments and only the line tag will be included."
W !!,"2. Line 2 will be excluded from the count.",!
W !,"3. The total value of the routine is determined (excluding"
W !," exceptions noted above) by multiplying the ASCII value of each"
W !," character by its position on the line "
I $G(XUCHFLG)=1 W "and position of the line in ",!," the routine "
W "being checked."
Q
;
CHECK1 ;New CheckSum logic
W !,"New CheckSum CHECK1^XTSUMBLD:"
N XUCHFLG S XUCHFLG=1 D CHECK
Q
;
CHCKSUM ;
W !,"This option determines the current Old (CHECK^XTSUMBLD) or New (CHECK1^XTSUMBLD) logic checksum of selected routine(s)."
N OON
S OON=$$ASKOON Q:OON<1 ;Return 1 or 2
I OON=1 D CHECK
I OON=2 D CHECK1
Q
;
ASKOON() ;
;Ask if user wants old/new checksum
;Return 1 or 2.
N DIR,DIOUT
S DIR(0)="S^1:Old;2:New",DIR("A")="New or Old Checksums",DIR("B")="New"
D ^DIR
I $D(DIRUT) S Y=-1
Q Y
ROU ;;
;; ;ISC/XTSUMBLD KERNEL - Package checksum checker ;
;; ;;0.0;
;; ;;7.3;10/1/94
;; S XT4="I 1",X=$T(+3) W !!,"Checksum routine created on ",$P(X,";",4)," by KERNEL V",$P(X,";",3),!
;;CONT F XT1=1:1 S XT2=$T(ROU+XT1) Q:XT2="" S X=$P(XT2," ",1),XT3=$P(XT2,";",3) X XT4 I $T W !,X X ^%ZOSF("TEST") S:'$T XT3=0 X:XT3 ^%ZOSF("RSUM") W ?10,$S('XT3:"Routine not in UCI",XT3'=Y:"Calculated "_$C(7)_Y_", off by "_(Y-XT3),1:"ok")
;; ;
;; K %1,%2,%3,X,Y,XT1,XT2,XT3,XT4 Q
;;ONE S XT4="I $D(^UTILITY($J,X))",X=$T(+3) W !!,"Checksum routine created on ",$P(X,";",4)," by KERNEL V",$P(X,";",3),!
;; W !,"Check a subset of routines:" K ^UTILITY($J) X ^%ZOSF("RSEL")
;; W ! G CONT
;;ROU ;;