X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fworld%2FBlockTypeRegistry.hpp;h=23b183a1b1cf765a390d920bc9b41278f7500fd5;hb=b94a7dc7daad9ae9be90a39d723e332dae375325;hp=6612d1516e72c893298f21ed193830a15fdd5671;hpb=ed3bdc028edc0ecb5835d1c0bf18dbc59b342daf;p=blank.git diff --git a/src/world/BlockTypeRegistry.hpp b/src/world/BlockTypeRegistry.hpp index 6612d15..23b183a 100644 --- a/src/world/BlockTypeRegistry.hpp +++ b/src/world/BlockTypeRegistry.hpp @@ -3,6 +3,8 @@ #include "BlockType.hpp" +#include +#include #include @@ -20,6 +22,8 @@ public: public: BlockTypeRegistry(); + /// register a new block type + /// this may throw if the name is already taken (names must be unique) Block::Type Add(BlockType &&); size_t size() const noexcept { return types.size(); } @@ -29,14 +33,20 @@ public: iterator end() noexcept { return types.end(); } const_iterator end() const noexcept { return types.end(); } - BlockType &operator [](Block::Type id) { return types[id]; } - const BlockType &operator [](Block::Type id) const { return types[id]; } + /// lookup by ID + BlockType &operator [](Block::Type id) noexcept { return types[id]; } + const BlockType &operator [](Block::Type id) const noexcept { return types[id]; } - BlockType &Get(Block::Type id) { return types[id]; } - const BlockType &Get(Block::Type id) const { return types[id]; } + BlockType &Get(Block::Type id) noexcept { return types[id]; } + const BlockType &Get(Block::Type id) const noexcept { return types[id]; } + + /// lookup by name + BlockType &Get(const std::string &name); + const BlockType &Get(const std::string &name) const; private: std::vector types; + std::map names; };