]> git.tdb.fi Git - libs/gl.git/blobdiff - source/primitivebuilder.cpp
Share shader data between copied RenderPasses
[libs/gl.git] / source / primitivebuilder.cpp
index 046cc5b248c12874ab889c1c09358d9946795880..dd869908d9240df76b2f48a2308a0396613a35ad 100644 (file)
@@ -1,5 +1,8 @@
+#include "error.h"
 #include "primitivebuilder.h"
 
+using namespace std;
+
 namespace Msp {
 namespace GL {
 
@@ -13,7 +16,7 @@ PrimitiveBuilder::PrimitiveBuilder(VertexArray &a):
 void PrimitiveBuilder::begin(PrimitiveType t)
 {
        if(in_batch)
-               throw InvalidState("begin() already called");
+               throw invalid_operation("PrimitiveBuilder::begin");
 
        type = t;
        in_batch = true;
@@ -24,7 +27,7 @@ void PrimitiveBuilder::begin(PrimitiveType t)
 void PrimitiveBuilder::end()
 {
        if(!in_batch)
-               throw InvalidState("end() called without begin()");
+               throw invalid_operation("PrimitiveBuilder::end");
 
        in_batch = false;
 
@@ -34,23 +37,23 @@ void PrimitiveBuilder::end()
 void PrimitiveBuilder::offset(unsigned o)
 {
        if(o>array.size())
-               throw InvalidParameterValue("Element offset out of range");
+               throw out_of_range("PrimitiveBuilder::offset");
        offs = o;
 }
 
 void PrimitiveBuilder::element(unsigned i)
 {
        if(!in_batch)
-               throw InvalidState("Element specification not between begin() and end()");
+               throw invalid_operation("PrimitiveBuilder::element");
        if(offs+i>=array.size())
-               throw InvalidParameterValue("Element index out of range");
+               throw out_of_range("PrimitiveBuilder::element");
        element_(offs+i);
 }
 
 PrimitiveType PrimitiveBuilder::get_type() const
 {
        if(!in_batch)
-               throw InvalidState("Not between begin() and end()");
+               throw invalid_operation("PrimitiveBuilder::get_type");
        return type;
 }