/* libs/corecg/SkBuffer.cpp ** ** Copyright 2006, The Android Open Source Project ** ** Licensed under the Apache License, Version 2.0 (the "License"); ** you may not use this file except in compliance with the License. ** You may obtain a copy of the License at ** ** http://www.apache.org/licenses/LICENSE-2.0 ** ** Unless required by applicable law or agreed to in writing, software ** distributed under the License is distributed on an "AS IS" BASIS, ** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. ** See the License for the specific language governing permissions and ** limitations under the License. */ #include "SkBuffer.h" //////////////////////////////////////////////////////////////////////////////////////// void SkRBuffer::readNoSizeCheck(void* buffer, size_t size) { SkASSERT((fData != 0 && fStop == 0) || fPos + size <= fStop); if (buffer) memcpy(buffer, fPos, size); fPos += size; } const void* SkRBuffer::skip(size_t size) { const void* result = fPos; readNoSizeCheck(NULL, size); return result; } size_t SkRBuffer::skipToAlign4() { size_t pos = this->pos(); size_t n = SkAlign4(pos) - pos; fPos += n; return n; } void* SkWBuffer::skip(size_t size) { void* result = fPos; writeNoSizeCheck(NULL, size); return fData == NULL ? NULL : result; } void SkWBuffer::writeNoSizeCheck(const void* buffer, size_t size) { SkASSERT(fData == 0 || fStop == 0 || fPos + size <= fStop); if (fData && buffer) memcpy(fPos, buffer, size); fPos += size; } size_t SkWBuffer::padToAlign4() { size_t pos = this->pos(); size_t n = SkAlign4(pos) - pos; if (n && fData) { char* p = fPos; char* stop = p + n; do { *p++ = 0; } while (p < stop); } fPos += n; return n; } #if 0 #ifdef SK_DEBUG static void AssertBuffer32(const void* buffer) { SkASSERT(buffer); SkASSERT(((size_t)buffer & 3) == 0); } #else #define AssertBuffer32(buffer) #endif void* sk_buffer_write_int32(void* buffer, int32_t value) { AssertBuffer32(buffer); *(int32_t*)buffer = value; return (char*)buffer + sizeof(int32_t); } void* sk_buffer_write_int32(void* buffer, const int32_t values[], int count) { AssertBuffer32(buffer); SkASSERT(count >= 0); memcpy((int32_t*)buffer, values, count * sizeof(int32_t)); return (char*)buffer + count * sizeof(int32_t); } const void* sk_buffer_read_int32(const void* buffer, int32_t* value) { AssertBuffer32(buffer); if (value) *value = *(const int32_t*)buffer; return (const char*)buffer + sizeof(int32_t); } const void* sk_buffer_read_int32(const void* buffer, int32_t values[], int count) { AssertBuffer32(buffer); SkASSERT(count >= 0); if (values) memcpy(values, (const int32_t*)buffer, count * sizeof(int32_t)); return (const char*)buffer + count * sizeof(int32_t); } void* sk_buffer_write_ptr(void* buffer, void* ptr) { AssertBuffer32(buffer); *(void**)buffer = ptr; return (char*)buffer + sizeof(void*); } const void* sk_buffer_read_ptr(const void* buffer, void** ptr) { AssertBuffer32(buffer); if (ptr) *ptr = *(void**)buffer; return (const char*)buffer + sizeof(void*); } #endif