]> git.tdb.fi Git - libs/gl.git/blobdiff - source/vertexarraybuilder.cpp
Allow generic vertex attribute 0, since OpenGL 3.0 does not support any fixed-functio...
[libs/gl.git] / source / vertexarraybuilder.cpp
index c64c8ebfc882fca127b9771b2d1818af9ddeabaa..09b0a1f2a85655e21e3f87b15525a7f8ac87d756 100644 (file)
@@ -1,7 +1,7 @@
 /* $Id$
 
 This file is part of libmspgl
-Copyright © 2007  Mikko Rasa, Mikkosoft Productions
+Copyright © 2007-2009  Mikko Rasa, Mikkosoft Productions
 Distributed under the LGPL
 */
 
@@ -23,10 +23,11 @@ VertexArrayBuilder::~VertexArrayBuilder()
 void VertexArrayBuilder::vertex_(float x, float y, float z, float w)
 {
        float *ptr=array.append();
-       for(uint fmt=array.get_format(); fmt; fmt>>=4)
+       for(const unsigned char *c=array.get_format().begin(); c!=array.get_format().end(); ++c)
        {
-               uint size=(fmt&3)+1;
-               switch(fmt&12)
+               uint size=(*c&3)+1;
+               uint type=*c>>2;
+               switch(type)
                {
                case 0:
                        *ptr++=x;
@@ -34,35 +35,42 @@ void VertexArrayBuilder::vertex_(float x, float y, float z, float w)
                        if(size>=3) *ptr++=z;
                        if(size>=4) *ptr++=w;
                        break;
-               case 4:
-                       *+ptr++=nx;
-                       *+ptr++=ny;
-                       *+ptr++=nz;
+               case 1:
+                       *ptr++=nx;
+                       *ptr++=ny;
+                       *ptr++=nz;
                        break;
-               case 8:
-                       *+ptr++=ts;
-                       if(size>=2) *+ptr++=tt;
-                       if(size>=3) *+ptr++=tr;
-                       if(size>=4) *+ptr++=tq;
+               case 2:
+                       *ptr++=ts;
+                       if(size>=2) *ptr++=tt;
+                       if(size>=3) *ptr++=tr;
+                       if(size>=4) *ptr++=tq;
                        break;
-               case 12:
+               case 3:
                        if(size==1)
                        {
                                union { ubyte c[4]; float f; } u;
-                               u.c[0]=(ubyte)(cr*255);
-                               u.c[1]=(ubyte)(cg*255);
-                               u.c[2]=(ubyte)(cb*255);
-                               u.c[3]=(ubyte)(ca*255);
-                               *+ptr++=u.f;
+                               u.c[0]=static_cast<ubyte>(cr*255);
+                               u.c[1]=static_cast<ubyte>(cg*255);
+                               u.c[2]=static_cast<ubyte>(cb*255);
+                               u.c[3]=static_cast<ubyte>(ca*255);
+                               *ptr++=u.f;
                        }
                        else
                        {
-                               *+ptr++=cr;
-                               *+ptr++=cg;
-                               *+ptr++=cb;
+                               *ptr++=cr;
+                               *ptr++=cg;
+                               *ptr++=cb;
                                if(size>=4) *+ptr++=ca;
                        }
                        break;
+               default:
+                       const Attrib &a=av[type-4];
+                       *ptr++=a.x;
+                       if(size>=2) *ptr++=a.y;
+                       if(size>=3) *ptr++=a.z;
+                       if(size>=4) *ptr++=a.w;
+                       break;
                }
        }
 }