/* $DOC$ $NAME$ TFileRead() $CATEGORY$ Harbour Tools $ONELINER$ Read a file one line at a time $SYNTAX$ oFile := TFileRead():New( [, ] ) $ARGUMENTS$ is the required name of the file to be read. is the optional size to use when reading from the file. The default value is 4096 and the allowed range is 1 through 65535. Any value outside of this range causes the default value to be used. $RETURNS$ An instance of the File Reader class $DESCRIPTION$ TFileRead() is used to access a file one line at a time. You must specify the name of the file when an instance of the class is created. The class data should be considered private to the class. The class methods are as follows: New() Creates a new instance of the TFileRead class. Open( [] ) Opens the file for reading. The optional nFlags parameter can use any of the file open flags from fileio.ch. The default is FO_READ + FO_SHARED. Calling this method when the file is already open causes the next ReadLine() to start over from the beginning of the file. Close() Closes the file. ReadLine() Returns one line from the file, stripping the newline characters. The following sequences are treated as one newline: 1) CR CR LF; 2) CR LF; 3) LF; and 4) CR. Note: LF CR is 2 newlines. Name() Returns the name of the file. IsOpen() Returns .T. if the file is open. MoreToRead() Returns .T. if there are more lines to be read (think of it as an inverse EOF function). Error() Returns .T. if an error has occurred. ErrorNo() Returns the current error code. ErrorMsg( [] ) Returns a formatted error message. $EXAMPLES$ PROCEDURE Main( cFile ) LOCAL oFile := TFileRead():New( cFile ) oFile:Open() IF oFile:Error() ? oFile:ErrorMsg( "FileRead:" ) ELSE DO WHILE oFile:MoreToRead() ? oFile:ReadLine() ENDDO oFile:Close() ENDIF RETURN $STATUS$ R $COMPLIANCE$ This is a new Harbour Tools class $FILES$ Library is hbmisc $SEEALSO$ TClass() $END$ */