diff options
author | Andreas Stöckel <astoecke@techfak.uni-bielefeld.de> | 2015-01-24 03:07:00 +0100 |
---|---|---|
committer | Andreas Stöckel <astoecke@techfak.uni-bielefeld.de> | 2015-01-24 03:07:00 +0100 |
commit | 4c5ecbe39bf17ebd1c663c863cef5094f53caf86 (patch) | |
tree | f02551371b0cdd0563136ba22d831781d01afc91 /src/core/common/CharReader.cpp | |
parent | fcdc9e28805138383c6ef662ea5e3822720b772c (diff) |
Added seek function to CharReader, improved getOffset
Diffstat (limited to 'src/core/common/CharReader.cpp')
-rw-r--r-- | src/core/common/CharReader.cpp | 21 |
1 files changed, 18 insertions, 3 deletions
diff --git a/src/core/common/CharReader.cpp b/src/core/common/CharReader.cpp index 6fd3d45..07482ff 100644 --- a/src/core/common/CharReader.cpp +++ b/src/core/common/CharReader.cpp @@ -502,16 +502,31 @@ size_t CharReader::readRaw(char *buf, size_t size) return res; } +size_t CharReader::seek(size_t requestedOffset) +{ + // Fetch the current offset + const ssize_t currentOffs = getOffset(); + const ssize_t relativeOffs = requestedOffset - currentOffs; + + // Perform the actual seeking, move the peek cursor to the read cursor + const ssize_t reachedOffs = currentOffs + buffer->moveCursor(readCursor, relativeOffs); + buffer->copyCursor(readCursor, peekCursor); + coherent = true; + + // Clamp to values larger or equal to zero + return reachedOffs < 0 ? 0 : reachedOffs; +} + bool CharReader::atEnd() const { return buffer->atEnd(readCursor); } -SourceOffset CharReader::getOffset() const +size_t CharReader::getOffset() const { return buffer->offset(readCursor) + offs; } -SourcePosition CharReader::getPosition() const +size_t CharReader::getPeekOffset() const { - return getOffset(); + return buffer->offset(readCursor) + offs; } SourceLocation CharReader::getLocation() const |