Annotation of freem_fileman/DIDG.m, revision 1.1
1.1 ! snw 1: DIDG ;SFISC/RWF-GLOBAL MAP ;08:03 AM 11 Dec 1994
! 2: ;;21.0;VA FileMan;;Dec 28, 1994
! 3: ;Per VHA Directive 10-93-142, this routine should not be modified.
! 4: K W S DJ(Z)=D0,F=0,W=F(Z),M=1,DP=0
! 5: W !
! 6: UP I $D(^DD(W,0,"UP")) S Y=^("UP"),N=$O(^DD(Y,"SB",W,0)) I $D(^DD(Y,N,0)) S F=F+1,W(F)=$P($P(^(0),U,4),";",1),W=Y G UP
! 7: S W=$S($D(^DIC(W,0,"GL")):^("GL"),1:"^("),Y=0 F N=F:-1:1 S W=W_"D"_Y_","_$S(+W(N)=W(N):W(N),1:""""_W(N)_"""")_",",Y=Y+1
! 8: S DID(Z-1)=W K W
! 9: ;
! 10: L S DN(Z)=""
! 11: A S DN(Z)=$O(^DD(F(Z),"GL",DN(Z))),DP(0)=0 I DN(Z)="" D POP Q
! 12: S DID(Z)=DID(Z-1)_"D"_(F+Z-1)_","_DN(Z) I $O(^DD(F(Z),"GL",DN(Z),""))'=0 S W=DID(Z)_")=" W ! D WL Q:M=U
! 13: B S DP=$O(^DD(F(Z),"GL",DN(Z),DP)) G PUSH:DP=0,A:DP=""
! 14: S DF=$O(^DD(F(Z),"GL",DN(Z),DP,0))
! 15: I DP(0)+1<DP F I1=DP(0)+1:1:DP-1 S W=" ^ " D WL Q:M=U
! 16: S N=^DD(F(Z),DF,0),DP(0)=DP
! 17: S X=$P(N,U,2) I +X S Z=Z+1,F(Z)=+X D L G B
! 18: S W="(#"_DF_") "_$P(N,U,1)_" ["_DP
! 19: F Y="F","S","D","N","P","W","V","K" I X[Y S W=W_Y
! 20: S W=W_"] ^ " D WL Q:M=U G B
! 21: ;
! 22: PUSH S N=$O(^DD(F(Z),"GL",DN(Z),DP,0)) S:N="" N=-1 S Y=^DD(F(Z),N,0),DID(Z)=DID(Z)_","
! 23: W !,DID(Z)_"0)=^"_$P(Y,U,2)_"^^ (#",N,") "_$P(Y,U,1) S Z=Z+1,F(Z)=+$P(Y,U,2)
! 24: D L Q:M=U G A
! 25: ;
! 26: POP S Z=Z-1,DID(Z)=$E(DID(Z),1,$L(DID(Z))-1) Q:Z K DN,W,DP,DG,DID S DN=0 W ! Q
! 27: ;
! 28: END ;
! 29: S S=0,M=1
! 30: T1 S S=S+1 D:$Y+3>IOSL HDR Q:M=U
! 31: W !!,$S(S<4:$P("INPU^PRIN^SOR",U,S)_"T TEMPLATE(S):",1:"FORM(S)/BLOCK(S):")
! 32: S DFF="^DI"_$P("E^PT^BT^ST(.403)",U,S),DA=""
! 33: F S DA=$O(@DFF@("F"_F(1),DA)) Q:DA="" D Q:M=U
! 34: . S DUB=0 F S DUB=$O(@DFF@("F"_F(1),DA,DUB)) Q:DUB'>0 D Q:M=U
! 35: .. I $D(@DFF@(DUB,0))#2 S %1=^(0) D TEMPL
! 36: K %1 Q:M=U G T1:S<4
! 37: Q Q
! 38: TEMPL I $Y+3>IOSL D HDR Q:M=U
! 39: N % S %=$S($D(^("ROU")):"Compiled: "_^("ROU"),'$D(^("ROU"))&($D(^("ROUOLD"))):"Previously Compiled: "_^("ROUOLD"),1:"")
! 40: I %]"",DFF["DIBT" S %=%_"*"
! 41: I DFF'["DIST" W !,DFF,"("_DUB_")= ",$P(%1,U)_" "_%
! 42: E D FORM
! 43: Q
! 44: WL I $Y+4>IOSL S %1=W D HD Q:M=U S W=%1 I W[DID(Z) S W=""
! 45: F I=1:1 S Y=$P(W," ",I)_" " Q:$P(W," ",I,99)="" W:$X+$L(Y)+2>IOM !,?$L(DID(Z)),"==>" W Y
! 46: Q
! 47: W W:$X+$L(W)+3>IOM !,?$S(IOM-$L(W)-5<M:IOM-5-$L(W),1:M),S S %Y=$E(W,IOM-$X,999) W $E(W,1,IOM-$X-1),S Q:%Y="" S W=%Y G W
! 48: ;
! 49: HD S DC=DC+1 D ^DIDH Q:M=U W !,DID(Z),")= " Q
! 50: ;
! 51: HDR ;
! 52: S DC=DC+1 I IOST?1"C".E W $C(7) R M:DTIME S:'$T M=U Q:M=U
! 53: H1 W:$D(DIFF)&($Y) @IOF S DIFF=1 W "TEMPLATE LIST -- FILE #"_DIB,?(IOM-20),$E(DT,4,5)_"/"_$E(DT,6,7)_"/"_$E(DT,2,3)_" PAGE "_DC
! 54: S M="",$P(M,"-",IOM)="" W !,M
! 55: Q
! 56: ;
! 57: FORM ;
! 58: W !,"^DIST(.403,"_DUB_")= ",$P(%1,U)_" "_%
! 59: ;
! 60: N B,L,P
! 61: S L=1,L(1)=U
! 62: S P=0 F S P=$O(^DIST(.403,DUB,40,P)) Q:'P D Q:M=U
! 63: . Q:$D(^DIST(.403,DUB,40,P,0))[0 S B=$P(^(0),U,2) D:B BLOCK Q:M=U
! 64: . S B=0 F S B=$O(^DIST(.403,DUB,40,P,40,B)) Q:'B D BLOCK Q:M=U
! 65: W !
! 66: Q
! 67: BLOCK ;
! 68: N I
! 69: F I=1:1:L I L(I)[(U_B_U) G BLOCKQ
! 70: S:$L(L)+$L(B)+1>245 L=L+1,L(L)=U S L(L)=L(L)_B_U
! 71: Q:$D(^DIST(.404,B,0))[0 S %1=^(0)
! 72: ;
! 73: I $Y+3>IOSL D HDR Q:M=U
! 74: W !?2,"^DIST(.404,"_B_")= ",$P(%1,U)
! 75: BLOCKQ Q
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>