]> git.tdb.fi Git - libs/gl.git/blobdiff - source/primitivebuilder.cpp
Style update: add spaces around assignment operators
[libs/gl.git] / source / primitivebuilder.cpp
index 92b2cb0eb0b76ef97c73875bd00f14651409c3b8..e032a441c00603062e750eb9367c2025c4023e1c 100644 (file)
@@ -12,6 +12,7 @@ namespace GL {
 
 PrimitiveBuilder::PrimitiveBuilder(VertexArray &a):
        array(a),
+       vab(array),
        in_batch(false)
 { }
 
@@ -20,9 +21,8 @@ void PrimitiveBuilder::begin(PrimitiveType t)
        if(in_batch)
                throw InvalidState("begin() already called");
 
-       type=t;
-       in_batch=true;
-       builder=array.modify();
+       type = t;
+       in_batch = true;
 
        begin_();
 }
@@ -32,8 +32,7 @@ void PrimitiveBuilder::end()
        if(!in_batch)
                throw InvalidState("end() called without begin()");
 
-       builder=0;
-       in_batch=false;
+       in_batch = false;
 
        end_();
 }
@@ -56,10 +55,12 @@ PrimitiveType PrimitiveBuilder::get_type() const
 
 void PrimitiveBuilder::vertex_(float x, float y, float z, float w)
 {
-       builder->texcoord(ts, tt, tr,tq);
-       builder->color(cr, cg, cb, ca);
-       builder->normal(nx, ny, nz);
-       builder->vertex(x, y, z, w);
+       vab.texcoord(ts, tt, tr, tq);
+       vab.color(cr, cg, cb, ca);
+       vab.normal(nx, ny, nz);
+       for(std::map<unsigned, Attrib>::iterator i=av.begin(); i!=av.end(); ++i)
+               vab.attrib(i->first, i->second.x, i->second.y, i->second.z, i->second.w);
+       vab.vertex(x, y, z, w);
 
        if(in_batch)
                element_(array.size()-1);