Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: DDW7

DDW7.m

Go to the documentation of this file.
  1. DDW7 ;SFISC/MKO-MARK TEXT ;2:30 PM 27 Jul 2000 [ 04/02/2003 8:25 AM ]
  1. ;;22.0;VA FileMan;**1001**;APR 1, 2003
  1. ;;22.0;VA FileMan;**18**;Mar 30, 1999
  1. ;Per VHA Directive 10-93-142, this routine should not be modified.
  1. ;
  1. MARK ;Mark the text
  1. I $D(DDWMARK) D
  1. . D BOUND
  1. E D
  1. . S DDWMARK=DDWA+DDWRW_U_DDWC_U_(DDWA+DDWRW)_U_$$MAX(DDWC,$L(DDWN))
  1. . D PAINT(DDWMARK,1),IND(1)
  1. Q
  1. ;
  1. BOUND ;Mark ending boundary, highlight selected text
  1. N DDWI,DDWX,DDWY
  1. ;
  1. S DDWI=DDWA+DDWRW_U_DDWC
  1. S DDWX=$P(DDWMARK,U,1,2)
  1. S DDWY=$P(DDWMARK,U,3,4)
  1. ;
  1. I $$ISLESS(DDWI,DDWX) D
  1. . D PAINT(DDWX_U_DDWY)
  1. . D PAINT(DDWI_U_DDWX,1)
  1. . S DDWMARK=DDWI_U_DDWX
  1. E D
  1. . I $$ISLESS(DDWI,DDWY) D
  1. .. D PAINT(DDWI_U_DDWY),PAINT(DDWI_U_DDWI,1)
  1. . E D PAINT(DDWY_U_DDWI,1)
  1. . S DDWMARK=DDWX_U_DDWI
  1. D CUP(DDWRW,DDWC-DDWOFS)
  1. Q
  1. ;
  1. UNMARK ;Unmark the text
  1. D:$D(DDWMARK) PAINT(DDWMARK),IND()
  1. K DDWMARK
  1. Q
  1. ;
  1. PAINT(DDWMARK,DDWREV) ;Paint selected text
  1. N DDWI,DDWE1,DDWE2,DDWL1,DDWL2,DDWR1,DDWC1,DDWR2,DDWC2
  1. S DDWR1=$P(DDWMARK,U,1),DDWC1=$P(DDWMARK,U,2)
  1. S DDWR2=$P(DDWMARK,U,3),DDWC2=$P(DDWMARK,U,4)
  1. S DDWL1=$$MAX(DDWR1-DDWA,1),DDWL2=$$MIN(DDWR2-DDWA,DDWMR)
  1. Q:DDWL1>DDWL2
  1. ;
  1. W:$G(DDWREV) $P(DDGLVID,DDGLDEL,6)
  1. F DDWI=DDWL1:1:DDWL2 D
  1. . S DDWE1=$$MAX($S(DDWI+DDWA=DDWR1:DDWC1,1:1),DDWOFS+1)
  1. . S DDWE2=$$MIN($S(DDWI+DDWA=DDWR2:DDWC2,1:999),IOM+DDWOFS)
  1. . Q:DDWE1>DDWE2
  1. . D CUP(DDWI,DDWE1-DDWOFS)
  1. . W $E(DDWL(DDWI),DDWE1,DDWE2)
  1. W:$G(DDWREV) $P(DDGLVID,DDGLDEL,10)
  1. Q
  1. ;
  1. IND(DDWX) ;Paint indicator
  1. S DY=$G(DDWBM,IOSL)-1,DX=IOM-7 X IOXY
  1. W $S($G(DDWX):$P(DDGLVID,DDGLDEL,6)_"Select"_$P(DDGLVID,DDGLDEL,10),1:$P(DDGLCLR,DDGLDEL))
  1. D CUP(DDWRW,DDWC-DDWOFS)
  1. Q
  1. ;
  1. CUP(Y,X) ;
  1. S DY=IOTM+Y-2,DX=X-1 X IOXY
  1. Q
  1. ;
  1. POS(R,C,F) ;Pos cursor based on char pos C
  1. N DDWX
  1. S:$G(C)="E" C=$L($G(DDWL(R)))+1
  1. S:$G(F)["N" DDWN=$G(DDWL(R))
  1. S:$G(F)["R" DDWRW=R,DDWC=C
  1. ;
  1. S DDWX=C-DDWOFS
  1. I DDWX>IOM!(DDWX<1) D SHIFT^DDW3(C,.DDWOFS)
  1. S DY=IOTM+R-2,DX=C-DDWOFS-1 X IOXY
  1. Q
  1. ;
  1. ISLESS(X,Y) ;Is coordinate X less than coordinate Y
  1. N R1,C1,R2,C2
  1. S R1=$P(X,U),C1=$P(X,U,2)
  1. S R2=$P(Y,U),C2=$P(Y,U,2)
  1. ;
  1. Q:R1>R2 0
  1. Q:R1<R2 1
  1. Q:C1>C2 0
  1. Q 1
  1. ;
  1. MIN(X,Y) ;
  1. Q $S(X<Y:X,1:Y)
  1. ;
  1. MAX(X,Y) ;
  1. Q $S(X>Y:X,1:Y)