+#include <stdexcept>
#include "arb_vertex_buffer_object.h"
#include "extension.h"
#include "buffer.h"
+using namespace std;
+
namespace Msp {
namespace GL {
+const Buffer *Buffer::bound[4] = { 0, 0, 0, 0 };
+
Buffer::Buffer(BufferType t):
type(t),
- usage(STATIC_DRAW)
+ usage(STATIC_DRAW),
+ size(0)
{
static RequireExtension _req_vbo("GL_ARB_vertex_buffer_object");
if(type==PIXEL_PACK_BUFFER || type==PIXEL_UNPACK_BUFFER)
usage = u;
}
-void Buffer::data(unsigned size, const void *d)
+void Buffer::data(unsigned sz, const void *d)
{
const Buffer *old = current(type);
bind();
- glBufferDataARB(type, size, d, usage);
+ glBufferDataARB(type, sz, d, usage);
+ size = sz;
restore(old, type);
}
-void Buffer::sub_data(unsigned offset, unsigned size, const void *d)
+void Buffer::sub_data(unsigned off, unsigned sz, const void *d)
{
const Buffer *old = current(type);
bind();
- glBufferSubDataARB(type, offset, size, d);
+ glBufferSubDataARB(type, off, sz, d);
restore(old, type);
}
case ELEMENT_ARRAY_BUFFER: return bound[1];
case PIXEL_PACK_BUFFER: return bound[2];
case PIXEL_UNPACK_BUFFER: return bound[3];
- default: throw InvalidParameterValue("Invalid buffer type");
+ default: throw invalid_argument("Buffer::binding");
}
}
}
}
-const Buffer *Buffer::bound[4] = { 0, 0, 0, 0 };
-
} // namespace GL
} // namespace Msp