| 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 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 59 return this->readU16(); | 59 return this->readU16(); |
| 60 } else if (SK_BYTE_SENTINEL_FOR_U32 == byte) { | 60 } else if (SK_BYTE_SENTINEL_FOR_U32 == byte) { |
| 61 return this->readU32(); | 61 return this->readU32(); |
| 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 return size ? this->readIntoData(size) : SkData::NewEmpty(); |
| 70 return SkData::NewEmpty(); | 70 } |
| 71 } else { | 71 |
| 72 SkData* data = SkData::NewUninitialized(size); | 72 SkData* SkStream::readIntoData(size_t size) { |
| 73 this->read(data->writable_data(), size); | 73 SkAutoDataUnref data(SkData::NewUninitialized(size)); |
| 74 return data; | 74 if (this->read(data->writable_data(), size) != size) { |
| 75 return NULL; |
| 75 } | 76 } |
| 77 return data.detach(); |
| 76 } | 78 } |
| 77 | 79 |
| 78 ////////////////////////////////////////////////////////////////////////////////
////// | 80 ////////////////////////////////////////////////////////////////////////////////
////// |
| 79 | 81 |
| 80 SkWStream::~SkWStream() | 82 SkWStream::~SkWStream() |
| 81 { | 83 { |
| 82 } | 84 } |
| 83 | 85 |
| 84 void SkWStream::newline() | 86 void SkWStream::newline() |
| 85 { | 87 { |
| (...skipping 797 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 883 void* dst = storage->reset(length); | 885 void* dst = storage->reset(length); |
| 884 tempStream.copyTo(dst); | 886 tempStream.copyTo(dst); |
| 885 return length; | 887 return length; |
| 886 } | 888 } |
| 887 | 889 |
| 888 // Declared in SkStreamPriv.h: | 890 // Declared in SkStreamPriv.h: |
| 889 SkData* SkCopyStreamToData(SkStream* stream) { | 891 SkData* SkCopyStreamToData(SkStream* stream) { |
| 890 SkASSERT(stream != NULL); | 892 SkASSERT(stream != NULL); |
| 891 | 893 |
| 892 if (stream->hasLength()) { | 894 if (stream->hasLength()) { |
| 893 const size_t length = stream->getLength(); | 895 return stream->readIntoData(stream->getLength()); |
| 894 SkData* data = SkData::NewUninitialized(length); | |
| 895 if (stream->read(data->writable_data(), length) != length) { | |
| 896 data->unref(); | |
| 897 data = NULL; | |
| 898 } | |
| 899 return data; | |
| 900 } | 896 } |
| 901 | 897 |
| 902 SkDynamicMemoryWStream tempStream; | 898 SkDynamicMemoryWStream tempStream; |
| 903 const size_t bufferSize = 4096; | 899 const size_t bufferSize = 4096; |
| 904 char buffer[bufferSize]; | 900 char buffer[bufferSize]; |
| 905 do { | 901 do { |
| 906 size_t bytesRead = stream->read(buffer, bufferSize); | 902 size_t bytesRead = stream->read(buffer, bufferSize); |
| 907 tempStream.write(buffer, bytesRead); | 903 tempStream.write(buffer, bytesRead); |
| 908 } while (!stream->isAtEnd()); | 904 } while (!stream->isAtEnd()); |
| 909 return tempStream.copyToData(); | 905 return tempStream.copyToData(); |
| 910 } | 906 } |
| 911 | 907 |
| 912 SkStreamRewindable* SkStreamRewindableFromSkStream(SkStream* stream) { | 908 SkStreamRewindable* SkStreamRewindableFromSkStream(SkStream* stream) { |
| 913 if (!stream) { | 909 if (!stream) { |
| 914 return NULL; | 910 return NULL; |
| 915 } | 911 } |
| 916 SkAutoTUnref<SkStreamRewindable> dupStream(stream->duplicate()); | 912 SkAutoTUnref<SkStreamRewindable> dupStream(stream->duplicate()); |
| 917 if (dupStream) { | 913 if (dupStream) { |
| 918 return dupStream.detach(); | 914 return dupStream.detach(); |
| 919 } | 915 } |
| 920 stream->rewind(); | 916 stream->rewind(); |
| 921 if (stream->hasLength()) { | 917 if (stream->hasLength()) { |
| 922 size_t length = stream->getLength(); | 918 size_t length = stream->getLength(); |
| 923 if (stream->hasPosition()) { // If stream has length, but can't rewind. | 919 if (stream->hasPosition()) { // If stream has length, but can't rewind. |
| 924 length -= stream->getPosition(); | 920 length -= stream->getPosition(); |
| 925 } | 921 } |
| 926 SkAutoTUnref<SkData> data(SkData::NewUninitialized(length)); | 922 SkAutoTUnref<SkData> data(stream->readIntoData(length)); |
| 927 SkDEBUGCODE(size_t read =) stream->read(data->writable_data(), length); | |
| 928 SkASSERT(length == read); | |
| 929 return SkNEW_ARGS(SkMemoryStream, (data.get())); | 923 return SkNEW_ARGS(SkMemoryStream, (data.get())); |
| 930 } | 924 } |
| 931 SkDynamicMemoryWStream tempStream; | 925 SkDynamicMemoryWStream tempStream; |
| 932 const size_t bufferSize = 4096; | 926 const size_t bufferSize = 4096; |
| 933 char buffer[bufferSize]; | 927 char buffer[bufferSize]; |
| 934 do { | 928 do { |
| 935 size_t bytesRead = stream->read(buffer, bufferSize); | 929 size_t bytesRead = stream->read(buffer, bufferSize); |
| 936 tempStream.write(buffer, bytesRead); | 930 tempStream.write(buffer, bytesRead); |
| 937 } while (!stream->isAtEnd()); | 931 } while (!stream->isAtEnd()); |
| 938 return tempStream.detachAsStream(); // returns a SkBlockMemoryStream, | 932 return tempStream.detachAsStream(); // returns a SkBlockMemoryStream, |
| 939 // cheaper than copying to SkData | 933 // cheaper than copying to SkData |
| 940 } | 934 } |
| OLD | NEW |