X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fcore%2Funiformblock.cpp;h=b06ddf926a0f3a34159ed9a2b7921a1ad708d018;hb=009918e76dda88b0cb68fdaa20c63d6e952af260;hp=f713bd2af5d320541b27f114b9a4cad719528231;hpb=8366f8951984aa436938b1bb18a57067ff2260c1;p=libs%2Fgl.git diff --git a/source/core/uniformblock.cpp b/source/core/uniformblock.cpp index f713bd2a..b06ddf92 100644 --- a/source/core/uniformblock.cpp +++ b/source/core/uniformblock.cpp @@ -1,13 +1,10 @@ +#include #include #include -#include "buffer.h" -#include "color.h" #include "deviceinfo.h" -#include "error.h" -#include "matrix.h" -#include "uniform.h" #include "uniformblock.h" -#include "vector.h" + +using namespace std; namespace Msp { namespace GL { @@ -22,19 +19,67 @@ UniformBlock::UniformBlock(const ReflectData::UniformBlockInfo &info): unsigned UniformBlock::get_alignment() const { - return Limits::get_global().uniform_buffer_alignment; + return DeviceInfo::get_global().limits.uniform_buffer_alignment; } -void UniformBlock::store(const ReflectData::UniformInfo &info, const Uniform &uni) +void UniformBlock::store(const ReflectData::UniformInfo &info, unsigned array_size, const void *value) { + array_size = min(array_size, max(info.array_size, 1U)); + + char *store_ptr; + bool packed; if(info.block->bind_point<0) { if(info.location<0) return; - uni.store(info, &data[info.location*16]); + + store_ptr = data.data()+info.location*16; + packed = true; + } + else + { + store_ptr = data.data()+info.offset; + if(array_size!=1 && info.array_stride!=get_type_size(info.type)) + packed = false; + else if(is_matrix(info.type)) + packed = (info.matrix_stride==get_type_size(get_matrix_column_type(info.type))); + else + packed = true; + } + + const char *value_ptr = static_cast(value); + if(packed) + { + const char *data_end = value_ptr+array_size*get_type_size(info.type); + copy(value_ptr, data_end, store_ptr); + } + else if(is_matrix(info.type)) + { + unsigned col_size = get_type_size(get_matrix_column_type(info.type)); + unsigned cols = get_type_size(info.type)/col_size; + for(unsigned i=0; i