aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/core/SkReadBuffer.cpp
diff options
context:
space:
mode:
authorGravatar Mike Reed <reed@google.com>2017-12-07 13:01:39 -0500
committerGravatar Skia Commit-Bot <skia-commit-bot@chromium.org>2017-12-07 18:25:09 +0000
commit44aa9b2d1e708acb0e32db549abff793283ff442 (patch)
treecb4279459a54ff3791a7a2dcfcdd11e73b8a1781 /src/core/SkReadBuffer.cpp
parent20b1572912aa62eb3662f7066983218cfee8d6e6 (diff)
check for bad strings in readFlattenable
Bug:792815 Change-Id: I3b79d8b182bd129e9a17185991020d1dafb66a34 Reviewed-on: https://skia-review.googlesource.com/82060 Reviewed-by: Mike Klein <mtklein@chromium.org> Commit-Queue: Mike Reed <reed@google.com>
Diffstat (limited to 'src/core/SkReadBuffer.cpp')
-rw-r--r--src/core/SkReadBuffer.cpp7
1 files changed, 4 insertions, 3 deletions
diff --git a/src/core/SkReadBuffer.cpp b/src/core/SkReadBuffer.cpp
index b6d0d14f48..06457fa8d8 100644
--- a/src/core/SkReadBuffer.cpp
+++ b/src/core/SkReadBuffer.cpp
@@ -418,12 +418,13 @@ SkFlattenable* SkReadBuffer::readFlattenable(SkFlattenable::Type ft) {
// Read the index. We are guaranteed that the first byte
// is zeroed, so we must shift down a byte.
uint32_t index = fReader.readU32() >> 8;
- if (0 == index) {
+ if (!this->validate(index > 0)) {
return nullptr; // writer failed to give us the flattenable
}
-
SkString* namePtr = fFlattenableDict.find(index);
- SkASSERT(namePtr);
+ if (!this->validate(namePtr != nullptr)) {
+ return nullptr;
+ }
name = *namePtr;
}