Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(16)

Unified Diff: include/utils/SkBufferedStream.h

Issue 23717055: Add a buffered SkStream class. (Closed) Base URL: https://skia.googlecode.com/svn/trunk
Patch Set: Respond to comments Created 7 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « gyp/utils.gyp ('k') | src/utils/SkBufferedStream.cpp » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: include/utils/SkBufferedStream.h
diff --git a/include/utils/SkBufferedStream.h b/include/utils/SkBufferedStream.h
new file mode 100644
index 0000000000000000000000000000000000000000..cc15d151b91fe80ec0a9e1a851daddf8ddffe788
--- /dev/null
+++ b/include/utils/SkBufferedStream.h
@@ -0,0 +1,57 @@
+/*
+ * Copyright 2013 Google Inc.
+ *
+ * Use of this source code is governed by a BSD-style license that can be
+ * found in the LICENSE file.
+ */
+
+#include "SkStream.h"
+#include "SkTypes.h"
+
+class SkBufferedStream : public SkStreamRewindable {
reed1 2013/09/17 20:23:02 We might consider just adding the static Create to
scroggo 2013/09/17 20:41:19 I was leaving it in utils since I think only Andro
+public:
+ /**
+ * Creates a new stream that wraps and buffers SkStream.
+ * @param stream SkStream to buffer. If NULL, NULL is returned. After
+ * this call, unref stream and do not refer to it.
+ * SkBufferedStream is expected to be its only owner.
+ * @param bufferSize Exact size of the buffer to be used.
+ * @return An SkStream that can buffer up to bufferSize.
+ */
+ static SkBufferedStream* Create(SkStream* stream, size_t bufferSize);
+
+ virtual size_t read(void* buffer, size_t size) SK_OVERRIDE;
+
+ virtual bool isAtEnd() const SK_OVERRIDE;
+
+ virtual bool rewind() SK_OVERRIDE;
+
+ virtual bool hasPosition() const SK_OVERRIDE { return true; }
+
+ virtual size_t getPosition() const SK_OVERRIDE { return fOffset; }
+
+ virtual bool hasLength() const SK_OVERRIDE;
+
+ virtual size_t getLength() const SK_OVERRIDE;
+
+ virtual SkStreamRewindable* duplicate() const SK_OVERRIDE { return NULL; }
+
+private:
+ SkAutoTUnref<SkStream> fStream;
+ size_t fOffset;
+ size_t fBufferedSoFar;
+ const size_t fBufferSize;
+ SkAutoTMalloc<char> fBuffer;
+
+ // Unimplemented.
+ SkBufferedStream();
+
+ // Private. Use Create.
+ SkBufferedStream(SkStream*, size_t bufferSize);
+
+ char* getBufferAtOffset() {
+ return fBuffer.get() + fOffset;
+ }
+
+ typedef SkStream INHERITED;
+};
« no previous file with comments | « gyp/utils.gyp ('k') | src/utils/SkBufferedStream.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698