/* 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