aboutsummaryrefslogtreecommitdiffstats
path: root/src/main.cpp
diff options
context:
space:
mode:
authorAndy <drumsetmonkey@gmail.com>2019-08-29 13:07:45 -0400
committerAndy <drumsetmonkey@gmail.com>2019-08-29 13:07:45 -0400
commit4ac4b280abf2ffa28caa5a532353115a3033444f (patch)
tree2a13d658bb454360b2faf401244bb0321d3460d4 /src/main.cpp
parente9758416b18b27a65337c28d9641afc0ee89b34b (diff)
parent7a46fa2dd3dad3f038bf8e7339bc67abca428ae6 (diff)
Started creating scripting library/namespace and added sol2 for interfacing
Diffstat (limited to 'src/main.cpp')
-rw-r--r--src/main.cpp117
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);
}
+*/