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