diff options
Diffstat (limited to 'src/main.cpp')
-rw-r--r-- | src/main.cpp | 101 |
1 files changed, 6 insertions, 95 deletions
diff --git a/src/main.cpp b/src/main.cpp index 5e5e278..a1c605e 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -18,67 +18,11 @@ * along with this program. If not, see <https://www.gnu.org/licenses/>. */ -#include <entityx/entityx.h> +#include "engine.hpp" #include <SDL2/SDL.h> -#include <atomic> -#include <chrono> #include <iostream> -#include <memory> -#include <thread> - -class Window { -private: - constexpr static const char *title = "gamedev2"; - constexpr static int width = 640; - constexpr static int height = 480; - - static std::unique_ptr<SDL_Window, void (*)(SDL_Window *)> window; - static SDL_GLContext context; - - static void destroyWindow(SDL_Window *w) { - SDL_GL_DeleteContext(context); - SDL_DestroyWindow(w); - } - -public: - static int init(void) { - if (SDL_InitSubSystem(SDL_INIT_VIDEO) != 0) { - std::cerr << "SDL video failed to initialize: " - << SDL_GetError() << std::endl; - return -1; - } - - window.reset(SDL_CreateWindow(title, - SDL_WINDOWPOS_UNDEFINED, SDL_WINDOWPOS_UNDEFINED, - width, height, - SDL_WINDOW_OPENGL)); - - if (window.get() == nullptr) { - std::cerr << "SDL window creation failed: " - << SDL_GetError() << std::endl; - return -1; - } - - context = SDL_GL_CreateContext(window.get()); - - return 0; - } - - static void render(void) { - SDL_GL_SwapWindow(window.get()); - } -}; - -std::unique_ptr<SDL_Window, void (*)(SDL_Window *)> Window::window (nullptr, - Window::destroyWindow); -SDL_GLContext Window::context; - -std::atomic_bool shouldRun; - -static void renderLoop(void); -static void logicLoop(void); int main([[maybe_unused]] int argc, [[maybe_unused]] char *argv[]) { @@ -91,46 +35,13 @@ int main([[maybe_unused]] int argc, [[maybe_unused]] char *argv[]) atexit(SDL_Quit); } - // Create our window - Window::init(); + // Create the engine + Engine engine; + engine.init(); - // Start game - shouldRun.store(true); - std::thread logic (logicLoop); - renderLoop(); - logic.join(); + // Go go go! + engine.run(); return 0; } -void renderLoop(void) -{ - while (shouldRun.load()) { - Window::render(); - std::this_thread::yield(); - } -} - -void logicLoop(void) -{ - using namespace std::chrono_literals; - - std::cout << "Press escape to exit." << std::endl; - - while (shouldRun.load()) { - for (SDL_Event event; SDL_PollEvent(&event);) { - switch (event.type) { - case SDL_KEYUP: - // Exit game on escape - if (event.key.keysym.sym == SDLK_ESCAPE) - shouldRun.store(false); - break; - default: - break; - } - } - - std::this_thread::sleep_for(100ms); - } -} - |