X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fcore%2Fbuffer.cpp;h=4a36937e7b745d1dd32f8c1e9ce19df0766037d7;hb=e98188ff6c9bba9761b71f2a69f3be7eb89ba3da;hp=240fcd72754b67babe7a28b9ee2fe42a80f1fe4b;hpb=4365124bd39bd6edbda6eaef64ec72a1a10565f8;p=libs%2Fgl.git diff --git a/source/core/buffer.cpp b/source/core/buffer.cpp index 240fcd72..4a36937e 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(); } @@ -45,5 +46,23 @@ void Buffer::require_size(size_t req_sz) const throw buffer_too_small(format("buffer has %d bytes; %d required", size, req_sz)); } +void *Buffer::map() +{ + if(!can_map() || mapped) + throw invalid_operation("Buffer::map"); + void *result = BufferBackend::map(); + mapped = true; + return result; +} + +bool Buffer::unmap() +{ + if(!can_map() || !mapped) + throw invalid_operation("Buffer::map"); + bool result = BufferBackend::unmap(); + mapped = false; + return result; +} + } // namespace GL } // namespace Msp