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

Unified Diff: third_party/WebKit/Source/platform/image-decoders/DataSegmentReader.h

Issue 1812273003: Eliminate copies of encoded image data (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Convert to PassRefPtr in ImageDecoder, helper for setData Created 4 years, 9 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
Index: third_party/WebKit/Source/platform/image-decoders/DataSegmentReader.h
diff --git a/third_party/WebKit/Source/platform/image-decoders/DataSegmentReader.h b/third_party/WebKit/Source/platform/image-decoders/DataSegmentReader.h
new file mode 100644
index 0000000000000000000000000000000000000000..ed8441c231bb1eec8c0a0ca1e7a7973b73fe33fb
--- /dev/null
+++ b/third_party/WebKit/Source/platform/image-decoders/DataSegmentReader.h
@@ -0,0 +1,29 @@
+// Copyright 2016 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef DataSegmentReader_h
+#define DataSegmentReader_h
+
+#include "platform/image-decoders/SegmentReader.h"
+#include "skia/ext/refptr.h"
+#include "third_party/skia/include/core/SkData.h"
+#include "wtf/Noncopyable.h"
+#include "wtf/PassRefPtr.h"
+
+namespace blink {
+
+// Interface for ImageDecoder to read an SkData
+class DataSegmentReader final : public SegmentReader {
+ WTF_MAKE_NONCOPYABLE(DataSegmentReader);
+public:
+ DataSegmentReader(PassRefPtr<SkData>);
+ size_t size() const override;
+ size_t getSomeData(const char*& data, size_t position) const override;
+ PassRefPtr<SkData> getAsSkData() const override;
+private:
+ skia::RefPtr<SkData> m_data;
+};
+
+} // namespace blink
+#endif // DataSegmentReader_h

Powered by Google App Engine
This is Rietveld 408576698