diff options
author | djsollen@google.com <djsollen@google.com@2bbb7eff-a529-9590-31e7-b0007b416f81> | 2012-08-07 15:54:32 +0000 |
---|---|---|
committer | djsollen@google.com <djsollen@google.com@2bbb7eff-a529-9590-31e7-b0007b416f81> | 2012-08-07 15:54:32 +0000 |
commit | c73dd5c6880739f26216f198c757028fd28df1a4 (patch) | |
tree | 17a4984fe2caecb5d36a27324eaa698550d4db04 /src/core/SkData.cpp | |
parent | 7b4531f64cbd85d32a77ceab1bdec8335c5a7864 (diff) |
Update SkFlattenable buffers to be more modular.
This CL is an effort to stage the conversion to named
parameters for all SkFlattenable commands. This particular
stage only does the following two things...
1. Move flattenable buffers from SkFlattenable.h into
their own header.
2. Update and Add new read write methods for better clarity
and convenience.
BUG=
Review URL: https://codereview.appspot.com/6448095
git-svn-id: http://skia.googlecode.com/svn/trunk@4980 2bbb7eff-a529-9590-31e7-b0007b416f81
Diffstat (limited to 'src/core/SkData.cpp')
-rw-r--r-- | src/core/SkData.cpp | 37 |
1 files changed, 16 insertions, 21 deletions
diff --git a/src/core/SkData.cpp b/src/core/SkData.cpp index 261b571436..5dbc206d8e 100644 --- a/src/core/SkData.cpp +++ b/src/core/SkData.cpp @@ -6,6 +6,7 @@ */ #include "SkData.h" +#include "SkFlattenableBuffers.h" SK_DEFINE_INST_COUNT(SkData) @@ -122,25 +123,22 @@ SkData* SkData::NewWithCString(const char cstr[]) { /////////////////////////////////////////////////////////////////////////////// void SkData::flatten(SkFlattenableWriteBuffer& buffer) const { - buffer.write32(fSize); - buffer.writePad(fPtr, fSize); + buffer.writeByteArray(fPtr, fSize); } SkData::SkData(SkFlattenableReadBuffer& buffer) { - fSize = buffer.readU32(); + fSize = buffer.getArrayCount(); fReleaseProcContext = NULL; - if (0 == fSize) { + if (fSize > 0) { + fPtr = sk_malloc_throw(fSize); + fReleaseProc = sk_free_releaseproc; + } else { fPtr = NULL; fReleaseProc = NULL; - } else { - // buffer.read expects a 4-byte aligned size - size_t size4 = SkAlign4(fSize); - void* data = sk_malloc_throw(size4); - buffer.read(data, size4); - fPtr = data; - fReleaseProc = sk_free_releaseproc; } + + buffer.readByteArray(const_cast<void*>(fPtr)); } SK_DEFINE_FLATTENABLE_REGISTRAR(SkData) @@ -247,11 +245,9 @@ void SkDataSet::writeToStream(SkWStream* stream) const { } void SkDataSet::flatten(SkFlattenableWriteBuffer& buffer) const { - buffer.write32(fCount); + buffer.writeInt(fCount); if (fCount > 0) { - buffer.write32(fKeySize); - // our first key points to all the key storage - buffer.writePad(fPairs[0].fKey, fKeySize); + buffer.writeByteArray(fPairs[0].fKey, fKeySize); for (int i = 0; i < fCount; ++i) { buffer.writeFlattenable(fPairs[i].fValue); } @@ -279,19 +275,18 @@ SkDataSet::SkDataSet(SkStream* stream) { } SkDataSet::SkDataSet(SkFlattenableReadBuffer& buffer) { - fCount = buffer.readU32(); + fCount = buffer.readInt(); if (fCount > 0) { - fKeySize = buffer.readU32(); - // we align fKeySize, since buffer.read needs to read a mul4 amount - fPairs = allocatePairStorage(fCount, SkAlign4(fKeySize)); + fKeySize = buffer.getArrayCount(); + fPairs = allocatePairStorage(fCount, fKeySize); char* keyStorage = (char*)(fPairs + fCount); - buffer.read(keyStorage, SkAlign4(fKeySize)); + buffer.readByteArray(keyStorage); for (int i = 0; i < fCount; ++i) { fPairs[i].fKey = keyStorage; keyStorage += strlen(keyStorage) + 1; - fPairs[i].fValue = (SkData*)buffer.readFlattenable(); + fPairs[i].fValue = buffer.readFlattenableT<SkData>(); } } else { fKeySize = 0; |