X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fcore%2Fbuffer.cpp;h=00fd9cd3d42ac0597c255413b983f8d704b73bb4;hb=a77629d781eeb789870470c5ebdbd4b691e1b138;hp=56810b6f4ff12aa41f9c37b7812f5d4496187e7a;hpb=a061bbfa87391ddea42c6220c1e17054d5b6b0c8;p=libs%2Fgl.git diff --git a/source/core/buffer.cpp b/source/core/buffer.cpp index 56810b6f..00fd9cd3 100644 --- a/source/core/buffer.cpp +++ b/source/core/buffer.cpp @@ -2,6 +2,7 @@ #include #include #include +#include #include #include "buffer.h" #include "error.h" @@ -49,7 +50,11 @@ void Buffer::require_buffer_type(BufferType type) void Buffer::storage(unsigned sz) { if(size>0) - throw invalid_operation("Buffer::storage"); + { + if(sz!=size) + throw incompatible_data("Buffer::storage"); + return; + } if(sz==0) throw invalid_argument("Buffer::storage"); @@ -142,6 +147,7 @@ BufferRange *Buffer::create_range(unsigned s, unsigned o) void *Buffer::map() { + allocate(); if(ARB_map_buffer_range) { if(ARB_direct_state_access) @@ -232,6 +238,16 @@ bool Buffer::set_current(BufferType type, const Buffer *buf) return true; } +void Buffer::set_debug_name(const string &name) +{ +#ifdef DEBUG + if(KHR_debug) + glObjectLabel(GL_BUFFER, id, name.size(), name.c_str()); +#else + (void)name; +#endif +} + vector BufferRange::bound_uniform;