diff options
author | Andy <drumsetmonkey@gmail.com> | 2019-08-29 13:07:45 -0400 |
---|---|---|
committer | Andy <drumsetmonkey@gmail.com> | 2019-08-29 13:07:45 -0400 |
commit | 4ac4b280abf2ffa28caa5a532353115a3033444f (patch) | |
tree | 2a13d658bb454360b2faf401244bb0321d3460d4 /src/main.cpp | |
parent | e9758416b18b27a65337c28d9641afc0ee89b34b (diff) | |
parent | 7a46fa2dd3dad3f038bf8e7339bc67abca428ae6 (diff) |
Started creating scripting library/namespace and added sol2 for interfacing
Diffstat (limited to 'src/main.cpp')
-rw-r--r-- | src/main.cpp | 117 |
1 files changed, 10 insertions, 107 deletions
diff --git a/src/main.cpp b/src/main.cpp index 23cfe2d..386aafc 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -22,69 +22,11 @@ #include <entityx/entityx.h> #include <LuaBridge/LuaBridge.h> +#include "engine.hpp" + #include <SDL2/SDL.h> -#include <atomic> -#include <chrono> #include <iostream> -#include <memory> -#include <thread> - -#include <components/Position.hpp> -#include <script.hpp> - -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); -static void LuaTest(void); int main([[maybe_unused]] int argc, [[maybe_unused]] char *argv[]) { @@ -97,59 +39,19 @@ int main([[maybe_unused]] int argc, [[maybe_unused]] char *argv[]) atexit(SDL_Quit); } - LuaTest(); + //LuaTest(); - // 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); - } -} - -//struct Position : entityx::Component<Position> -//{ -// Position(float _x, float _y): x(_x), y(_y) {} -// Position(void){x = y = 0.0;} -// -// float x,y; -//}; - +/* using namespace entityx; namespace lb = luabridge; @@ -230,3 +132,4 @@ void LuaTest(void) //lua_close(L); } +*/ |