X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fcore%2Fbuffer.h;h=9737a2ea9323ddd0af5c44b3d51d595eff6fc6d1;hb=160e9eea29bd10034733d59507fa1bcca36be401;hp=a80e52a68b9c34b00e499c6a16fb0b9e85446d39;hpb=9b3bce7ae76ff8c0c81315d2505ea96bf422a318;p=libs%2Fgl.git diff --git a/source/core/buffer.h b/source/core/buffer.h index a80e52a6..9737a2ea 100644 --- a/source/core/buffer.h +++ b/source/core/buffer.h @@ -3,13 +3,7 @@ #include #include -#include -#include -#include "gl.h" -#include -#include -#include -#include +#include "buffer_backend.h" namespace Msp { namespace GL { @@ -21,26 +15,6 @@ public: virtual ~buffer_too_small() throw() { } }; -enum BufferUsage -{ - STREAM_DRAW = GL_STREAM_DRAW, - STREAM_READ = GL_STREAM_READ, - STREAM_COPY = GL_STREAM_COPY, - STATIC_DRAW = GL_STATIC_DRAW, - STATIC_READ = GL_STATIC_READ, - STATIC_COPY = GL_STATIC_COPY, - DYNAMIC_DRAW = GL_DYNAMIC_DRAW, - DYNAMIC_READ = GL_DYNAMIC_READ, - DYNAMIC_COPY = GL_DYNAMIC_COPY -}; - -enum BufferAccess -{ - READ_ONLY = GL_READ_ONLY, - WRITE_ONLY = GL_WRITE_ONLY, - READ_WRITE = GL_READ_WRITE -}; - class BufferRange; /** @@ -48,41 +22,25 @@ A buffer for storing data in GL memory. Putting vertex and index data in buffers can improve rendering performance. The VertexArray, Mesh and UniformBlock classes contain built-in support for buffers. */ -class Buffer +class Buffer: public BufferBackend { - friend class BufferRange; + friend BufferBackend; private: - unsigned id; unsigned size; - bool allocated; public: Buffer(); - ~Buffer(); - - /** Returns the OpenGL ID of the buffer. For internal use only. */ - unsigned get_id() const { return id; } /** Defines the storage size of the buffer. Must be called before data can be uploaded. Storage cannot be changed once set. */ void storage(unsigned); - /** Allocates storage for the buffer. The contents are initially undefined. - If storage has already been allocated, does nothing. */ - void allocate(); - - /** Sets the usage hint of the buffer. It will take effect the next time - the buffer's contents are defined. */ - DEPRECATED void set_usage(BufferUsage); - /** Uploads data into the buffer, completely replacing any previous contents. Storage must be defined beforehand. The data must have size matching the defined storage. */ void data(const void *); - DEPRECATED void data(unsigned, const void *); - /** Overwrites part of the buffer data with new data. Storage must be defined beforehand. */ void sub_data(unsigned, unsigned, const void *); @@ -91,11 +49,10 @@ public: void require_size(unsigned) const; - void *map(); - DEPRECATED void *map(BufferAccess) { return map(); } - bool unmap(); + using BufferBackend::map; + using BufferBackend::unmap; - void set_debug_name(const std::string &); + using BufferBackend::set_debug_name; }; } // namespace GL