Files
harbour-core/harbour/tests/mt/mttest11.prg
Przemyslaw Czerpak 810fd37bee 2008-12-16 10:06 UTC+0100 Przemyslaw Czerpak (druzus/at/priv.onet.pl)
* harbour/source/vm/classes.c
    * pacified BCC warning

  + harbour/tests/mt/mttest11.prg
    + added new test for asynchronous screen updating in MT mode
2008-12-16 09:04:47 +00:00

52 lines
1.2 KiB
Plaintext

/*
* $Id$
*/
/*
* Harbour Project source code:
* demonstration/test code for asynchronous screen updating without
* breaking foreground screen operations.
*
* Copyright 2008 Przemyslaw Czerpak <druzus / at / priv.onet.pl>
* www - http://www.harbour-project.org
*
*/
proc main()
local getList := {}
local cVar := space( 20 )
CLEAR SCREEN
if ! hb_mtvm()
? "No MT support in HVM. Clock will not be shown."
WAIT
else
hb_threadStart( @thFunc() )
endif
@ 10, 10 SAY "Insert cVar:" GET cVar
READ
SetPos( 12, 0 )
? "Result -> [" + cVar + "]"
WAIT
return
func thFunc()
local cTime
while .T.
cTime := dtoc( date() ) + " " + time()
/* use hb_dispOutAt() which does not change current default
* color and cursor position so can be executed without bad
* side effects for other threads which updates screen.
* This functions also accepts colors as numeric values.
* Similar functionality have hb_dispBox() and hb_scroll().
* All these functions changes only screen buffer but do not
* touch cursor position and current color settings.
*/
hb_dispOutAt( 0, maxcol() - len( cTime ) + 1, cTime, "GR+/N" )
hb_idleSleep( 1 )
enddo
return nil