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

XTRUTL.m

Go to the documentation of this file.
  1. XTRUTL ;ISCSF/RWF - Developer Routine Utilities ;3/21/2006 2:50PM
  1. ;;7.3;TOOLKIT;**20,39,59,66,76,100**;Apr 25, 1995;Build 4
  1. ;
  1. Q ;No entry from the top.
  1. BUILD ;
  1. K ^UTILITY($J),^TMP($J) D HOME^%ZIS
  1. N BLDA,DIC,IX,X,PATCH,RTN,RN,L2,OLDSUM,OON
  1. W !!,"This generates the Checksum/2nd line list for the routines from a BUILD file."
  1. I '$D(^XPD(9.6,0)) W !,"No BUILD file to work from." Q
  1. S Y=$$BUILD^XTRUTL1 G EXIT:Y'>0 S BLDA=+Y,PATCH=+$P(Y,"*",3)
  1. D RTN^XTRUTL1(BLDA)
  1. I '$D(^UTILITY($J)) W !,"No routines in this build." G EXIT
  1. ;Ask about old/new checksums
  1. S OON=$$ASKOON Q:OON<1 ;Return 1 or 2
  1. ;S X=$P(^DIC(9.4,+$P(Y(0),U,2),0),U,2)
  1. S RN="" F S RN=$O(^UTILITY($J,RN)) Q:RN="" D Q:$D(L2)
  1. . S X=RN X ^%ZOSF("TEST") I '$T D Q
  1. . . W !,RN,?13,"Routine not in this UCI."
  1. . . K ^UTILITY($J,RN)
  1. . S L2=$T(+2^@RN)
  1. I '$D(L2) W !,"No other routines in this build." G EXIT
  1. S L2=$P(L2,";",1,4)_";**[Patch List]**;"_$P(L2,";",6,99)
  1. W !!,"Routine Summary"
  1. W !,"Checksums shown are "_$S(OON=1:"OLD",1:"NEW")_" Checksums"
  1. W !,"The following routines are included in this patch. The second line of each",!,"of these routines now looks like:"
  1. W !,L2
  1. W !!,?17,"Checksums",!,"Routine",?16,"Old",?28,"New",?39,"Patch List"
  1. S RN=""
  1. F S RN=$O(^UTILITY($J,RN)) Q:RN="" D
  1. . S RSUM=$P($$NEWSUM(RN),"/",OON) ;rwf
  1. . S OLDSUM=$$OLDSUM(RN),OLDSUM=$P(OLDSUM,"/",OON) ;rwf
  1. . S X=$G(RTN(2,0)) ;X has second line of routine
  1. . S:(+OLDSUM=0) OLDSUM="n/a " S:(+RSUM=0) RSUM="n/a "
  1. . W !,RN,?13,$J(OLDSUM,8),?25,$J(RSUM,8) D WRAP(37,$P(X,";",5))
  1. . D PTLBLD($P(X,";",5))
  1. . S Y=$P(X,"**",2),Z=$P(Y,",",$L(Y,","))
  1. . I PATCH,Z'=PATCH W " <<<No "_PATCH
  1. . Q
  1. W ! D PTLDSP
  1. W !,"Sites should use CHECK"_$S(OON=2:"1",1:"")_"^XTSUMBLD to verify checksums.",!
  1. EXIT K %
  1. Q
  1. ;
  1. ASKOON() ;Ask if user wants old/new checksum
  1. ;Return 1 or 2.
  1. N DIR,DIOUT
  1. S DIR(0)="S^1:Old;2:New",DIR("A")="New or Old Checksums",DIR("B")="New"
  1. D ^DIR
  1. I $D(DIRUT) S Y=-1
  1. Q Y
  1. ;
  1. WRAP(C,S) ;Wrap S starting at col C.
  1. I $L(S)+C<80 W ?C,S Q
  1. N I,T
  1. S I=$F(S,",",70-C) W ?C,$E(S,1,I-1) S S=$E(S,I,999)
  1. F S I=$F(S,",",70-C),I=$S(I>0:I,1:$L(S)+2) W !,?C+2,$E(S,1,I-1) S S=$E(S,I,999) Q:'$L(S)
  1. Q
  1. ;
  1. RSUM() N Y,Y2,%,%1,%2,%3 S (Y,Y2)=0
  1. F %=1,3:1:LC S %1=RTN(%,0),%3=$F(%1," "),%3=$S($E(%1,%3)'=";":$L(%1),$E(%1,%3+1)=";":$L(%1),1:%3-2) F %2=1:1:%3 S Y=$A(%1,%2)*%2+Y,Y2=$A(%1,%2)*(%2+%)+Y2
  1. ;S RSUM=Y,RSUM2=Y2
  1. Q Y_"/"_Y2
  1. ;
  1. NEWSUM(X) ;Get the NEW Checksum
  1. N XCNP,DIF K RTN I '$L($T(^@X)) Q 0
  1. S XCNP=0,DIF="RTN(" K RTN X ^%ZOSF("LOAD") S LC=XCNP-1
  1. Q $$RSUM
  1. ;
  1. OLDSUM(X) ;Get the OLD Checksum
  1. N Y S Y=$O(^DIC(9.8,"B",X,0)) Q:Y'>0 ""
  1. S X=$G(^DIC(9.8,Y,4))
  1. Q $P(X,"^",2)
  1. ;
  1. PTLBLD(Z) ;Build in ^TMP the patches used
  1. N I,J,K,P S Z=$P(Z,"**",2),K=""
  1. F I=1:1 S J=$P(Z,",",I) Q:(J="") I (J'=PATCH) S P=$G(^TMP($J,J)),^TMP($J,J)=P_K S K=K_J_","
  1. Q
  1. PTLSRT ;Sort the list
  1. N I,J,K,L S I=0
  1. F I=0:0 S I=$O(^TMP($J,I)) Q:I'>0 S K=^(I) D
  1. . F J=1:1 S L=$P(K,",",J) Q:L="" K ^TMP($J,L)
  1. . Q
  1. Q
  1. ;
  1. PTLDSP ;Display list of patches.
  1. D PTLSRT
  1. N I,J K ^TMP($J,PATCH)
  1. Q:$O(^TMP($J,0))=""
  1. W !,"List of preceding patches: "
  1. S (I,J)="" F S I=$O(^TMP($J,I)) Q:I="" D
  1. . I $X>70 W ! S J=""
  1. . W J,I S J=", "
  1. S:$L(J)>2 J=$E(J,1,$L(J)-2)
  1. Q
  1. ;
  1. UPDATE ;Update the ROUTINE file with current checksums
  1. K ^UTILITY($J)
  1. N BLDA,DIC,IX,X,NOW,DIR
  1. W !!,"This will update the ROUTINE file for the routines from a BUILD file."
  1. I '$D(^XPD(9.6,0)) W !,"No BUILD file to work from." Q
  1. S Y=$$BUILD^XTRUTL1 G EXIT:Y'>0 S BLDA=+Y
  1. S DIR(0)="Y",DIR("A")="Is "_$P(Y,U,2)_" the one you want" D ^DIR
  1. I $D(DIRUT)!(Y'=1) Q
  1. D RTN^XTRUTL1(BLDA)
  1. S NOW=$$NOW^XLFDT()
  1. G EXIT:$O(^UTILITY($J,""))=""
  1. S RN=""
  1. F S RN=$O(^UTILITY($J,RN)) Q:RN="" D UD1(RN)
  1. W !,"Done"
  1. Q
  1. ;
  1. UD1(RN) ;
  1. N X,XCNP,DIF,LC,RSUM,Y S:'$D(NOW) NOW=$$NOW^XLFDT
  1. S U="^",RSUM=$$NEWSUM(RN) Q:RSUM=0
  1. S X=RTN(2,0)
  1. S Y=$$GETDA(RN) I Y'>0 W !," Routine ",RN," not found in the database." Q
  1. I '$$LOCAL(Y) W !,"This is a national routine and will not be updated" Q
  1. S ^DIC(9.8,+Y,4)=NOW_U_RSUM_U_$P(X,";",5)
  1. Q
  1. ;
  1. SHOW(RN) ;Show current data
  1. N Y,%0,%4,RTN,RSUM S %4="^n/a^n/a",U="^"
  1. S Y=$$GETDA(RN) I Y>0 S %0=^DIC(9.8,Y,0),%4=$G(^(4))
  1. S RSUM=$$NEWSUM(RN)
  1. W !,"RTN",?10,"New ChkSum",?28,"Old ChkSum",?46,"Old Date"
  1. W !,RN,?10,RSUM,?28,$P(%4,U,2),?46,$P(%4,U)
  1. W !,$S($$LOCAL(Y):"Local",1:"National")_" Routine"
  1. Q
  1. ;
  1. GETDA(X) ;Find a DA in file
  1. Q $O(^DIC(9.8,"B",X,0))
  1. ;
  1. M ;Manual Update of the Routine file
  1. N DIC,DIE,DA,DR
  1. S DIC="^DIC(9.8,",DIC(0)="AEMQ" D ^DIC Q:Y'>0
  1. I '$$LOCAL(+Y) W !,"This routine Checksum only updated from FORUM." Q
  1. S DA=+Y,DIE=DIC,DR=7.2 D ^DIE
  1. Q
  1. ;
  1. LIST ;List all routines that don't match the old checksum
  1. N Y,X,RN,RSUM,DA
  1. S RN="",U="^"
  1. F S RN=$O(^DIC(9.8,"B",RN)) Q:RN="" D
  1. . S DA=$O(^DIC(9.8,"B",RN,0)) Q:DA'>0
  1. . S %4=$G(^DIC(9.8,DA,4)) Q:$P(%4,U,2)="" S RSUM=$$NEWSUM(RN)
  1. . I RSUM'=$P(%4,U,2) W !,RN,?10,"Checksum mismatch ",$P($T(+2^@RN),";",5)
  1. . Q
  1. Q
  1. ;
  1. LOCAL(DA) ;Return if this is a local routine in the ROUTINE file.
  1. Q $P($G(^DIC(9.8,DA,6)),"^")<2
  1. ;