Annotation of freem_fileman/DICATT.m, revision 1.1
1.1 ! snw 1: DICATT ;SFISC/GFT,XAK-MODIFY FILE ATTR ;10/6/94 12:54
! 2: ;;21.0;VA FileMan;;Dec 28, 1994
! 3: ;Per VHA Directive 10-93-142, this routine should not be modified.
! 4: S DLAYGO=1 D D^DICRW Q:Y<0 I $P($G(^DD(+Y,0,"DI")),U)["Y",($P(@(^DIC(+Y,0,"GL")_"0)"),U,4)) W !!,$C(7),"DATA DICTIONARY MODIFICATIONS ON ARCHIVE FILES ARE NOT ALLOWED!" Q
! 5: I '$D(DIC) D DIE^DIB Q:'$D(DG) S DIC=DG
! 6: S:$D(DIAX) DIAXDIC=+$P(@(DIC_"0)"),U,2)
! 7: EN ;
! 8: K I S Q="""",I(0)=DIC,B=+$P(@(DIC_"0)"),U,2),S=";"
! 9: B ;
! 10: K DA,J,DIU0,DDA S A=B,DICL=0,J(0)=B I $D(^DD(A,0,"DDA")),^("DDA")["Y" S DDA=""
! 11: M ;
! 12: I $G(Z)["W",A-B G B
! 13: W !!! K O,DQ,DIC,DIE,DG,M G Q^DIB:$D(DTOUT)
! 14: S O=1,E=0,DIC(0)="ALEQIZ",DIC="^DD("_A_"," S:$D(DICS) DIC("S")=DICS
! 15: S DIC("W")="S %=$P(^(0),U,2) I % W $P("" (multiple)^ (word-processing)"",U,$P(^DD(+%,.01,0),U,2)[""W""+1)"
! 16: I $P(^DD(A,.01,0),U,2)["W" S DIC(0)="AEQZ",DIC("B")=.01
! 17: E I $D(DA),$D(^DD(A,DA,0)),'$P(^(0),U,2),$P(^(0),U,4)'?.P S E=DA
! 18: D ^DIC S:$D(DDA)&$P(Y,U,3) DDA="N" I Y<0 G B:A-B,Q^DICATT2
! 19: I '$P(Y,U,3) S DIU0=A,O(1)=$P(^DD(A,+Y,0),U,1,2),O(2)=$S($D(^(.1)):$P(^(.1),U),1:"") I $D(DDA) S DDA="E" D SV^DICATTA
! 20: S:$D(DDA) DDA(1)=A
! 21: S DIAC="AUDIT",DIFILE=A D ^DIAC S O=+% K DIAC,DIFILE
! 22: SKP S DA=+Y,DA(1)=A,DIE=DIC,M=Y(0),T=$P(M,U,2) S:T["C"!(T["W") O=0
! 23: S DR=$P(".01:.1;",U,DUZ(0)="@"!'$F(T,"X"))_$P("1.1;",U,O)_$S(DUZ(0)="@"&(T'["C")&(T'["W"):"1.2;",1:"")_$S(T["C":"8;",1:"8:9;10:")_"11;20:29"
! 24: S O=$S($P(Y,U,3):0,1:1_U_$P(M,U,2,99)),F=$P(M,U) K DIC,DQI
! 25: S X=0 F S X=$O(^DD(A,DA,1,X)) Q:X'>0 I +^(X,0)=B,$P(^(0),B,2)?1"^"1.A S DQI=$P(^(0),U,2)
! 26: S X=-1 I 'T D DIE:O Q:$D(DTOUT) S:'$D(DA)&($D(DDA)) DDA="D" G TYPE^DICATT2:$D(DA),N:$P(O,U,4)?.P,^DICATT4
! 27: S DR=".01;8;9;10:11;20:29" D DIE I '$D(DA) S:$D(DDA) DDA="D" S DQ(+T)=0 G NEW^DICATT4
! 28: S X=$P($P(M,U,4),S,1),M=^DD(A,DA,0),E=$P(M,U,1),A=+T,DICL=DICL+1,J(DICL)=A,Y=$E(Q,+X'=X),I(DICL)=Y_X_Y I E'=F S ^(0)=E_" SUB-FIELD^"_$P(^DD(A,0),U,2,9) K ^(0,"NM") S ^("NM",E)=""
! 29: G 5:$P(M,U,2)["W",N
! 30: ;
! 31: ;
! 32: E S DE=^DD(A,E,0) W $P(DE,U,1) Q
! 33: ;
! 34: P S DI=DIU0 I '$D(DA),$D(O(1)) S DA=D0 D DIPZ^DIU0 Q
! 35: I $D(^DD(DI,DA,0)),O(1)'=$P(^(0),U,1,2) D DIPZ^DIU0 Q
! 36: I $D(^(.1)),O(2)'=$P(^(.1),U) D DIPZ^DIU0 Q
! 37: K DIU0 Q
! 38: ;
! 39: N I $D(DDA),DDA]"" S:'$D(DA) DA=D0 D AUDT^DICATTA
! 40: D:$D(DIU0) P S DIZZ=$S(('O&$D(DIZ)):DIZ,1:$P(O,U,2,3)) G M
! 41: ;
! 42: X W $C(7)," '",F,"' DELETED!" I $D(DDA) S DDA=$S(DDA="":"D",1:"")
! 43: S DIK="^DD(A,",DA(1)=A D ^DIK G N
! 44: ;
! 45: CHECK G:$P(^DD(A,DA,0),U,2)']"" X:$D(DTOUT) G NO^DICATT2
! 46: ;
! 47: DIE ;
! 48: N I,J
! 49: D ^DIE
! 50: Q
! 51: ;
! 52: 0 S C=$P(O,U,5,99) G @N
! 53: 1 ;
! 54: 2 G ^DICATT0
! 55: 3 ;
! 56: 4 G ^DICATT6
! 57: 5 S W="0;1",(Z,DIZ)="W^",C="Q",V=1,L=1 G ^DICATT2:O,SUB^DICATT1
! 58: 6 G ^DICATT3
! 59: 7 G ^DICATT5
! 60: 8 G VP^DICATT4
! 61: 9 S (Z,DIZ)="K^",V=0,C="K:$L(X)>245 X D:$D(X) ^DIM",L=245
! 62: S:$P(^DD(A,DA,0),U,4)]"" W=$P(^(0),U,4) G ^DICATT2:O,SUB^DICATT1
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>