diff options
author | LaG1924 <12997935+LaG1924@users.noreply.github.com> | 2017-07-29 16:55:16 +0200 |
---|---|---|
committer | LaG1924 <12997935+LaG1924@users.noreply.github.com> | 2017-07-29 16:55:16 +0200 |
commit | f942405184c2d6067fb5303b58a225edf7e452b1 (patch) | |
tree | 83e70c7e3019e5b195c9caf41194b2113fa76d7f /src/Core.cpp | |
parent | 2017-07-26 (diff) | |
download | AltCraft-f942405184c2d6067fb5303b58a225edf7e452b1.tar AltCraft-f942405184c2d6067fb5303b58a225edf7e452b1.tar.gz AltCraft-f942405184c2d6067fb5303b58a225edf7e452b1.tar.bz2 AltCraft-f942405184c2d6067fb5303b58a225edf7e452b1.tar.lz AltCraft-f942405184c2d6067fb5303b58a225edf7e452b1.tar.xz AltCraft-f942405184c2d6067fb5303b58a225edf7e452b1.tar.zst AltCraft-f942405184c2d6067fb5303b58a225edf7e452b1.zip |
Diffstat (limited to '')
-rw-r--r-- | src/Core.cpp | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/src/Core.cpp b/src/Core.cpp new file mode 100644 index 0000000..3a89c07 --- /dev/null +++ b/src/Core.cpp @@ -0,0 +1,59 @@ +#include "Core.hpp" +#include "NetworkClient.hpp" + +Core::Core() { + coreLoop = std::thread(&Core::ExecuteCoreLoop, this); + render = new Render(900, 480, "AltCraft"); +} + +Core::~Core() { + delete render; + coreLoop.join(); +} + +void Core::ExecuteRenderLoop() { + render->ExecuteRenderLoop(); +} + +void Core::ExecuteCoreLoop() { + + EventListener events; + events.RegisterHandler(EventType::ConnectionSuccessfull, [](EventData eventData) { + GlobalAppStateData data = {GlobalState::Loading}; + EventAgregator::PushEvent(EventType::GlobalAppState, EventData{data}); + }); + events.RegisterHandler(EventType::GlobalAppState, [this](EventData eventData) { + auto data = std::get<GlobalAppStateData>(eventData); + globalState = data.state; + }); + + while (globalState != GlobalState::Exiting) { + if (events.IsEventsQueueIsNotEmpty()) { + events.HandleEvent(); + } + } +} + +void Core::ExecuteNetworkLoop() { + NetworkClient *nc; + EventListener events; + bool isRunning = true; + events.RegisterHandler(EventType::ConnectToServer, [](EventData eventData) { + auto data = std::get<ConnectToServerData>(eventData); + try { + nc = new NetworkClient(data.address, data.port, "HelloOne", isRunning); + } catch (std::exception &e) { + GlobalAppStateData data{GlobalState::Exiting}; + EventAgregator::PushEvent(EventType::GlobalAppState, data); + } + }); + events.RegisterHandler(EventType::Disconnect, [nc](EventData eventData) { + delete nc; + nc = nullptr; + }); + + while (globalState != GlobalState::Exiting) { + + } + delete nc; +} |