X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fcore%2Fbuffer.cpp;h=d5fc29d11635830042b1b065905c818c1d3ac79d;hb=b294ef47df0ae87c42fe8114987817fb28326f10;hp=557e576d2ac929e256646c0a3cdc59bd3887a962;hpb=be6ffe96ecb4707599fe1a6f620c348760213d46;p=libs%2Fgl.git diff --git a/source/core/buffer.cpp b/source/core/buffer.cpp index 557e576d..d5fc29d1 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,87 @@ 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