X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Funiformblock.cpp;h=6b9de26931995e46446ef52e4dd57c81a3381ca0;hb=ccd59643144950604f95339683bac0ca4e8366d1;hp=2b9a135c0d8b61d9dd545c4aefeccd603f39fbf7;hpb=8eb9a8d90e5597154dab666481037b306b7bbca2;p=libs%2Fgl.git diff --git a/source/uniformblock.cpp b/source/uniformblock.cpp index 2b9a135c..6b9de269 100644 --- a/source/uniformblock.cpp +++ b/source/uniformblock.cpp @@ -12,14 +12,39 @@ using namespace std; namespace Msp { namespace GL { -UniformBlock::UniformBlock() +UniformBlock::UniformBlock(): + buf_range(0) { } UniformBlock::UniformBlock(unsigned s): size(s), - data(size) + data(size), + buf_range(0) { } +UniformBlock::~UniformBlock() +{ + delete buf_range; +} + +unsigned UniformBlock::get_alignment() const +{ + return BufferRange::get_uniform_buffer_alignment(); +} + +void UniformBlock::offset_changed() +{ + delete buf_range; + buf_range = 0; +} + +void UniformBlock::upload_data() const +{ + if(!buf_range) + buf_range = new BufferRange(*get_buffer(), get_offset(), size); + buf_range->data(&data[0]); +} + void UniformBlock::attach(int index, const Uniform &uni) { uniforms[index] = &uni; @@ -28,7 +53,7 @@ void UniformBlock::attach(int index, const Uniform &uni) void UniformBlock::attach(const Program::UniformInfo &info, const Uniform &uni) { uniforms[info.location] = &uni; - if(buffer) + if(get_buffer()) { uni.store(info, &data[info.location]); dirty = true; @@ -37,17 +62,13 @@ void UniformBlock::attach(const Program::UniformInfo &info, const Uniform &uni) void UniformBlock::apply(int index) const { - if((index>=0) != (buffer!=0)) + if((index>=0) != (get_buffer()!=0)) throw invalid_operation("UniformBlock::apply"); - if(buffer) + if(get_buffer()) { if(dirty) - { - update_buffer_data(); - if(!buf_range) - buf_range = new BufferRange(*buffer, buffer_offset, size); - } + update_buffer(); buf_range->bind_to(UNIFORM_BUFFER, index); } else