parent
fb5bf9d733
commit
440be444ea
@ -0,0 +1,39 @@ |
||||
#include <map> |
||||
#include <string> |
||||
#include <fmt/core.h> |
||||
#include <fmt/color.h> |
||||
#include "game_engine.hpp" |
||||
|
||||
using namespace fmt; |
||||
using namespace std; |
||||
|
||||
const auto ERROR = fmt::emphasis::bold | fg(fmt::color::red); |
||||
|
||||
GameEngine::GameEngine(int hp) : hit_points(hp) {}; |
||||
|
||||
int GameEngine::determine_damage(string &type) { |
||||
try { |
||||
return damage_types.at(type); |
||||
} catch(std::out_of_range &err) { |
||||
print(ERROR, "BAD DAMAGE TYPE {}\n", type); |
||||
return 1000; |
||||
} |
||||
} |
||||
|
||||
bool GameEngine::hit(string &type) { |
||||
int damage = determine_damage(type); |
||||
hit_points -= damage; |
||||
|
||||
if(is_dead()) { |
||||
print(ERROR, "YOU DIED!\n"); |
||||
} else { |
||||
println("DAMAGE {}, HP: {}", damage, hit_points); |
||||
} |
||||
|
||||
// super dumb but I'll clean it up later
|
||||
return is_dead(); |
||||
} |
||||
|
||||
bool GameEngine::is_dead() { |
||||
return hit_points <= 0; |
||||
} |
@ -0,0 +1,22 @@ |
||||
#include <string> |
||||
#include <map> |
||||
|
||||
using namespace std; |
||||
|
||||
class GameEngine { |
||||
int hit_points = 0; |
||||
map<string, int> damage_types{ |
||||
{"error", 4}, |
||||
{"warning", 1}, |
||||
{"note", 1}, |
||||
}; |
||||
|
||||
public: |
||||
GameEngine(int hp); |
||||
|
||||
int determine_damage(string &type); |
||||
|
||||
bool hit(string &type); |
||||
|
||||
bool is_dead(); |
||||
}; |
@ -0,0 +1,10 @@ |
||||
#include <doctest.h> |
||||
#include "../game_engine.hpp" |
||||
|
||||
TEST_CASE("game engine can start and take hit") { |
||||
// test fails on purpose right now
|
||||
GameEngine game{100}; |
||||
string err{"error"}; |
||||
game.hit(err); |
||||
CHECK(game.is_dead() == true); |
||||
} |
Loading…
Reference in new issue