Menu

[r2378]: / trunk / Src / UStringReader.pas  Maximize  Restore  History

Download this file

131 lines (110 with data), 3.2 kB

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
{
* This Source Code Form is subject to the terms of the Mozilla Public License,
* v. 2.0. If a copy of the MPL was not distributed with this file, You can
* obtain one at http://mozilla.org/MPL/2.0/
*
* Copyright (C) 2005-2012, Peter Johnson (www.delphidabbler.com).
*
* $Rev$
* $Date$
*
* Defines class that performs character based access to a stream.
}
unit UStringReader;
interface
uses
// Project
UConsts;
type
/// <summary>
/// Class that performs character based access to a string. Reads data from
/// the string one character at a time, treating CRLF pairs as a single EOL
/// character. Characters can be put back onto the string.
/// </summary>
TStringReader = class(TObject)
strict private
/// String being read.
var fBuffer: string;
/// Cursor that indexes next character to be read.
var fIdx: Integer;
/// Read accessor for Ch property. Returns last character read or EOF.
function GetCh: Char;
public
/// Character indicating end of file.
const EOF = #0;
/// Character indicating end of line.
const EOL = LF;
/// Object constructor. Records string to be read. Initialises Ch property
/// by reading first character.
constructor Create(const Str: string);
/// Fetches next character from string and returns it. Returns EOL at end
/// of line and EOF at end of file.
function NextChar: Char;
/// Puts last character read back on end of string.
procedure PutBackChar;
/// Last character read from stream (EOL at end of line and EOF at end of
/// file).
property Ch: Char read GetCh;
end;
implementation
uses
// Delphi
SysUtils;
{ TStringReader }
constructor TStringReader.Create(const Str: string);
begin
inherited Create;
fBuffer := Str;
// set cursor to just before start of buffer then read first char
fIdx := 0;
NextChar;
end;
function TStringReader.GetCh: Char;
begin
if fIdx <= Length(fBuffer) then
begin
// within buffer: get char at current position
Result := fBuffer[fIdx];
if CharInSet(Result, [CR, LF]) then
// char is one of EOL chars => return EOL
Result := EOL;
end
else
Result := EOF;
end;
function TStringReader.NextChar: Char;
begin
if fIdx < Length(fBuffer) then
begin
// there are more chars: increment cursor to next char position
Inc(fIdx);
if fBuffer[fIdx] = CR then
begin
// new char is CR: skip it if followed by LF
if (fIdx < Length(fBuffer)) and (fBuffer[fIdx + 1] = LF) then
Inc(fIdx);
end;
end
else
// no remaining chars: place cursor beyond end of buffer => EOF
fIdx := Length(fBuffer) + 1;
// return character just read or EOF
Result := GetCh;
end;
procedure TStringReader.PutBackChar;
begin
if fIdx > 1 then
begin
// fIdx in [2..Length(fBuffer) + 1] => we can move back in buffer
// this permits putting back char at EOF
Dec(fIdx);
if fBuffer[fIdx] = LF then
begin
// new current char is LF: if preceeded by CR we will have skipped over CR
// when read so we go back two chars in buffer
if (fIdx > 1) and (fBuffer[fIdx - 1] = CR) then
Dec(fIdx);
end;
end;
end;
end.
Want the latest updates on software, tech news, and AI?
Get latest updates about software, tech news, and AI from SourceForge directly in your inbox once a month.