X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fapp%2Finit.hpp;h=122210d1e96bc426a33de8b8a6fb938eda02976e;hb=50f35affb16c78bd3d0b420f5ba37d74fcac391f;hp=cd0d9be481121ee80d55b87c9cdb9eada719cff3;hpb=282d731ea8f10342efa82012028de7043b3dd639;p=blank.git diff --git a/src/app/init.hpp b/src/app/init.hpp index cd0d9be..122210d 100644 --- a/src/app/init.hpp +++ b/src/app/init.hpp @@ -2,11 +2,20 @@ #define BLANK_APP_INIT_HPP_ #include +#include +#include namespace blank { -class GLContext; +class SDLError +: public std::runtime_error { + +public: + SDLError(); + explicit SDLError(const std::string &); + +}; class InitSDL { @@ -71,7 +80,7 @@ public: void GrabMouse(); void ReleaseMouse(); - GLContext CreateContext(); + SDL_Window *Handle() { return handle; } void Flip(); @@ -87,23 +96,11 @@ public: explicit GLContext(SDL_Window *); ~GLContext(); - GLContext(GLContext &&); - GLContext &operator =(GLContext &&); - GLContext(const GLContext &) = delete; GLContext &operator =(const GLContext &) = delete; - static void EnableVSync(); - static void EnableDepthTest() noexcept; - static void EnableBackfaceCulling() noexcept; - static void EnableAlphaBlending() noexcept; - static void DisableAlphaBlending() noexcept; - - static void Clear() noexcept; - static void ClearDepthBuffer() noexcept; - private: - SDL_GLContext handle; + SDL_GLContext ctx; }; @@ -118,6 +115,21 @@ public: }; + +struct Init { + + Init(bool double_buffer = true, int sample_size = 1); + + InitSDL init_sdl; + InitIMG init_img; + InitTTF init_ttf; + InitGL init_gl; + Window window; + GLContext ctx; + InitGLEW init_glew; + +}; + } #endif