* extras/hbvpdf/hbvpdf.hbx
! two more corrections
* contrib/gtwvg/tests/_dyndlgs.prg
* contrib/hbct/doc/en/finan.txt
* contrib/hbct/readme.txt
* contrib/hbct/tests/asciisum.prg
* contrib/hbct/tests/trig.prg
* contrib/hbfoxpro/dll.prg
* contrib/hbhttpd/core.prg
* contrib/hbhttpd/widgets.prg
* contrib/hbmisc/fcomma.prg
* contrib/hbmlzo/tests/test.prg
* contrib/hbmxml/tests/custom.prg
* contrib/hbmzip/readme.txt
* contrib/hbnf/nwuid.prg
* contrib/hbnf/vidcur.prg
* contrib/hbtip/client.prg
* contrib/hbwin/tests/olesrv1.prg
* contrib/hbwin/tests/testprn.prg
* contrib/xhb/cstruct.prg
* contrib/xhb/hjwindow.prg
* contrib/xhb/hterrsys.prg
* contrib/xhb/htjlist.prg
* contrib/xhb/htmutil.prg
* contrib/xhb/tests/decode.prg
* contrib/xhb/xhberr.prg
* doc/cmdline.txt
* doc/en/objfunc.txt
* doc/en/set.txt
* doc/en/string.txt
* doc/pragma.txt
* extras/gfspell/spell.prg
* extras/gtwvw/docs/gtwvw.txt
* extras/gtwvw/tests/wvwtest9.prg
* extras/hbvpdf/core.prg
* extras/hbvpdf/fonts.prg
* extras/hbvpdf/tests/pdf_demo.prg
* extras/httpsrv/cgifunc.prg
* extras/httpsrv/home/counter.html
* extras/httpsrv/home/testxmldb.html
* extras/httpsrv/session.prg
* extras/httpsrv/uhttpd.prg
* tests/base64.prg
* tests/boxtest.prg
* tests/db_brows.prg
* tests/ddate.prg
* tests/inherit.prg
* tests/langmsg.prg
* tests/mathtest.prg
* tests/memtst.prg
* tests/readhrb.prg
* tests/switch.prg
* tests/testsha2.prg
* tests/testwarn.prg
* tests/tstdbi.prg
* tests/utf8at.prg
* utils/hbtest/hbtest.prg
* utils/hbtest/rt_class.prg
* utils/hbtest/rt_date.prg
* utils/hbtest/rt_hvma.prg
* utils/hbtest/rt_math.prg
* utils/hbtest/rt_misc.prg
* utils/hbtest/rt_trans.prg
* website/news.html
* website/news1.html
* website/samples.html
* website/samples/arreval.html
* website/samples/codebl.prg.html
* website/samples/dates3.html
* website/samples/switch.prg.html
* website/samples/testcgi.prg.html
* website/samples/tstmacro.prg.html
* rerun case fixer script after applying
some fixes, and this time it run fully
automatically.
316 lines
7.4 KiB
Plaintext
316 lines
7.4 KiB
Plaintext
/*
|
|
* $Id$
|
|
*/
|
|
|
|
#include "fileio.ch"
|
|
#include "set.ch"
|
|
|
|
//
|
|
// Test of inheritance
|
|
//
|
|
|
|
/*
|
|
* Written by Eddie Runia <eddie@runia.comu>
|
|
* www - http://harbour-project.org
|
|
*
|
|
* Placed in the public domain
|
|
*/
|
|
|
|
#xtranslate Default( <Var>, <xVal> ) => iif( <Var> == NIL, <xVal>, <Var> )
|
|
|
|
PROCEDURE Main()
|
|
|
|
LOCAL oFrom
|
|
LOCAL oTo
|
|
LOCAL cOut
|
|
|
|
oFrom := TOnTop() :New( "hello.prg", "R" )
|
|
oTo := TTextFile():New( "hello.out", "W" )
|
|
|
|
? "What's in oFrom"
|
|
? hb_ValToExp( { oFrom, __objGetMethodList( oFrom ) } )
|
|
|
|
?
|
|
? "What's in oFrom:TEmpty"
|
|
? hb_ValToExp( { oFrom:TEmpty, __objGetMethodList( oFrom:TEmpty ) } )
|
|
|
|
?
|
|
? "Let's call Run() from TEmpty : "
|
|
oFrom:TEmpty:Run()
|
|
|
|
?
|
|
? "Let's call a method from TEmpty and one from TOnTop"
|
|
oFrom:Set( "Done !" )
|
|
oFrom:Say( "Out" )
|
|
|
|
?
|
|
? "Basic copy loop using the default Run() from TTextFile"
|
|
DO WHILE ! oFrom:lEoF
|
|
cOut := oFrom:Run()
|
|
? cOut
|
|
oTo:Run( cOut )
|
|
ENDDO
|
|
oFrom:Dispose()
|
|
oTo:Dispose()
|
|
|
|
// ? hb_ValToExp( __dbgVMStkGList() ) // Stack is OK!
|
|
|
|
RETURN
|
|
|
|
//
|
|
// Generic Empty Class
|
|
//
|
|
|
|
FUNCTION TEmpty()
|
|
|
|
STATIC oEmpty
|
|
|
|
IF oEmpty == NIL
|
|
oEmpty := HBClass():New( "TEmpty" ) // Create a new class def
|
|
|
|
oEmpty:AddInline( "New", {| self | self } )
|
|
|
|
oEmpty:AddInline( "Run", {|| QOut( "Run !" ) } ) // Test command
|
|
oEmpty:AddInline( "Set", {| self, xParam | ::Out := xParam } )
|
|
oEmpty:AddData( "Out", "Hi there" ) // Test command
|
|
oEmpty:AddVirtual( "Dispose" ) // Clean up code
|
|
|
|
oEmpty:Create()
|
|
ENDIF
|
|
|
|
RETURN oEmpty:Instance()
|
|
|
|
//
|
|
// Let's add another one on top
|
|
//
|
|
|
|
FUNCTION TOnTop()
|
|
|
|
STATIC oOnTop
|
|
|
|
IF oOnTop == NIL
|
|
oOnTop := HBClass():New( "TOnTop", "TTextFile" )
|
|
oOnTop:AddInline( "Say", {| self, cArg | QOut( __objSendMsg( self, cArg ) ) } )
|
|
oOnTop:Create()
|
|
ENDIF
|
|
|
|
RETURN oOnTop:Instance()
|
|
|
|
//
|
|
// Generic Text file handler
|
|
//
|
|
|
|
FUNCTION TTextFile()
|
|
|
|
STATIC oFile
|
|
|
|
IF oFile == NIL
|
|
oFile := HBClass():New( "TTextFile", "TEmpty" )
|
|
// Create a new class def
|
|
// from TEmpty class
|
|
|
|
oFile:AddData( "cFileName" ) // Filename spec. by user
|
|
oFile:AddData( "hFile" ) // File handle
|
|
oFile:AddData( "nLine" ) // Current linenumber
|
|
oFile:AddData( "nError" ) // Last error
|
|
oFile:AddData( "lEoF" ) // End of file
|
|
oFile:AddData( "cBlock" ) // Storage block
|
|
oFile:AddData( "nBlockSize" ) // Size of read-ahead buffer
|
|
oFile:AddData( "cMode" ) // Mode of file use
|
|
// R = read, W = write
|
|
|
|
oFile:AddMethod( "New" , @New() ) // Constructor
|
|
oFile:AddMethod( "Run" , @Run() ) // Get/set data
|
|
oFile:AddMethod( "Dispose", @Dispose() ) // Clean up code
|
|
oFile:AddMethod( "Read" , @Read() ) // Read line
|
|
oFile:AddMethod( "WriteLn", @WriteLn() ) // Write line
|
|
oFile:AddMethod( "Write" , @Write() ) // Write without CR
|
|
oFile:AddMethod( "Goto" , @Goto() ) // Go to line
|
|
|
|
oFile:Create()
|
|
ENDIF
|
|
|
|
RETURN oFile:Instance()
|
|
|
|
//
|
|
// Method TextFile:New -> Create a new text file
|
|
//
|
|
// <cFile> file name. No wild characters
|
|
// <cMode> mode for opening. Default "R"
|
|
// <nBlockSize> Optional maximum blocksize
|
|
//
|
|
|
|
FUNCTION New( cFileName, cMode, nBlock )
|
|
|
|
LOCAL self := QSelf() // Get self
|
|
|
|
::nLine := 0
|
|
::lEoF := .F.
|
|
::cBlock := ""
|
|
::cFileName := cFileName
|
|
::cMode := Default( cMode, "R" )
|
|
|
|
IF ::cMode == "R"
|
|
::hFile := FOpen( cFileName )
|
|
ELSEIF ::cMode == "W"
|
|
::hFile := FCreate( cFileName )
|
|
ELSE
|
|
? "DosFile Init: Unknown file mode:", ::cMode
|
|
ENDIF
|
|
|
|
::nError := FError()
|
|
IF ::nError != 0
|
|
::lEoF := .T.
|
|
? "Error ", ::nError
|
|
ENDIF
|
|
::nBlockSize := Default( nBlock, 4096 )
|
|
|
|
RETURN self
|
|
|
|
FUNCTION RUN( xTxt, lCRLF )
|
|
|
|
LOCAL self := QSelf()
|
|
LOCAL xRet
|
|
|
|
IF ::cMode == "R"
|
|
xRet := ::Read()
|
|
ELSE
|
|
xRet := ::WriteLn( xTxt, lCRLF )
|
|
ENDIF
|
|
|
|
RETURN xRet
|
|
|
|
//
|
|
// Dispose -> Close the file handle
|
|
//
|
|
|
|
FUNCTION Dispose()
|
|
|
|
LOCAL self := QSelf()
|
|
|
|
::cBlock := NIL
|
|
IF ::hFile != F_ERROR
|
|
IF ! FClose( ::hFile )
|
|
::nError := FError()
|
|
? "Dos Error closing ", ::cFileName, " Code ", ::nError
|
|
ENDIF
|
|
ENDIF
|
|
|
|
RETURN self
|
|
|
|
//
|
|
// Read a single line
|
|
//
|
|
|
|
FUNCTION READ()
|
|
|
|
LOCAL self := QSelf()
|
|
LOCAL cRet := ""
|
|
LOCAL cBlock
|
|
LOCAL nCrPos
|
|
LOCAL nEoFPos
|
|
|
|
IF ::hFile == F_ERROR
|
|
? "DosFile:Read : No file open"
|
|
ELSEIF !( ::cMode == "R" )
|
|
? "File ", ::cFileName, " not open for reading"
|
|
ELSEIF ! ::lEoF
|
|
|
|
IF Len( ::cBlock ) == 0 // Read new block
|
|
cBlock := FReadStr( ::hFile, ::nBlockSize )
|
|
IF Len( cBlock ) == 0
|
|
::nError := FError() // Error or EOF
|
|
::lEoF := .T.
|
|
ELSE
|
|
::cBlock := cBlock
|
|
ENDIF
|
|
ENDIF
|
|
|
|
IF ! ::lEoF
|
|
::nLine++
|
|
nCRPos := At( Chr( 10 ), ::cBlock )
|
|
IF nCRPos != 0 // More than one line read
|
|
cRet := SubStr( ::cBlock, 1, nCRPos - 1 )
|
|
::cBlock := SubStr( ::cBlock, nCRPos + 1 )
|
|
ELSE // No complete line
|
|
cRet := ::cBlock
|
|
::cBlock := ""
|
|
cRet += ::Read() // Read the rest
|
|
IF ! ::lEoF
|
|
::nLine-- // Adjust erroneous line count
|
|
ENDIF
|
|
ENDIF
|
|
nEoFPos := hb_BAt( Chr( 26 ), cRet )
|
|
IF nEoFPos != 0 // End of file read
|
|
cRet := hb_BSubStr( cRet, 1, nEoFPos - 1 )
|
|
::lEoF := .T.
|
|
ENDIF
|
|
cRet := StrTran( cRet, Chr( 13 ) ) // Remove CR
|
|
ENDIF
|
|
ENDIF
|
|
|
|
RETURN cRet
|
|
|
|
//
|
|
// WriteLn -> Write a line to a file
|
|
//
|
|
// <xTxt> Text to write. May be any type. May also be an array containing
|
|
// one or more strings
|
|
// <lCRLF> End with Carriage Return/Line Feed (Default == TRUE)
|
|
//
|
|
|
|
FUNCTION WriteLn( xTxt, lCRLF )
|
|
|
|
LOCAL self := QSelf()
|
|
LOCAL cBlock
|
|
|
|
IF ::hFile == F_ERROR
|
|
? "DosFile:Write : No file open"
|
|
ELSEIF !( ::cMode == "W" )
|
|
? "File ", ::cFileName, " not opened for writing"
|
|
ELSE
|
|
cBlock := hb_ValToExp( xTxt ) // Convert to string
|
|
IF Default( lCRLF, .T. )
|
|
cBlock += hb_eol()
|
|
ENDIF
|
|
FWrite( ::hFile, cBlock, Len( cBlock ) )
|
|
IF FError() != 0
|
|
::nError := FError() // Not completely written !
|
|
ENDIF
|
|
::nLine := ::nLine + 1
|
|
ENDIF
|
|
|
|
RETURN self
|
|
|
|
FUNCTION Write( xTxt )
|
|
|
|
LOCAL self := QSelf()
|
|
|
|
RETURN ::WriteLn( xTxt, .F. )
|
|
|
|
//
|
|
// Go to a specified line number
|
|
//
|
|
|
|
STATIC FUNCTION GOTO( nLine )
|
|
|
|
LOCAL self := QSelf()
|
|
LOCAL nWhere := 1
|
|
|
|
IF Empty( ::hFile )
|
|
? "DosFile:Goto : No file open"
|
|
ELSEIF !( ::cMode == "R" )
|
|
? "File ", ::cFileName, " not open for reading"
|
|
ELSE
|
|
::lEoF := .F. // Clear (old) End of file
|
|
::nLine := 0 // Start at beginning
|
|
::cBlock := ""
|
|
FSeek( ::hFile, 0 ) // Go top
|
|
DO WHILE ! ::lEoF .AND. nWhere < nLine
|
|
nWhere++
|
|
::Read()
|
|
ENDDO
|
|
ENDIF
|
|
|
|
RETURN ! ::lEoF
|