Annotation of freem_fileman/DDW7.m, revision 1.1.1.1

1.1       snw         1: DDW7   ;SFISC/MKO-MARK TEXT ;09:09 AM  21 Jun 1994
                      2:        ;;21.0;VA FileMan;;Dec 28, 1994
                      3:        ;Per VHA Directive 10-93-142, this routine should not be modified.
                      4:        ;
                      5: MARK   ;Mark the text
                      6:        I $D(DDWMARK) D
                      7:        . D BOUND
                      8:        E  D
                      9:        . S DDWMARK=DDWA+DDWRW_U_DDWC_U_(DDWA+DDWRW)_U_$$MAX(DDWC,$L(DDWN))
                     10:        . D PAINT(DDWMARK,1),IND(1)
                     11:        Q
                     12:        ;
                     13: BOUND  ;Mark ending boundary, highlight selected text
                     14:        N DDWI,DDWX,DDWY
                     15:        ;
                     16:        S DDWI=DDWA+DDWRW_U_DDWC
                     17:        S DDWX=$P(DDWMARK,U,1,2)
                     18:        S DDWY=$P(DDWMARK,U,3,4)
                     19:        ;
                     20:        I $$ISLESS(DDWI,DDWX) D
                     21:        . D PAINT(DDWX_U_DDWY)
                     22:        . D PAINT(DDWI_U_DDWX,1)
                     23:        . S DDWMARK=DDWI_U_DDWX
                     24:        E  D
                     25:        . I $$ISLESS(DDWI,DDWY) D
                     26:        .. D PAINT(DDWI_U_DDWY),PAINT(DDWI_U_DDWI,1)
                     27:        . E  D PAINT(DDWY_U_DDWI,1)
                     28:        . S DDWMARK=DDWX_U_DDWI
                     29:        D CUP(DDWRW,DDWC-DDWOFS)
                     30:        Q
                     31:        ;
                     32: UNMARK ;Unmark the text
                     33:        D:$D(DDWMARK) PAINT(DDWMARK),IND()
                     34:        K DDWMARK
                     35:        Q
                     36:        ;
                     37: PAINT(DDWMARK,DDWREV)  ;Paint selected text
                     38:        N DDWI,DDWR1,DDWC1,DDWR2,DDWC2
                     39:        S DDWR1=$P(DDWMARK,U,1),DDWC1=$P(DDWMARK,U,2)
                     40:        S DDWR2=$P(DDWMARK,U,3),DDWC2=$P(DDWMARK,U,4)
                     41:        ;
                     42:        W:$G(DDWREV) $P(DDGLVID,DDGLDEL,6)
                     43:        F DDWI=$$MAX(DDWR1-DDWA,1):1:$$MIN(DDWR2-DDWA,DDWMR) D
                     44:        . D CUP(DDWI,$S(DDWI+DDWA=DDWR1:DDWC1-DDWOFS,1:1))
                     45:        . W $E(DDWL(DDWI),$S(DDWI+DDWA=DDWR1:DDWC1,1:1+DDWOFS),$$MIN($S(DDWI+DDWA=DDWR2:DDWC2,1:999),IOM+DDWOFS))
                     46:        W:$G(DDWREV) $P(DDGLVID,DDGLDEL,10)
                     47:        Q
                     48:        ;
                     49: IND(DDWX)      ;Paint indicator
                     50:        S DY=$G(DDWBM,IOSL)-1,DX=IOM-7 X IOXY
                     51:        I $G(DDWX) D
                     52:        W $S($G(DDWX):$P(DDGLVID,DDGLDEL,6)_"Select"_$P(DDGLVID,DDGLDEL,10),1:$P(DDGLCLR,DDGLDEL))
                     53:        D CUP(DDWRW,DDWC-DDWOFS)
                     54:        Q
                     55:        ;
                     56: CUP(Y,X)       ;
                     57:        S DY=IOTM+Y-2,DX=X-1 X IOXY
                     58:        Q
                     59:        ;
                     60: POS(R,C,F)     ;Pos cursor based on char pos C
                     61:        N DDWX
                     62:        S:$G(C)="E" C=$L($G(DDWL(R)))+1
                     63:        S:$G(F)["N" DDWN=$G(DDWL(R))
                     64:        S:$G(F)["R" DDWRW=R,DDWC=C
                     65:        ;
                     66:        S DDWX=C-DDWOFS
                     67:        I DDWX>IOM!(DDWX<1) D SHIFT^DDW3(C,.DDWOFS)
                     68:        S DY=IOTM+R-2,DX=C-DDWOFS-1 X IOXY
                     69:        Q
                     70:        ;
                     71: ISLESS(X,Y)    ;Is coordinate X less than coordinate Y
                     72:        N R1,C1,R2,C2
                     73:        S R1=$P(X,U),C1=$P(X,U,2)
                     74:        S R2=$P(Y,U),C2=$P(Y,U,2)
                     75:        ;
                     76:        Q:R1>R2 0
                     77:        Q:R1<R2 1
                     78:        Q:C1>C2 0
                     79:        Q 1
                     80:        ;
                     81: MIN(X,Y)       ;
                     82:        Q $S(X<Y:X,1:Y)
                     83:        ;
                     84: MAX(X,Y)       ;
                     85:        Q $S(X>Y:X,1:Y)

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