aboutsummaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/core/SkStream.cpp22
1 files changed, 16 insertions, 6 deletions
diff --git a/src/core/SkStream.cpp b/src/core/SkStream.cpp
index 2c5e9eba2f..fef5aa8794 100644
--- a/src/core/SkStream.cpp
+++ b/src/core/SkStream.cpp
@@ -472,9 +472,9 @@ SkDynamicMemoryWStream::~SkDynamicMemoryWStream() {
}
void SkDynamicMemoryWStream::reset() {
- Block* block = fHead;
+ Block* block = fHead;
while (block != nullptr) {
- Block* next = block->fNext;
+ Block* next = block->fNext;
sk_free(block);
block = next;
}
@@ -493,7 +493,8 @@ size_t SkDynamicMemoryWStream::bytesWritten() const {
bool SkDynamicMemoryWStream::write(const void* buffer, size_t count) {
if (count > 0) {
- size_t size;
+ SkASSERT(buffer);
+ size_t size;
if (fTail) {
if (fTail->avail() > 0) {
@@ -516,10 +517,11 @@ bool SkDynamicMemoryWStream::write(const void* buffer, size_t count) {
block->init(size);
block->append(buffer, count);
- if (fTail != nullptr)
+ if (fTail != nullptr) {
fTail->fNext = block;
- else
+ } else {
fHead = fTail = block;
+ }
fTail = block;
this->validate();
}
@@ -536,8 +538,9 @@ bool SkDynamicMemoryWStream::read(void* buffer, size_t offset, size_t count) {
if (offset < size) {
size_t part = offset + count > size ? size - offset : count;
memcpy(buffer, block->start() + offset, part);
- if (count <= part)
+ if (count <= part) {
return true;
+ }
count -= part;
buffer = (void*) ((char* ) buffer + part);
}
@@ -548,6 +551,7 @@ bool SkDynamicMemoryWStream::read(void* buffer, size_t offset, size_t count) {
}
void SkDynamicMemoryWStream::copyTo(void* dst) const {
+ SkASSERT(dst);
Block* block = fHead;
while (block != nullptr) {
size_t size = block->written();
@@ -558,6 +562,7 @@ void SkDynamicMemoryWStream::copyTo(void* dst) const {
}
bool SkDynamicMemoryWStream::writeToStream(SkWStream* dst) const {
+ SkASSERT(dst);
for (Block* block = fHead; block != nullptr; block = block->fNext) {
if (!dst->write(block->start(), block->written())) {
return false;
@@ -583,6 +588,10 @@ void SkDynamicMemoryWStream::padToAlign4() {
void SkDynamicMemoryWStream::copyToAndReset(void* ptr) {
+ if (!ptr) {
+ this->reset();
+ return;
+ }
// By looping through the source and freeing as we copy, we
// can reduce real memory use with large streams.
char* dst = reinterpret_cast<char*>(ptr);
@@ -600,6 +609,7 @@ void SkDynamicMemoryWStream::copyToAndReset(void* ptr) {
}
bool SkDynamicMemoryWStream::writeToAndReset(SkWStream* dst) {
+ SkASSERT(dst);
// By looping through the source and freeing as we copy, we
// can reduce real memory use with large streams.
bool dstStreamGood = true;