X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Fcore%2Funiformblock.cpp;h=af4016ee5da8b32ad926689e0c211a3b0dbc4042;hp=59871cdde8249b3b90e0dd03a89db66963e2efd6;hb=9b3bce7ae76ff8c0c81315d2505ea96bf422a318;hpb=a482029babea3210840d8c62e9df9ece4342b2b9 diff --git a/source/core/uniformblock.cpp b/source/core/uniformblock.cpp index 59871cdd..af4016ee 100644 --- a/source/core/uniformblock.cpp +++ b/source/core/uniformblock.cpp @@ -38,11 +38,8 @@ void DefaultUniformBlock::attach(int index, const Uniform &uni) uniforms[index] = &uni; } -void DefaultUniformBlock::apply(int index) const +void DefaultUniformBlock::apply() const { - if(index>=0) - throw invalid_argument("DefaultUniformBlock::apply"); - for(unsigned i=0; iapply(i); @@ -51,8 +48,7 @@ void DefaultUniformBlock::apply(int index) const BufferBackedUniformBlock::BufferBackedUniformBlock(unsigned s): size(s), - data(size), - buf_range(0) + data(size) { static Require _req(ARB_shader_objects); static Require _req2(ARB_uniform_buffer_object); @@ -61,22 +57,11 @@ BufferBackedUniformBlock::BufferBackedUniformBlock(unsigned s): throw invalid_argument("BufferBackedUniformBlock::BufferBackedUniformBlock"); } -BufferBackedUniformBlock::~BufferBackedUniformBlock() -{ - delete buf_range; -} - unsigned BufferBackedUniformBlock::get_alignment() const { return Limits::get_global().uniform_buffer_alignment; } -void BufferBackedUniformBlock::location_changed(Buffer *buf, unsigned off, unsigned) const -{ - delete buf_range; - buf_range = buf->create_range(off, size); -} - void BufferBackedUniformBlock::attach(const Program::UniformInfo &info, const Uniform &uni) { if(info.block->bind_point<0) @@ -86,16 +71,5 @@ void BufferBackedUniformBlock::attach(const Program::UniformInfo &info, const Un dirty = true; } -void BufferBackedUniformBlock::apply(int index) const -{ - if(index<0) - throw invalid_argument("BufferBackedUniformBlock::apply"); - if(!get_buffer()) - throw invalid_operation("UniformBlock::apply"); - - refresh(); - buf_range->bind_to(UNIFORM_BUFFER, index); -} - } // namespace GL } // namespace Msp