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>