* harbour/source/debug/dbgtwin.prg
* use hb_scroll() instead of scroll()
* harbour/source/debug/tbrwtext.prg
! fixed screen redrawing in horizontal movement
* harbour/source/debug/debugger.prg
* harbour/source/debug/dbgtinp.prg
! replaced GET/GETLIST objects by HbDbInput()
! fixed some interface incompatibilities with Clipper debugger
* removed HB_NO_READDBG and code using GET classes - HbDbInput()
works better and is much simpler in use.
% do not use __GetListActive()/__GetListSetActive() - now debugger
does not touch GET/GETLIST so it's not necessary to save/restore
GETLIST state
Now all references (except HBCLASS) to external .prg code in
debugger have been removed.
TODO: remove HB_NO_READDBG from other debugger files replacing
code inside with __dbgInput()/HbDbInput().
I would like to leave it for someone else and return to
core code modifications.
219 lines
6.1 KiB
Plaintext
219 lines
6.1 KiB
Plaintext
/*
|
|
* $Id$
|
|
*/
|
|
|
|
/*
|
|
* Harbour Project source code:
|
|
* User input class for debugger
|
|
*
|
|
* Copyright 2008 Przemyslaw Czerpak <druzus / at / priv.onet.pl>
|
|
* www - http://www.harbour-project.org
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2, or (at your option)
|
|
* any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this software; see the file COPYING. If not, write to
|
|
* the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
|
|
* Boston, MA 02111-1307 USA (or visit the web site http://www.gnu.org/).
|
|
*
|
|
* As a special exception, the Harbour Project gives permission for
|
|
* additional uses of the text contained in its release of Harbour.
|
|
*
|
|
* The exception is that, if you link the Harbour libraries with other
|
|
* files to produce an executable, this does not by itself cause the
|
|
* resulting executable to be covered by the GNU General Public License.
|
|
* Your use of that executable is in no way restricted on account of
|
|
* linking the Harbour library code into it.
|
|
*
|
|
* This exception does not however invalidate any other reasons why
|
|
* the executable file might be covered by the GNU General Public License.
|
|
*
|
|
* This exception applies only to the code released by the Harbour
|
|
* Project under the name Harbour. If you copy code from other
|
|
* Harbour Project or Free Software Foundation releases into a copy of
|
|
* Harbour, as the General Public License permits, the exception does
|
|
* not apply to the code that you add in this way. To avoid misleading
|
|
* anyone as to the status of such modified files, you must delete
|
|
* this exception notice from them.
|
|
*
|
|
* If you write modifications of your own for Harbour, it is your choice
|
|
* whether to permit this exception to apply to your modifications.
|
|
* If you do not wish that, delete this exception notice.
|
|
*
|
|
*/
|
|
|
|
#pragma DEBUGINFO=OFF
|
|
|
|
#define HB_CLS_NOTOBJECT /* do not inherit from HBObject calss */
|
|
#include "hbclass.ch"
|
|
|
|
#include "inkey.ch"
|
|
#include "color.ch"
|
|
#include "setcurs.ch"
|
|
#include "common.ch"
|
|
|
|
|
|
CREATE CLASS HbDbInput
|
|
|
|
HIDDEN:
|
|
VAR nRow AS INTEGER
|
|
VAR nCol AS INTEGER
|
|
VAR nWidth AS INTEGER
|
|
VAR nPos AS INTEGER INIT 1
|
|
VAR nFirst AS INTEGER INIT 1
|
|
VAR nSize AS INTEGER
|
|
VAR cValue AS CHARACTER
|
|
VAR acColor AS ARRAY
|
|
VAR lFocus AS LOGICAL INIT .F.
|
|
|
|
EXPORTED:
|
|
METHOD new( nRow, nCol, nWidth, cValue, nSize )
|
|
METHOD applyKey( nKey )
|
|
METHOD getValue()
|
|
METHOD setValue( cValue )
|
|
METHOD setFocus()
|
|
METHOD killFocus()
|
|
METHOD display()
|
|
METHOD newPos( nRow, nCol )
|
|
METHOD setColor( cColor )
|
|
|
|
ENDCLASS
|
|
|
|
METHOD new( nRow, nCol, nWidth, cValue, cColor, nSize ) CLASS HbDbInput
|
|
|
|
::nRow := nRow
|
|
::nCol := nCol
|
|
::nWidth := nWidth
|
|
::nSize := IIF( ISNUMBER( nSize ), nSize, nWidth )
|
|
::cValue := PadR( cValue, ::nSize )
|
|
::nRow := nRow
|
|
|
|
::setColor( cColor )
|
|
|
|
RETURN Self
|
|
|
|
METHOD setColor( cColor ) CLASS HbDbInput
|
|
|
|
::acColor:= { hb_ColorIndex( cColor, CLR_STANDARD ), ;
|
|
hb_ColorIndex( cColor, CLR_ENHANCED ) }
|
|
IF hb_colorToN( ::acColor[ 2 ] ) == -1
|
|
::acColor[ 2 ] := IIF( hb_colorToN( ::acColor[ 1 ] ) != -1, ;
|
|
::acColor[ 1 ], ;
|
|
hb_ColorIndex( SetColor(), CLR_ENHANCED ) )
|
|
ENDIF
|
|
IF hb_colorToN( ::acColor[ 1 ] ) == -1
|
|
::acColor[ 1 ] := hb_ColorIndex( SetColor(), CLR_STANDARD )
|
|
ENDIF
|
|
RETURN Self
|
|
|
|
METHOD newPos( nRow, nCol ) CLASS HbDbInput
|
|
::nRow := nRow
|
|
::nCol := nCol
|
|
RETURN Self
|
|
|
|
METHOD setFocus() CLASS HbDbInput
|
|
IF !::lFocus
|
|
::lFocus := .T.
|
|
::display()
|
|
ENDIF
|
|
RETURN Self
|
|
|
|
METHOD killFocus() CLASS HbDbInput
|
|
IF ::lFocus
|
|
::lFocus := .F.
|
|
::display()
|
|
ENDIF
|
|
RETURN Self
|
|
|
|
METHOD getValue() CLASS HbDbInput
|
|
RETURN ::cValue
|
|
|
|
METHOD setValue( cValue ) CLASS HbDbInput
|
|
::cValue := PadR( cValue, ::nSize )
|
|
::nPos := Min( ::nSize, Len( RTrim( ::cValue ) ) + 1 )
|
|
RETURN Self
|
|
|
|
METHOD display() CLASS HbDbInput
|
|
|
|
IF ::nPos < ::nFirst
|
|
::nFirst := ::nPos
|
|
ELSEIF ::nPos - ::nFirst >= ::nWidth
|
|
::nFirst := ::nPos - ::nWidth + 1
|
|
ENDIF
|
|
hb_dispOutAt( ::nRow, ::nCol, Substr( ::cValue, ::nFirst, ::nWidth ), ;
|
|
::acColor[ IIF( ::lFocus, 2, 1 ) ] )
|
|
IF ::lFocus
|
|
SetPos( ::nRow, ::nCol + ::nPos - ::nFirst )
|
|
SetCursor( IIF( Set( _SET_INSERT ), SC_INSERT, SC_NORMAL ) )
|
|
ENDIF
|
|
RETURN Self
|
|
|
|
METHOD applyKey( nKey ) CLASS HbDbInput
|
|
|
|
LOCAL lUpdate := .T.
|
|
|
|
SWITCH nKey
|
|
CASE K_HOME
|
|
::nPos := 1
|
|
EXIT
|
|
CASE K_END
|
|
::nPos := Len( RTrim( ::cValue ) ) + 1
|
|
IF ::nPos > ::nSize
|
|
::nPos := ::nSize
|
|
ENDIF
|
|
EXIT
|
|
CASE K_LEFT
|
|
IF ::nPos > 1
|
|
::nPos--
|
|
ENDIF
|
|
EXIT
|
|
CASE K_RIGHT
|
|
IF ::nPos < ::nSize
|
|
::nPos++
|
|
ENDIF
|
|
EXIT
|
|
CASE K_DEL
|
|
::cValue := Stuff( ::cValue, ::nPos, 1, "" ) + " "
|
|
EXIT
|
|
CASE K_BS
|
|
IF ::nPos > 1
|
|
::cValue := Stuff( ::cValue, --::nPos, 1, "" ) + " "
|
|
ENDIF
|
|
EXIT
|
|
CASE K_CTRL_Y
|
|
CASE K_CTRL_DEL
|
|
::cValue := Space( ::nSize )
|
|
::nPos := 1
|
|
EXIT
|
|
CASE K_INS
|
|
Set( _SET_INSERT, !Set( _SET_INSERT ) )
|
|
EXIT
|
|
OTHERWISE
|
|
IF nKey >= 32 .AND. nKey <= 255
|
|
IF Set( _SET_INSERT )
|
|
::cValue := Left( Stuff( ::cValue, ::nPos, 0, Chr( nKey ) ), ::nSize )
|
|
ELSE
|
|
::cValue := Stuff( ::cValue, ::nPos, 1, Chr( nKey ) )
|
|
ENDIF
|
|
IF ::nPos < ::nSize
|
|
::nPos++
|
|
ENDIF
|
|
ELSE
|
|
lUpdate := .F.
|
|
ENDIF
|
|
ENDSWITCH
|
|
|
|
IF lUpdate
|
|
::display()
|
|
ENDIF
|
|
|
|
RETURN Self
|