Basic tile map implemented.

main
Zed A. Shaw 1 month ago
parent 290affa49a
commit b66a3154c7
  1. 4
      .gdbinit
  2. 8
      config.cpp
  3. 10
      config.hpp
  4. 4
      map.cpp
  5. 8
      matrix.hpp
  6. 7
      meson.build
  7. 26
      tests/tilemap.cpp
  8. 47
      tilemap.cpp
  9. 33
      tilemap.hpp

@ -5,6 +5,6 @@ set logging overwrite on
set print pretty on
set pagination off
break abort
break _invalid_parameter_noinfo
break _invalid_parameter
#break _invalid_parameter_noinfo
#break _invalid_parameter
catch throw

@ -1,5 +1,7 @@
#include "config.hpp"
using nlohmann::json;
Config::Config(const std::string src_path) : $src_path(src_path) {
std::ifstream infile($src_path);
$config = json::parse(infile);
@ -9,6 +11,12 @@ json &Config::operator[](const std::string &key) {
return $config[key];
}
std::wstring Config::wstring(const std::string key) {
std::wstring_convert<std::codecvt_utf8_utf16<wchar_t>> $converter;
const std::string& str_val = $config[key];
return $converter.from_bytes(str_val);
}
std::wstring Config::wstring(const std::string main_key, const std::string sub_key) {
std::wstring_convert<std::codecvt_utf8_utf16<wchar_t>> $converter;
const std::string& str_val = $config[main_key][sub_key];

@ -3,19 +3,17 @@
#include <fstream>
#include <codecvt>
using namespace nlohmann;
struct Config {
json $config;
nlohmann::json $config;
std::string $src_path;
Config(const std::string src_path);
Config(json config, std::string src_path)
Config(nlohmann::json config, std::string src_path)
: $config(config), $src_path(src_path) {}
json &operator[](const std::string &key);
nlohmann::json &operator[](const std::string &key);
std::wstring wstring(const std::string main_key);
std::wstring wstring(const std::string main_key, const std::string sub_key);
};

@ -13,8 +13,8 @@ using namespace fmt;
Map::Map(size_t width, size_t height) :
$width(width),
$height(height),
$tiles(height, matrix::Row(width, INV_WALL)),
$walls(height, matrix::Row(width, INV_WALL)),
$tiles(height, matrix::Row(width, SPACE_VALUE)),
$walls(height, matrix::Row(width, SPACE_VALUE)),
$paths(width, height)
{}

@ -76,6 +76,14 @@ namespace matrix {
return res;
}
inline size_t width(Matrix &mat) {
return mat[0].size();
}
inline size_t height(Matrix &mat) {
return mat.size();
}
void dump(const std::string &msg, Matrix &map, int show_x=-1, int show_y=-1);
struct flood {

@ -22,6 +22,7 @@ dependencies = [
runtests = executable('runtests', [
'matrix.cpp',
'dbc.cpp',
'tilemap.cpp',
'map.cpp',
'rand.cpp',
'sound.cpp',
@ -37,6 +38,7 @@ runtests = executable('runtests', [
'systems.cpp',
'gui.cpp',
'worldbuilder.cpp',
'tests/tilemap.cpp',
'tests/matrix.cpp',
'tests/fsm.cpp',
'tests/dbc.cpp',
@ -58,10 +60,11 @@ runtests = executable('runtests', [
dependencies: dependencies)
roguish = executable('roguish', [
'matrix.cpp',
'dbc.cpp',
'main.cpp',
'matrix.cpp',
'tilemap.cpp',
'map.cpp',
'main.cpp',
'gui.cpp',
'rand.cpp',
'sound.cpp',

@ -0,0 +1,26 @@
#include <catch2/catch_test_macros.hpp>
#include <fmt/core.h>
#include "map.hpp"
#include "worldbuilder.hpp"
#include "tilemap.hpp"
#include "config.hpp"
#include "rand.hpp"
using namespace fmt;
using std::string;
TEST_CASE("tilemap can load tiles and make a map", "[tilemap]") {
size_t width = Random::uniform<size_t>(10, 25);
size_t height = Random::uniform<size_t>(10, 33);
Map map(width,height);
WorldBuilder builder(map);
builder.generate();
Config config("./assets/tiles.json");
TileMap tiles(config, width, height);
auto& walls = map.walls();
tiles.load(walls);
tiles.dump();
REQUIRE(tiles.INVARIANT());
}

@ -0,0 +1,47 @@
#include "tilemap.hpp"
#include "dbc.hpp"
#include "constants.hpp"
#include "render.hpp"
TileMap::TileMap(Config& config, size_t width, size_t height)
: $config(config),
$width(width),
$height(height),
$tile_ids(height, matrix::Row(width, SPACE_VALUE)),
$display(height, TileRow(width, ""))
{
}
void TileMap::dump(int show_x, int show_y) {
SFMLRender::init_terminal();
for(matrix::each_row it{$tile_ids}; it.next();) {
string cell = $display[it.y][it.x];
if(int(it.x) == show_x && int(it.y) == show_y) {
fmt::print("{}<", cell);
} else {
fmt::print("{} ", cell);
}
if(it.row) fmt::print("\n");
}
}
void TileMap::load(matrix::Matrix &walls) {
for(matrix::each_cell it{walls}; it.next();) {
string tile_name = walls[it.y][it.x] == SPACE_VALUE ? "FLOOR_TILE" : "WALL_TILE";
std::wstring tile = $config.wstring(tile_name);
std::string tile_s = $config[tile_name];
$tile_ids[it.y][it.x] = tile[0];
$display[it.y][it.x] = tile_s;
}
}
bool TileMap::INVARIANT() {
dbc::check(matrix::height($tile_ids) == $height, "$tile_ids has wrong height");
dbc::check(matrix::width($tile_ids) == $width, "$tile_ids has wrong width");
return true;
}

@ -0,0 +1,33 @@
#pragma once
#include <vector>
#include <utility>
#include <string>
#include <algorithm>
#include <fmt/core.h>
#include "point.hpp"
#include "matrix.hpp"
#include "config.hpp"
typedef std::vector<std::string> TileRow;
typedef std::vector<TileRow> TileDisplay;
class TileMap {
public:
Config &$config;
size_t $width;
size_t $height;
matrix::Matrix $tile_ids;
TileDisplay $display;
TileMap(Config &config, size_t width, size_t height);
// disable copying
TileMap(TileMap &map) = delete;
size_t width() { return $width; }
size_t height() { return $height; }
void load(matrix::Matrix &walls);
void dump(int show_x=-1, int show_y=-1);
bool INVARIANT();
};
Loading…
Cancel
Save