Index: src/utils/SkFrontBufferedStream.cpp |
diff --git a/src/utils/SkFrontBufferedStream.cpp b/src/utils/SkFrontBufferedStream.cpp |
index f23b1f99c4c6da1c98f8b947647ce977421546e8..beead37a9579a3c8331cfeed5420adcda441e3dd 100644 |
--- a/src/utils/SkFrontBufferedStream.cpp |
+++ b/src/utils/SkFrontBufferedStream.cpp |
@@ -16,6 +16,8 @@ public: |
size_t read(void* buffer, size_t size) override; |
+ bool peek(void* buffer, size_t size) const override; |
+ |
bool isAtEnd() const override; |
bool rewind() override; |
@@ -155,6 +157,20 @@ size_t FrontBufferedStream::readDirectlyFromStream(char* dst, size_t size) { |
return bytesReadDirectly; |
} |
+bool FrontBufferedStream::peek(void* dst, size_t size) const { |
+ // Keep track of the offset so we can return to it. |
+ const size_t start = fOffset; |
+ if (start + size > fBufferSize) { |
+ // This stream is not able to buffer enough. |
+ return false; |
+ } |
+ FrontBufferedStream* nonConstThis = const_cast<FrontBufferedStream*>(this); |
+ SkDEBUGCODE(const size_t bytesRead =) nonConstThis->read(dst, size); |
+ SkASSERT(bytesRead == size); |
+ nonConstThis->fOffset = start; |
+ return true; |
+} |
+ |
size_t FrontBufferedStream::read(void* voidDst, size_t size) { |
// Cast voidDst to a char* for easy addition. |
char* dst = reinterpret_cast<char*>(voidDst); |