diff options
author | Aki <please@ignore.pl> | 2023-01-12 23:11:18 +0100 |
---|---|---|
committer | Aki <please@ignore.pl> | 2023-01-12 23:11:18 +0100 |
commit | c583337927c3dff61d7a3cf19aa4fda96c4d0e96 (patch) | |
tree | 41b4697fd830b6ca0655e62c932c1ee61c5a214e /universe | |
parent | e9187a92220a62337d83a18aa973a8e86d3014a4 (diff) | |
download | kurator-c583337927c3dff61d7a3cf19aa4fda96c4d0e96.zip kurator-c583337927c3dff61d7a3cf19aa4fda96c4d0e96.tar.gz kurator-c583337927c3dff61d7a3cf19aa4fda96c4d0e96.tar.bz2 |
Added method to retrieve default/first item from repository
Diffstat (limited to 'universe')
-rw-r--r-- | universe/include/kurator/universe/Repository.h | 2 | ||||
-rw-r--r-- | universe/src/JsonRepository.cpp | 20 | ||||
-rw-r--r-- | universe/src/JsonRepository.h | 2 |
3 files changed, 24 insertions, 0 deletions
diff --git a/universe/include/kurator/universe/Repository.h b/universe/include/kurator/universe/Repository.h index 3758421..e3f97a2 100644 --- a/universe/include/kurator/universe/Repository.h +++ b/universe/include/kurator/universe/Repository.h @@ -17,7 +17,9 @@ class Repository { public: virtual ~Repository() = default; + virtual ShipType ship_type() const = 0; virtual ShipType ship_type(const std::string& id) const = 0; + virtual TurretType turret_type() const = 0; virtual TurretType turret_type(const std::string& id) const = 0; virtual void for_ship_types(std::function<void(const ShipType&)> func) const = 0; virtual void for_turret_types(std::function<void(const TurretType&)> func) const = 0; diff --git a/universe/src/JsonRepository.cpp b/universe/src/JsonRepository.cpp index e8c8ed3..0100eb6 100644 --- a/universe/src/JsonRepository.cpp +++ b/universe/src/JsonRepository.cpp @@ -82,6 +82,16 @@ JsonRepository::JsonRepository(const std::string& path) ShipType +JsonRepository::ship_type() const +{ + const auto it = ships.begin(); + if (it == ships.end()) + throw NotFound("any/default"); + return it->second; +} + + +ShipType JsonRepository::ship_type(const std::string& id) const try { return ships.at(id); @@ -92,6 +102,16 @@ catch (const std::out_of_range&) { TurretType +JsonRepository::turret_type() const +{ + const auto it = turrets.begin(); + if (it == turrets.end()) + throw NotFound("any/default"); + return it->second; +} + + +TurretType JsonRepository::turret_type(const std::string& id) const try { return turrets.at(id); diff --git a/universe/src/JsonRepository.h b/universe/src/JsonRepository.h index ea6bf46..13df7e4 100644 --- a/universe/src/JsonRepository.h +++ b/universe/src/JsonRepository.h @@ -19,7 +19,9 @@ class JsonRepository : public Repository { public: explicit JsonRepository(const std::string& path); + ShipType ship_type() const override; ShipType ship_type(const std::string& id) const override; + TurretType turret_type() const override; TurretType turret_type(const std::string& id) const override; void for_ship_types(std::function<void(const ShipType&)> func) const; void for_turret_types(std::function<void(const TurretType&)> func) const; |