aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/core/SkPictureData.h
diff options
context:
space:
mode:
authorGravatar Florin Malita <fmalita@chromium.org>2018-05-15 14:57:12 -0400
committerGravatar Skia Commit-Bot <skia-commit-bot@chromium.org>2018-05-15 19:59:23 +0000
commit8fd15d8c7ef09ab5aad4d7bbf8c3f3564a537722 (patch)
tree50822f223a6d665b4622970d4a21e34e10c3252b /src/core/SkPictureData.h
parent724afe8b2da2cd32394921096d5c738519b5a51e (diff)
Scrub SkPictureData/SkPictureRecord
- replace manual ref fiddling with smart types - remove unused SkPictureData::fBitmapImageRefs - remove the preallocation in new_array_from_buffer (to prevent fuzzer OOMs) Bug: skia:7937 Change-Id: I50f49fa8e594a138ea09c22f7bf73cf57ec006ff Reviewed-on: https://skia-review.googlesource.com/128309 Commit-Queue: Florin Malita <fmalita@chromium.org> Reviewed-by: Mike Klein <mtklein@chromium.org> Reviewed-by: Kevin Lubick <kjlubick@google.com>
Diffstat (limited to 'src/core/SkPictureData.h')
-rw-r--r--src/core/SkPictureData.h45
1 files changed, 19 insertions, 26 deletions
diff --git a/src/core/SkPictureData.h b/src/core/SkPictureData.h
index 3d54a47a79..659b9ca510 100644
--- a/src/core/SkPictureData.h
+++ b/src/core/SkPictureData.h
@@ -12,6 +12,9 @@
#include "SkDrawable.h"
#include "SkPicture.h"
#include "SkPictureFlat.h"
+#include "SkTArray.h"
+
+#include <memory>
class SkData;
class SkPictureRecord;
@@ -65,9 +68,10 @@ public:
// Always write this guy last (with no length field afterwards)
#define SK_PICT_EOF_TAG SkSetFourByteTag('e', 'o', 'f', ' ')
-template <typename T> T* read_index_base_1_or_null(SkReadBuffer* reader, int count, T* array[]) {
+template <typename T>
+T* read_index_base_1_or_null(SkReadBuffer* reader, const SkTArray<sk_sp<T>>& array) {
int index = reader->readInt();
- return reader->validate(index > 0 && index <= count) ? array[index - 1] : nullptr;
+ return reader->validate(index > 0 && index <= array.count()) ? array[index - 1].get() : nullptr;
}
class SkPictureData {
@@ -80,8 +84,6 @@ public:
SkTypefacePlayback*);
static SkPictureData* CreateFromBuffer(SkReadBuffer&, const SkPictInfo&);
- virtual ~SkPictureData();
-
void serialize(SkWStream*, const SkSerialProcs&, SkRefCntSet*) const;
void flatten(SkWriteBuffer&) const;
@@ -98,7 +100,7 @@ public:
const SkImage* getImage(SkReadBuffer* reader) const {
// images are written base-0, unlike paths, pictures, drawables, etc.
const int index = reader->readInt();
- return reader->validateIndex(index, fImageCount) ? fImageRefs[index] : nullptr;
+ return reader->validateIndex(index, fImages.count()) ? fImages[index].get() : nullptr;
}
const SkPath& getPath(SkReadBuffer* reader) const {
@@ -108,11 +110,11 @@ public:
}
const SkPicture* getPicture(SkReadBuffer* reader) const {
- return read_index_base_1_or_null(reader, fPictureCount, fPictureRefs);
+ return read_index_base_1_or_null(reader, fPictures);
}
SkDrawable* getDrawable(SkReadBuffer* reader) const {
- return read_index_base_1_or_null(reader, fDrawableCount, fDrawableRefs);
+ return read_index_base_1_or_null(reader, fDrawables);
}
const SkPaint* getPaint(SkReadBuffer* reader) const {
@@ -125,16 +127,14 @@ public:
}
const SkTextBlob* getTextBlob(SkReadBuffer* reader) const {
- return read_index_base_1_or_null(reader, fTextBlobCount, fTextBlobRefs);
+ return read_index_base_1_or_null(reader, fTextBlobs);
}
const SkVertices* getVertices(SkReadBuffer* reader) const {
- return read_index_base_1_or_null(reader, fVerticesCount, fVerticesRefs);
+ return read_index_base_1_or_null(reader, fVertices);
}
private:
- void init();
-
// these help us with reading/writing
// Does not affect ownership of SkStream.
bool parseStreamTag(SkStream*, uint32_t tag, uint32_t size,
@@ -150,21 +150,14 @@ private:
const SkPath fEmptyPath;
const SkBitmap fEmptyBitmap;
- const SkPicture** fPictureRefs;
- int fPictureCount;
- SkDrawable** fDrawableRefs;
- int fDrawableCount;
- const SkTextBlob** fTextBlobRefs;
- int fTextBlobCount;
- const SkVertices** fVerticesRefs;
- int fVerticesCount;
- const SkImage** fImageRefs;
- int fImageCount;
- const SkImage** fBitmapImageRefs;
- int fBitmapImageCount;
-
- SkTypefacePlayback fTFPlayback;
- SkFactoryPlayback* fFactoryPlayback;
+ SkTArray<sk_sp<const SkPicture>> fPictures;
+ SkTArray<sk_sp<SkDrawable>> fDrawables;
+ SkTArray<sk_sp<const SkTextBlob>> fTextBlobs;
+ SkTArray<sk_sp<const SkVertices>> fVertices;
+ SkTArray<sk_sp<const SkImage>> fImages;
+
+ SkTypefacePlayback fTFPlayback;
+ std::unique_ptr<SkFactoryPlayback> fFactoryPlayback;
const SkPictInfo fInfo;