#define _GLWS_HPP_
+#include <vector>
+
+
namespace glws {
+enum Profile {
+ PROFILE_COMPAT,
+ PROFILE_ES1,
+ PROFILE_ES2,
+};
+
+
+extern bool debug;
+
+
+bool
+checkExtension(const char *extName, const char *extString);
+
+
+template< class T >
+class Attributes {
+protected:
+ std::vector<T> attribs;
+
+public:
+ void add(T param) {
+ attribs.push_back(param);
+ }
+
+ void add(T pname, T pvalue) {
+ add(pname);
+ add(pvalue);
+ }
+
+ void end(T terminator = 0) {
+ add(terminator);
+ }
+
+ operator T * (void) {
+ return &attribs[0];
+ }
+
+ operator const T * (void) const {
+ return &attribs[0];
+ }
+};
+
+
class Visual
{
public:
const Visual *visual;
int width;
int height;
+ bool visible;
Drawable(const Visual *vis, int w, int h) :
visual(vis),
width(w),
- height(h)
+ height(h),
+ visible(false)
{}
virtual ~Drawable() {}
height = h;
}
+ virtual void
+ show(void) {
+ visible = true;
+ }
+
virtual void swapBuffers(void) = 0;
};
};
-class WindowSystem
-{
-public:
- virtual ~WindowSystem() {}
+void
+init(void);
- virtual Visual *
- createVisual(bool doubleBuffer = false) = 0;
-
- virtual Drawable *
- createDrawable(const Visual *visual, int width = 256, int height = 256) = 0;
+void
+cleanup(void);
- virtual Context *
- createContext(const Visual *visual) = 0;
-
- virtual bool
- makeCurrent(Drawable *drawable, Context *context) = 0;
+Visual *
+createVisual(bool doubleBuffer = false);
- virtual bool
- processEvents(void) = 0;
-};
+Drawable *
+createDrawable(const Visual *visual, int width = 32, int height = 32);
+
+Context *
+createContext(const Visual *visual, Context *shareContext = 0, Profile profile = PROFILE_COMPAT);
+bool
+makeCurrent(Drawable *drawable, Context *context);
-WindowSystem *createNativeWindowSystem(void);
+bool
+processEvents(void);
} /* namespace glws */