Annotation of freem_fileman/DIDG.m, revision 1.1.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>