File:  [Coherent Logic Development] / freem_fileman / USER / DDW7.m
Revision 1.1: download - view: text, annotated - select for diffs
Mon Apr 28 14:13:19 2025 UTC (5 weeks, 5 days ago) by snw
Branches: MAIN
CVS tags: HEAD
Restructure repository

DDW7	;SFISC/MKO-MARK TEXT ;09:09 AM  21 Jun 1994
	;;21.0;VA FileMan;;Dec 28, 1994
	;Per VHA Directive 10-93-142, this routine should not be modified.
	;
MARK	;Mark the text
	I $D(DDWMARK) D
	. D BOUND
	E  D
	. S DDWMARK=DDWA+DDWRW_U_DDWC_U_(DDWA+DDWRW)_U_$$MAX(DDWC,$L(DDWN))
	. D PAINT(DDWMARK,1),IND(1)
	Q
	;
BOUND	;Mark ending boundary, highlight selected text
	N DDWI,DDWX,DDWY
	;
	S DDWI=DDWA+DDWRW_U_DDWC
	S DDWX=$P(DDWMARK,U,1,2)
	S DDWY=$P(DDWMARK,U,3,4)
	;
	I $$ISLESS(DDWI,DDWX) D
	. D PAINT(DDWX_U_DDWY)
	. D PAINT(DDWI_U_DDWX,1)
	. S DDWMARK=DDWI_U_DDWX
	E  D
	. I $$ISLESS(DDWI,DDWY) D
	.. D PAINT(DDWI_U_DDWY),PAINT(DDWI_U_DDWI,1)
	. E  D PAINT(DDWY_U_DDWI,1)
	. S DDWMARK=DDWX_U_DDWI
	D CUP(DDWRW,DDWC-DDWOFS)
	Q
	;
UNMARK	;Unmark the text
	D:$D(DDWMARK) PAINT(DDWMARK),IND()
	K DDWMARK
	Q
	;
PAINT(DDWMARK,DDWREV)	;Paint selected text
	N DDWI,DDWR1,DDWC1,DDWR2,DDWC2
	S DDWR1=$P(DDWMARK,U,1),DDWC1=$P(DDWMARK,U,2)
	S DDWR2=$P(DDWMARK,U,3),DDWC2=$P(DDWMARK,U,4)
	;
	W:$G(DDWREV) $P(DDGLVID,DDGLDEL,6)
	F DDWI=$$MAX(DDWR1-DDWA,1):1:$$MIN(DDWR2-DDWA,DDWMR) D
	. D CUP(DDWI,$S(DDWI+DDWA=DDWR1:DDWC1-DDWOFS,1:1))
	. W $E(DDWL(DDWI),$S(DDWI+DDWA=DDWR1:DDWC1,1:1+DDWOFS),$$MIN($S(DDWI+DDWA=DDWR2:DDWC2,1:999),IOM+DDWOFS))
	W:$G(DDWREV) $P(DDGLVID,DDGLDEL,10)
	Q
	;
IND(DDWX)	;Paint indicator
	S DY=$G(DDWBM,IOSL)-1,DX=IOM-7 X IOXY
	I $G(DDWX) D
	W $S($G(DDWX):$P(DDGLVID,DDGLDEL,6)_"Select"_$P(DDGLVID,DDGLDEL,10),1:$P(DDGLCLR,DDGLDEL))
	D CUP(DDWRW,DDWC-DDWOFS)
	Q
	;
CUP(Y,X)	;
	S DY=IOTM+Y-2,DX=X-1 X IOXY
	Q
	;
POS(R,C,F)	;Pos cursor based on char pos C
	N DDWX
	S:$G(C)="E" C=$L($G(DDWL(R)))+1
	S:$G(F)["N" DDWN=$G(DDWL(R))
	S:$G(F)["R" DDWRW=R,DDWC=C
	;
	S DDWX=C-DDWOFS
	I DDWX>IOM!(DDWX<1) D SHIFT^DDW3(C,.DDWOFS)
	S DY=IOTM+R-2,DX=C-DDWOFS-1 X IOXY
	Q
	;
ISLESS(X,Y)	;Is coordinate X less than coordinate Y
	N R1,C1,R2,C2
	S R1=$P(X,U),C1=$P(X,U,2)
	S R2=$P(Y,U),C2=$P(Y,U,2)
	;
	Q:R1>R2 0
	Q:R1<R2 1
	Q:C1>C2 0
	Q 1
	;
MIN(X,Y)	;
	Q $S(X<Y:X,1:Y)
	;
MAX(X,Y)	;
	Q $S(X>Y:X,1:Y)

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