Changes between Initial Version and Version 1 of FdoTextReaderEnhancements


Ignore:
Timestamp:
10/18/07 13:55:43 (17 years ago)
Author:
gregboone
Comment:

--

Legend:

Unmodified
Added
Removed
Modified
  • FdoTextReaderEnhancements

    v1 v1  
     1
     2== FDO !TextReader Enhancements ==
     3
     4==== Overview ====
     5
     6The FDO API provides a number of classes to support streamed I/O to files and in-memory buffers. Clients can add derived classes to support additional devices. A number of Reader and Writer classes are provided to read and write formatted data from and to these devices. One of these classes is the !FdoIoTextReader, which reads data from a stream in text format.
     7
     8The !FdoIoTextReader class is incomplete. Streaming support was added to FDO to satisfy the requirement to read and write XML documents.  Although XML documents tend to be in text format, !FdoIoTextReader was not actually needed to read XML; the !FdoXmlReader uses Xerces instead. Therefore, !FdoIoTextReader has constructor and destructor but no actual text reading functions.
     9
     10The !FdoIoTextReader should be completed for the following reasons:
     11
     12• It rounds out the API. The converse class (!FdoIoTextWriter) is fully implement so finishing !FdoIoTextReader would make the API more consistent[[br]]
     13• Developers using FDO 3.2 could have used !FdoIoTextReader to convert stream contents to a string. Instead, they had to write workaround code since this class was not complete[[br]]
     14• The API changes can be made in a way that will provide performance benefits for writing XML documents. This will be seen later in this document when the API changes are discussed[[br]]
     15
     16=== API Changes ===
     17
     18==== !FdoIoTextReader ====
     19
     20The text reader can be enhanced by adding functions to read formatted (delimited) text.
     21
     22
     23{{{
     24class FdoIoTextReader : public FdoIDisposable
     25{
     26public:
     27
     28        FDO_API_COMMON FdoBoolean ReadLine(FdoStringP& outString);
     29
     30        FDO_API_COMMON FdoBoolean Read(FdoStringP& outString);
     31
     32        FDO_API_COMMON FdoBoolean Read(
     33                FdoStringP& outString,
     34                FdoString* leftDelimiters
     35        );
     36
     37        FDO_API_COMMON FdoBoolean Read(
     38                FdoStringP& outString,
     39                FdoString* leftDelimiters,
     40                FdoString* rightDelimiters
     41        );
     42
     43        FDO_API_COMMON FdoBoolean Read(
     44                FdoStringP& outString,
     45                FdoString* leftDelimiters,
     46                FdoString* rightDelimiters,
     47                FdoString* skipChars
     48        );
     49
     50        FDO_API_COMMON FdoBoolean Read(
     51                FdoStringP& outString,
     52                FdoString* leftDelimiters,
     53                FdoString* rightDelimiters,
     54                FdoString* skipChars,
     55                FdoString* separators
     56        );
     57};
     58}}}
     59
     60''Parameters'':
     61
     62outString: the string that was read
     63
     64leftDelimiters: list of left delimiter characters; defaults to empty string (L"").
     65
     66rightDelimiters: list of right delimiter characters; defaults to empty string (L""). Position is important: 1st left delimiter corresponds to 1st right delimiter and so on. If a right delimiter is not explicitly specified for a particular left delimiter then the right delimiter is the same as the left.
     67
     68skipChars: list of characters that can be skipped while looking for the left delimiter; defaults to blank character plus end-of line (L" \n").
     69
     70separators: list of separator characters. These are similar to skip characters except that a separator can only occur once between each string that is read; defaults to empty string (L"").
     71
     72''Description'':
     73
     74!ReadLine() Reads the current line (from the current position to the next end-of-line character or end-of-stream).
     75
     76Read() provides the ability to read delimited strings.
     77
     78Reading is done according to the following steps:
     79
     80• starting at the current position, any characters in the skipChars set are skipped.[[br]]
     81• if the next character is a left delimiter, outString becomes all characters between but not including the left and corresponding right delimiter[[br]]
     82• otherwise. outString becomes all characters from the current character, up to but not including the next skipChar or separator (or end-of-stream, whichever comes first).[[br]]
     83• Any subsequent skipChars or separators are skipped. However, Read() stops if a second separator character is encountered.  In this case, the 2nd separator is not skipped but the current position is set to it.[[br]]
     84
     85''Returns'':
     86
     87!ReadLine() returns true if a line was read and false if at the end of the underlying stream.
     88
     89Read() returns true if a string was read and false otherwise. false is returned if the end of the stream is reached before a string can be extracted.
     90
     91It is possible for both of the above to return true with outString being an empty string. For !ReadLine(), this happens when the character at the current position is the end-of-line character. For Read() this can happen when there are no characters between the left and right delimeters.
     92
     93''Exceptions'':
     94
     95Read() throws an FdoException if a left delimiter is encountered but end-of-stream is reached before the right delimiter is found.
     96
     97''Example 1'':
     98
     99if the data at and after the input stream’s current position looks like this:
     100
     101"   {'T – true', 'F – false'} {'red' 'green', 'blue'}"
     102
     103then the following table shows the return value and string that is read. Current position on return from Read() is also shown by the remainder which shows the part of the stream at and after the new current position:
     104
     105||'''call'''||'''returns'''||'''outString'''||'''remainder'''||
     106||Read(outString, "", "", " {'" )||true||"T"||" – true’, ‘F – false’} {‘red’ ‘green’, ‘blue’}"||
     107||Read(outString)||true||"{'T"||" – true’, ‘F – false’} {‘red’ ‘green’, ‘blue’}"||
     108||Read(outString, "'", "", "{ " )||true||"T – true"||", ‘F – false’} {‘red’ ‘green’, ‘blue’}"||
     109||Read(outString, "'", "", "{" )||false(*)||n/a||"   {'T – true', 'F – false'} {'red' 'green', 'blue'}"||
     110||Read(outString,"", "", "" )||true||"   {'T – true', 'F – false'} {'red' 'green', 'blue'}"||"" (next call to Read would return false)||
     111||Read(outString,"'{","'}"," "}||true||"'T – true', 'F – false'" (**)||" {'red' 'green', 'blue'}"||
     112
     113(*) - " " is not a skip character so left delimiter is not reached[[br]]
     114(**) – the 2nd ("{"} leftDelimiter is encountered before "'", so read is done until the 2nd right delimiter ("}") is reached[[br]]
     115