X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fapp%2Finit.hpp;h=122210d1e96bc426a33de8b8a6fb938eda02976e;hb=1bc6f085c53cdeaa08e2c00e821d4e2e25cae1c8;hp=98a30ed9bcc2986c7ced3a58332033aaf0c8e58f;hpb=b7d09e1e35ef90282c97509e0020b20db3c7ea9f;p=blank.git diff --git a/src/app/init.hpp b/src/app/init.hpp index 98a30ed..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 { @@ -33,6 +42,18 @@ public: }; +class InitTTF { + +public: + InitTTF(); + ~InitTTF(); + + InitTTF(const InitTTF &) = delete; + InitTTF &operator =(const InitTTF &) = delete; + +}; + + class InitGL { public: @@ -59,7 +80,7 @@ public: void GrabMouse(); void ReleaseMouse(); - GLContext CreateContext(); + SDL_Window *Handle() { return handle; } void Flip(); @@ -75,21 +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 Clear() noexcept; - static void ClearDepthBuffer() noexcept; - private: - SDL_GLContext handle; + SDL_GLContext ctx; }; @@ -104,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