X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;ds=sidebyside;f=source%2Fcore%2Fvertexarray.cpp;h=2bb6a6677b9ef5e2099a1a5922b1d2990910708c;hb=d40673bd28c4b4524d3642b949d9d109dc6f9f24;hp=da868c7963f83a81efed4b08bdb10cb118cf7c80;hpb=70d9d2d28e5fe723c6b46894276e4c935f578e2d;p=libs%2Fgl.git diff --git a/source/core/vertexarray.cpp b/source/core/vertexarray.cpp index da868c79..2bb6a667 100644 --- a/source/core/vertexarray.cpp +++ b/source/core/vertexarray.cpp @@ -11,14 +11,19 @@ using namespace std; namespace Msp { namespace GL { +VertexArray::VertexArray(): + stride(0) +{ } + VertexArray::VertexArray(const VertexFormat &f) { - reset(f); + set_format(f); } -void VertexArray::reset(const VertexFormat &f) +void VertexArray::set_format(const VertexFormat &f) { - clear(); + if(!format.empty()) + throw invalid_operation("VertexArray::set_format"); format = f; stride = format.stride(); } @@ -30,11 +35,15 @@ void VertexArray::clear() void VertexArray::reserve(unsigned n) { + if(format.empty()) + throw invalid_operation("VertexArray::reserve"); data.reserve(n*stride); } float *VertexArray::append() { + if(format.empty()) + throw invalid_operation("VertexArray::append"); data.insert(data.end(), stride, 0.0f); update_offset(); dirty = true; @@ -43,6 +52,8 @@ float *VertexArray::append() float *VertexArray::modify(unsigned i) { + if(format.empty()) + throw invalid_operation("VertexArray::modify"); dirty = true; return &data[0]+i*stride; } @@ -74,8 +85,6 @@ VertexArray::Loader::Loader(VertexArray &a): add("generic", static_cast(&Loader::generic)); add("generic", static_cast(&Loader::generic)); add("generic", static_cast(&Loader::generic)); - add("tangent", static_cast(&Loader::tangent)); - add("binormal", static_cast(&Loader::binormal)); add("group", static_cast(&Loader::group)); add("group", static_cast(&Loader::group)); add("group", static_cast(&Loader::group)); @@ -104,8 +113,13 @@ VertexArray::Loader::Loader(VertexArray &a): add("generic2", static_cast(&Loader::generic)); add("generic3", static_cast(&Loader::generic)); add("generic4", static_cast(&Loader::generic)); +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wdeprecated-declarations" add("tangent3", static_cast(&Loader::tangent)); add("binormal3", static_cast(&Loader::binormal)); + add("tangent", static_cast(&Loader::tangent)); + add("binormal", static_cast(&Loader::binormal)); +#pragma GCC diagnostic pop } } // namespace GL