]> git.tdb.fi Git - libs/gl.git/blobdiff - source/uniformblock.cpp
Final touches of OS X support
[libs/gl.git] / source / uniformblock.cpp
index 350f57ab6d0f48acaad3bca42f961ac8bf634aee..6b9de26931995e46446ef52e4dd57c81a3381ca0 100644 (file)
@@ -22,6 +22,29 @@ UniformBlock::UniformBlock(unsigned s):
        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;
@@ -30,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;
@@ -39,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