Setup for the LevelManager to take charge of all level operations.

main
Zed A. Shaw 8 hours ago
parent 193f5f915e
commit 18a5f6bfa9
  1. 7
      gui.cpp
  2. 1
      gui.hpp
  3. 45
      levelmanager.cpp
  4. 23
      levelmanager.hpp
  5. 3
      map.hpp
  6. 3
      status.txt
  7. 28
      tests/levelmanager.cpp

@ -287,6 +287,9 @@ void GUI::handle_world_events() {
} break;
case eGUI::STAIRS_DOWN: {
auto& device = std::any_cast<Device&>(data);
next_level();
$status_ui.log(format("Up stairs has test {}.",
(bool)device.config["test"]));
toggle_modal(&$next_level_ui, $next_level);
@ -495,3 +498,7 @@ int GUI::main(bool run_once) {
return 0;
}
void GUI::next_level() {
}

@ -158,6 +158,7 @@ public:
void save_world();
void shake();
void shutdown();
void next_level();
int main(bool run_once=false);
void pause_screen();

@ -1,10 +1,49 @@
#include "levelmanager.hpp"
#include "worldbuilder.hpp"
#include "constants.hpp"
#include "save.hpp"
using lighting::LightRender;
using std::shared_ptr, std::make_shared;
LevelManager::LevelManager() {
// does nothing yet
}
size_t LevelManager::create_level() {
GameLevel level;
level.index = $levels.size();
level.world = make_shared<DinkyECS::World>();
save::load_configs(*level.world);
level.map = make_shared<Map>(GAME_MAP_X, GAME_MAP_Y);
WorldBuilder builder(*level.map);
builder.generate(*level.world);
level.lights = make_shared<LightRender>(level.map->width(), level.map->height());
$levels.push_back(level);
dbc::check(level.index == $levels.size() - 1, "Level index is not the same as $levels.size() - 1, off by one error");
return level.index;
}
GameLevel &LevelManager::next() {
dbc::check($current_level < $levels.size(), "attempt to get next level when at end");
$current_level++;
return $levels.at($current_level);
}
GameLevel &LevelManager::previous() {
dbc::check($current_level > 0, "attempt to go to previous level when at 0");
$current_level--;
return $levels.at($current_level);
}
GameLevel &LevelManager::current() {
return $levels.at($current_level);
}
void LevelManager::create_level() {
// does nothing yet
GameLevel &LevelManager::get(size_t index) {
return $levels.at(index);
}

@ -1,9 +1,30 @@
#pragma once
#include "dinkyecs.hpp"
#include "lights.hpp"
#include "map.hpp"
#include <vector>
#include <memory>
struct GameLevel {
size_t index = 0;
std::shared_ptr<Map> map = nullptr;
std::shared_ptr<DinkyECS::World> world = nullptr;
std::shared_ptr<lighting::LightRender> lights = nullptr;
};
class LevelManager {
public:
std::vector<GameLevel> $levels;
size_t $current_level = 0;
LevelManager();
void create_level();
size_t create_level();
GameLevel &next();
GameLevel &previous();
GameLevel &current();
size_t current_index();
GameLevel &get(size_t index);
};

@ -39,9 +39,6 @@ public:
Map(Matrix &walls, Pathing &paths);
// disable copying
Map(Map &map) = delete;
Matrix& paths() { return $paths.paths(); }
TileMap& tiles() { return $tiles; }
Matrix& input_map() { return $paths.input(); }

@ -1,5 +1,6 @@
TODAY'S GOAL:
TODO:
* What's the result of out of memory error with shared/unique ptr?
* Config is all over the place. Can I get rid of constant.hpp? Or most of it? Also renderer.cpp:RenderConfig is weird too. Too much indirection all around.
* GUI needs to become a statemachine now. Too many panels open at too many times.
* Panels should be able to take a width/height and center theirself for me

@ -10,9 +10,31 @@
#include "levelmanager.hpp"
using namespace fmt;
using namespace components;
using std::string;
TEST_CASE("", "[levelmanager]") {
// empty test to get setup
TEST_CASE("basic level manager test", "[levelmanager]") {
LevelManager lm;
size_t level1 = lm.create_level();
size_t level2 = lm.create_level();
auto& test1_level = lm.get(level1);
auto& test2_level = lm.get(level2);
REQUIRE(test1_level.map->width() > 0);
REQUIRE(test1_level.map->height() > 0);
REQUIRE(test1_level.index == 0);
REQUIRE(test2_level.map->width() > 0);
REQUIRE(test2_level.map->height() > 0);
REQUIRE(test2_level.index == 1);
auto& cur_level = lm.current();
REQUIRE(cur_level.index == 0);
auto& next_level = lm.next();
REQUIRE(next_level.index == 1);
auto& prev_level = lm.previous();
REQUIRE(prev_level.index == 0);
}

Loading…
Cancel
Save