X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Fcore%2Fbuffer.cpp;h=b6f2e44b9e55555bebcfa08b80bf1ffeadb4a3c5;hp=557e576d2ac929e256646c0a3cdc59bd3887a962;hb=c356a20547afae97b412da36e0b0a7d51e879401;hpb=be6ffe96ecb4707599fe1a6f620c348760213d46 diff --git a/source/core/buffer.cpp b/source/core/buffer.cpp index 557e576d..b6f2e44b 100644 --- a/source/core/buffer.cpp +++ b/source/core/buffer.cpp @@ -8,7 +8,7 @@ using namespace std; namespace Msp { namespace GL { -void Buffer::storage(size_t sz) +void Buffer::storage(size_t sz, BufferUsage u) { if(size>0) { @@ -20,6 +20,7 @@ void Buffer::storage(size_t sz) throw invalid_argument("Buffer::storage"); size = sz; + usage = u; allocate(); } @@ -31,17 +32,72 @@ void Buffer::data(const void *d) void Buffer::sub_data(size_t off, size_t sz, const void *d) { - if(size==0) - throw invalid_operation("Buffer::sub_data"); - + check_sub_data(off, sz, "Buffer::sub_data"); BufferBackend::sub_data(off, sz, d); } +Buffer::AsyncTransfer Buffer::sub_data_async(size_t off, size_t sz) +{ + check_sub_data(off, sz, "Buffer::sub_data_async"); + return AsyncTransfer(*this, off, sz); +} + +void Buffer::check_sub_data(size_t off, size_t sz, const char *func) +{ + if(size==0) + throw invalid_operation(func); + if(off>get_total_size() || off%size+sz>size) + throw out_of_range(func); +} + void Buffer::require_size(size_t req_sz) const { if(size