]> git.tdb.fi Git - libs/gl.git/blobdiff - source/renderbuffer.cpp
Complete rewrite of extension handling
[libs/gl.git] / source / renderbuffer.cpp
index 0f52ff595ec76bccee19f30c26e3f0e5f60ae7bb..c920633e0f2e0e84a009cab91477a1b0197a93c8 100644 (file)
@@ -1,11 +1,4 @@
-/* $Id$
-
-This file is part of libmspgl
-Copyright © 2007  Mikko Rasa, Mikkosoft Productions
-Distributed under the LGPL
-*/
-
-#include "extension.h"
+#include "ext_framebuffer_multisample.h"
 #include "ext_framebuffer_object.h"
 #include "renderbuffer.h"
 
@@ -14,26 +7,44 @@ namespace GL {
 
 Renderbuffer::Renderbuffer()
 {
-       static RequireExtension _ext("GL_EXT_framebuffer_object");
+       static Require _req(EXT_framebuffer_object);
 
-       glGenRenderbuffersEXT(1, &id);
-       bind();
+       glGenRenderbuffers(1, &id);
 }
 
 Renderbuffer::~Renderbuffer()
 {
-       glDeleteRenderbuffersEXT(1, &id);
+       glDeleteRenderbuffers(1, &id);
+}
+
+void Renderbuffer::storage(PixelFormat fmt, unsigned wd, unsigned ht)
+{
+       Bind _bind(this, true);
+       width = wd;
+       height = ht;
+       glRenderbufferStorage(GL_RENDERBUFFER, fmt, width, height);
+}
+
+void Renderbuffer::storage_multisample(unsigned samples, PixelFormat fmt, unsigned wd, unsigned ht)
+{
+       static Require _req(EXT_framebuffer_multisample);
+
+       Bind _bind(this, true);
+       width = wd;
+       height = ht;
+       glRenderbufferStorageMultisample(GL_RENDERBUFFER, samples, fmt, width, height);
 }
 
 void Renderbuffer::bind() const
 {
-       glBindRenderbufferEXT(GL_RENDERBUFFER_EXT, id);
+       if(set_current(this))
+               glBindRenderbuffer(GL_RENDERBUFFER, id);
 }
 
-void Renderbuffer::storage(PixelFormat fmt, sizei width, sizei height)
+void Renderbuffer::unbind()
 {
-       bind();
-       glRenderbufferStorageEXT(GL_RENDERBUFFER_EXT, fmt, width, height);
+       if(set_current(0))
+               glBindRenderbuffer(GL_RENDERBUFFER, 0);
 }
 
 } // namespace GL