Annotation of freem_fileman/DDGFUPDB.m, revision 1.1.1.1

1.1       snw         1: DDGFUPDB       ;SFISC/MKO-UPDATE BLOCK COORDINATES ;03:28 PM  17 Aug 1993
                      2:        ;;21.0;VA FileMan;;Dec 28, 1994
                      3:        ;Per VHA Directive 10-93-142, this routine should not be modified.
                      4: BLK(DDGFORIG)  ;
                      5:        ;Update image with adjusted block coordinates
                      6:        ; DDGFORIG(B) : defined for all blocks that changed coordinates
                      7:        ;               = original $Y^original $X
                      8:        N P,P1,P2,B,B1,B2,F,C1,C2,C3,C,D1,D2,D3,L,X1,Y1,N,I
                      9:        ;
                     10:        ;Get page coordinates
                     11:        S P=DDGFPG
                     12:        S P1=$P(@DDGFREF@("F",P),U),P2=$P(@DDGFREF@("F",P),U,2)
                     13:        ;
                     14:        ;Loop through all blocks on page
                     15:        S B="" F  S B=$O(@DDGFREF@("F",P,B)) Q:B=""  D BK
                     16:        Q
                     17:        ;
                     18: BK     ;Get block coordinates
                     19:        S B2=@DDGFREF@("F",P,B)
                     20:        S B1=$P(B2,U),B2=$P(B2,U,2)
                     21:        ;
                     22:        ;Get Y1=delta $Y, X1=delta $X
                     23:        I $D(DDGFORIG(B)) S Y1=B1-$P(DDGFORIG(B),U),X1=B2-$P(DDGFORIG(B),U,2)
                     24:        E  S (Y1,X1)=0
                     25:        I 'Y1,'X1 K DDGFORIG(B)
                     26:        ;
                     27:        ;Loop through all fields on block
                     28:        S F="" F  S F=$O(@DDGFREF@("F",P,B,F)) Q:F=""  D FD
                     29:        Q
                     30:        ;
                     31: FD     ;
                     32:        ;Get field data
                     33:        S N=@DDGFREF@("F",P,B,F)
                     34:        S C1=$P(N,U),C2=$P(N,U,2),C3=$P(N,U,3),C=$P(N,U,4)
                     35:        S D1=$P(N,U,5),D2=$P(N,U,6),D3=$P(N,U,7),L=$P(N,U,8)
                     36:        ;
                     37:        I $D(DDGFORIG(B)) D
                     38:        . I Y1 S:C1]"" $P(N,U)=C1+Y1 S:L $P(N,U,5)=D1+Y1
                     39:        . I X1 D
                     40:        .. I C]"" F I=2,3 S $P(N,U,I)=$P(N,U,I)+X1
                     41:        .. I L F I=6,7 S $P(N,U,I)=$P(N,U,I)+X1
                     42:        . S @DDGFREF@("F",P,B,F)=N
                     43:        . ;
                     44:        . I C]"" D
                     45:        .. K @DDGFREF@("RC",DDGFWID,C1,C2,C3,B,F,"C")
                     46:        .. S @DDGFREF@("RC",DDGFWID,$P(N,U),$P(N,U,2),$P(N,U,3),B,F,"C")=""
                     47:        . I L D
                     48:        .. K @DDGFREF@("RC",DDGFWID,D1,D2,D3,B,F,"D")
                     49:        .. S @DDGFREF@("RC",DDGFWID,$P(N,U,5),$P(N,U,6),$P(N,U,7),B,F,"D")=""
                     50:        ;
                     51:        I C]"" D WRITE^DDGLIBW(DDGFWID,C,$P(N,U)-P1,$P(N,U,2)-P2)
                     52:        I L D WRITE^DDGLIBW(DDGFWID,$TR($J("",L)," ","_"),$P(N,U,5)-P1,$P(N,U,6)-P2)
                     53:        Q

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>