| OLD | NEW |
| 1 | 1 |
| 2 /* | 2 /* |
| 3 * Copyright 2006 The Android Open Source Project | 3 * Copyright 2006 The Android Open Source Project |
| 4 * | 4 * |
| 5 * Use of this source code is governed by a BSD-style license that can be | 5 * Use of this source code is governed by a BSD-style license that can be |
| 6 * found in the LICENSE file. | 6 * found in the LICENSE file. |
| 7 */ | 7 */ |
| 8 | 8 |
| 9 | 9 |
| 10 #include "SkStream.h" | 10 #include "SkStream.h" |
| (...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 62 } else { | 62 } else { |
| 63 return byte; | 63 return byte; |
| 64 } | 64 } |
| 65 } | 65 } |
| 66 | 66 |
| 67 SkData* SkStream::readData() { | 67 SkData* SkStream::readData() { |
| 68 size_t size = this->readU32(); | 68 size_t size = this->readU32(); |
| 69 if (0 == size) { | 69 if (0 == size) { |
| 70 return SkData::NewEmpty(); | 70 return SkData::NewEmpty(); |
| 71 } else { | 71 } else { |
| 72 void* buffer = sk_malloc_throw(size); | 72 SkData* data = SkData::NewUninitialized(size); |
| 73 this->read(buffer, size); | 73 this->read(data->writable_data(), size); |
| 74 return SkData::NewFromMalloc(buffer, size); | 74 return data; |
| 75 } | 75 } |
| 76 } | 76 } |
| 77 | 77 |
| 78 ////////////////////////////////////////////////////////////////////////////////
////// | 78 ////////////////////////////////////////////////////////////////////////////////
////// |
| 79 | 79 |
| 80 SkWStream::~SkWStream() | 80 SkWStream::~SkWStream() |
| 81 { | 81 { |
| 82 } | 82 } |
| 83 | 83 |
| 84 void SkWStream::newline() | 84 void SkWStream::newline() |
| (...skipping 216 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 301 } | 301 } |
| 302 return fData->data(); | 302 return fData->data(); |
| 303 } | 303 } |
| 304 | 304 |
| 305 /////////////////////////////////////////////////////////////////////////////// | 305 /////////////////////////////////////////////////////////////////////////////// |
| 306 | 306 |
| 307 static SkData* newFromParams(const void* src, size_t size, bool copyData) { | 307 static SkData* newFromParams(const void* src, size_t size, bool copyData) { |
| 308 if (copyData) { | 308 if (copyData) { |
| 309 return SkData::NewWithCopy(src, size); | 309 return SkData::NewWithCopy(src, size); |
| 310 } else { | 310 } else { |
| 311 return SkData::NewWithProc(src, size, NULL, NULL); | 311 return SkData::NewWithoutCopy(src, size); |
| 312 } | 312 } |
| 313 } | 313 } |
| 314 | 314 |
| 315 SkMemoryStream::SkMemoryStream() { | 315 SkMemoryStream::SkMemoryStream() { |
| 316 fData = SkData::NewEmpty(); | 316 fData = SkData::NewEmpty(); |
| 317 fOffset = 0; | 317 fOffset = 0; |
| 318 } | 318 } |
| 319 | 319 |
| 320 SkMemoryStream::SkMemoryStream(size_t size) { | 320 SkMemoryStream::SkMemoryStream(size_t size) { |
| 321 fData = SkData::NewFromMalloc(sk_malloc_throw(size), size); | 321 fData = SkData::NewUninitialized(size); |
| 322 fOffset = 0; | 322 fOffset = 0; |
| 323 } | 323 } |
| 324 | 324 |
| 325 SkMemoryStream::SkMemoryStream(const void* src, size_t size, bool copyData) { | 325 SkMemoryStream::SkMemoryStream(const void* src, size_t size, bool copyData) { |
| 326 fData = newFromParams(src, size, copyData); | 326 fData = newFromParams(src, size, copyData); |
| 327 fOffset = 0; | 327 fOffset = 0; |
| 328 } | 328 } |
| 329 | 329 |
| 330 SkMemoryStream::SkMemoryStream(SkData* data) { | 330 SkMemoryStream::SkMemoryStream(SkData* data) { |
| 331 if (NULL == data) { | 331 if (NULL == data) { |
| (...skipping 315 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 647 // cast to remove unary-minus warning | 647 // cast to remove unary-minus warning |
| 648 int padBytes = -(int)fBytesWritten & 0x03; | 648 int padBytes = -(int)fBytesWritten & 0x03; |
| 649 if (padBytes == 0) | 649 if (padBytes == 0) |
| 650 return; | 650 return; |
| 651 int zero = 0; | 651 int zero = 0; |
| 652 write(&zero, padBytes); | 652 write(&zero, padBytes); |
| 653 } | 653 } |
| 654 | 654 |
| 655 SkData* SkDynamicMemoryWStream::copyToData() const { | 655 SkData* SkDynamicMemoryWStream::copyToData() const { |
| 656 if (NULL == fCopy) { | 656 if (NULL == fCopy) { |
| 657 void* buffer = sk_malloc_throw(fBytesWritten); | 657 SkData* data = SkData::NewUninitialized(fBytesWritten); |
| 658 this->copyTo(buffer); | 658 // be sure to call copyTo() before we assign to fCopy |
| 659 fCopy = SkData::NewFromMalloc(buffer, fBytesWritten); | 659 this->copyTo(data->writable_data()); |
| 660 fCopy = data; |
| 660 } | 661 } |
| 661 fCopy->ref(); | 662 return SkRef(fCopy); |
| 662 return fCopy; | |
| 663 } | 663 } |
| 664 | 664 |
| 665 void SkDynamicMemoryWStream::invalidateCopy() { | 665 void SkDynamicMemoryWStream::invalidateCopy() { |
| 666 if (fCopy) { | 666 if (fCopy) { |
| 667 fCopy->unref(); | 667 fCopy->unref(); |
| 668 fCopy = NULL; | 668 fCopy = NULL; |
| 669 } | 669 } |
| 670 } | 670 } |
| 671 | 671 |
| 672 class SkBlockMemoryRefCnt : public SkRefCnt { | 672 class SkBlockMemoryRefCnt : public SkRefCnt { |
| (...skipping 211 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 884 tempStream.copyTo(dst); | 884 tempStream.copyTo(dst); |
| 885 return length; | 885 return length; |
| 886 } | 886 } |
| 887 | 887 |
| 888 // Declared in SkStreamPriv.h: | 888 // Declared in SkStreamPriv.h: |
| 889 SkData* SkCopyStreamToData(SkStream* stream) { | 889 SkData* SkCopyStreamToData(SkStream* stream) { |
| 890 SkASSERT(stream != NULL); | 890 SkASSERT(stream != NULL); |
| 891 | 891 |
| 892 if (stream->hasLength()) { | 892 if (stream->hasLength()) { |
| 893 const size_t length = stream->getLength(); | 893 const size_t length = stream->getLength(); |
| 894 SkAutoMalloc dst(length); | 894 SkData* data = SkData::NewUninitialized(length); |
| 895 if (stream->read(dst.get(), length) != length) { | 895 if (stream->read(data->writable_data(), length) != length) { |
| 896 return NULL; | 896 data->unref(); |
| 897 data = NULL; |
| 897 } | 898 } |
| 898 return SkData::NewFromMalloc(dst.detach(), length); | 899 return data; |
| 899 } | 900 } |
| 900 | 901 |
| 901 SkDynamicMemoryWStream tempStream; | 902 SkDynamicMemoryWStream tempStream; |
| 902 const size_t bufferSize = 4096; | 903 const size_t bufferSize = 4096; |
| 903 char buffer[bufferSize]; | 904 char buffer[bufferSize]; |
| 904 do { | 905 do { |
| 905 size_t bytesRead = stream->read(buffer, bufferSize); | 906 size_t bytesRead = stream->read(buffer, bufferSize); |
| 906 tempStream.write(buffer, bytesRead); | 907 tempStream.write(buffer, bytesRead); |
| 907 } while (!stream->isAtEnd()); | 908 } while (!stream->isAtEnd()); |
| 908 return tempStream.copyToData(); | 909 return tempStream.copyToData(); |
| 909 } | 910 } |
| 910 | 911 |
| 911 SkStreamRewindable* SkStreamRewindableFromSkStream(SkStream* stream) { | 912 SkStreamRewindable* SkStreamRewindableFromSkStream(SkStream* stream) { |
| 912 if (!stream) { | 913 if (!stream) { |
| 913 return NULL; | 914 return NULL; |
| 914 } | 915 } |
| 915 SkAutoTUnref<SkStreamRewindable> dupStream(stream->duplicate()); | 916 SkAutoTUnref<SkStreamRewindable> dupStream(stream->duplicate()); |
| 916 if (dupStream) { | 917 if (dupStream) { |
| 917 return dupStream.detach(); | 918 return dupStream.detach(); |
| 918 } | 919 } |
| 919 stream->rewind(); | 920 stream->rewind(); |
| 920 if (stream->hasLength()) { | 921 if (stream->hasLength()) { |
| 921 size_t length = stream->getLength(); | 922 size_t length = stream->getLength(); |
| 922 if (stream->hasPosition()) { // If stream has length, but can't rewind. | 923 if (stream->hasPosition()) { // If stream has length, but can't rewind. |
| 923 length -= stream->getPosition(); | 924 length -= stream->getPosition(); |
| 924 } | 925 } |
| 925 SkAutoMalloc allocMemory(length); | 926 SkAutoTUnref<SkData> data(SkData::NewUninitialized(length)); |
| 926 SkDEBUGCODE(size_t read =) stream->read(allocMemory.get(), length); | 927 SkDEBUGCODE(size_t read =) stream->read(data->writable_data(), length); |
| 927 SkASSERT(length == read); | 928 SkASSERT(length == read); |
| 928 SkAutoTUnref<SkData> data( | |
| 929 SkData::NewFromMalloc(allocMemory.detach(), length)); | |
| 930 return SkNEW_ARGS(SkMemoryStream, (data.get())); | 929 return SkNEW_ARGS(SkMemoryStream, (data.get())); |
| 931 } | 930 } |
| 932 SkDynamicMemoryWStream tempStream; | 931 SkDynamicMemoryWStream tempStream; |
| 933 const size_t bufferSize = 4096; | 932 const size_t bufferSize = 4096; |
| 934 char buffer[bufferSize]; | 933 char buffer[bufferSize]; |
| 935 do { | 934 do { |
| 936 size_t bytesRead = stream->read(buffer, bufferSize); | 935 size_t bytesRead = stream->read(buffer, bufferSize); |
| 937 tempStream.write(buffer, bytesRead); | 936 tempStream.write(buffer, bytesRead); |
| 938 } while (!stream->isAtEnd()); | 937 } while (!stream->isAtEnd()); |
| 939 return tempStream.detachAsStream(); // returns a SkBlockMemoryStream, | 938 return tempStream.detachAsStream(); // returns a SkBlockMemoryStream, |
| 940 // cheaper than copying to SkData | 939 // cheaper than copying to SkData |
| 941 } | 940 } |
| OLD | NEW |