X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=src%2Ftool.h;h=c6bf0ad73fbee6b9e4b2f8cc4e9cd19e4b2298a4;hb=5a3b8e34b36a1f9b1f38f91483fc25d23b142f21;hp=e812a9e368c88cdd6889281c4da770cc0c41009e;hpb=979ca23f1eae1adeb8b0083dffe7203c54d87395;p=oweals%2Fminetest.git diff --git a/src/tool.h b/src/tool.h index e812a9e36..c6bf0ad73 100644 --- a/src/tool.h +++ b/src/tool.h @@ -17,30 +17,25 @@ with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ -#ifndef TOOL_HEADER -#define TOOL_HEADER +#pragma once #include "irrlichttypes.h" #include #include -#include #include "itemgroup.h" struct ToolGroupCap { - std::map times; - int maxlevel; - int uses; + std::unordered_map times; + int maxlevel = 1; + int uses = 20; - ToolGroupCap(): - maxlevel(1), - uses(20) - {} + ToolGroupCap() = default; bool getTime(int rating, float *time) const { - std::map::const_iterator i = times.find(rating); - if(i == times.end()){ + std::unordered_map::const_iterator i = times.find(rating); + if (i == times.end()) { *time = 0; return false; } @@ -50,28 +45,29 @@ struct ToolGroupCap }; -// CLANG SUCKS DONKEY BALLS -typedef std::map ToolGCMap; +typedef std::unordered_map ToolGCMap; +typedef std::unordered_map DamageGroup; struct ToolCapabilities { float full_punch_interval; int max_drop_level; - // CLANG SUCKS DONKEY BALLS ToolGCMap groupcaps; + DamageGroup damageGroups; ToolCapabilities( float full_punch_interval_=1.4, int max_drop_level_=1, - // CLANG SUCKS DONKEY BALLS - ToolGCMap groupcaps_=ToolGCMap() + const ToolGCMap &groupcaps_ = ToolGCMap(), + const DamageGroup &damageGroups_ = DamageGroup() ): full_punch_interval(full_punch_interval_), max_drop_level(max_drop_level_), - groupcaps(groupcaps_) + groupcaps(groupcaps_), + damageGroups(damageGroups_) {} - void serialize(std::ostream &os) const; + void serialize(std::ostream &os, u16 version) const; void deSerialize(std::istream &is); }; @@ -84,8 +80,8 @@ struct DigParams u16 wear; std::string main_group; - DigParams(bool a_diggable=false, float a_time=0, u16 a_wear=0, - std::string a_main_group=""): + DigParams(bool a_diggable = false, float a_time = 0.0f, u16 a_wear = 0, + const std::string &a_main_group = ""): diggable(a_diggable), time(a_time), wear(a_wear), @@ -103,33 +99,26 @@ struct HitParams { s16 hp; s16 wear; - std::string main_group; - HitParams(s16 hp_=0, s16 wear_=0, std::string main_group_=""): + HitParams(s16 hp_=0, s16 wear_=0): hp(hp_), - wear(wear_), - main_group(main_group_) + wear(wear_) {} }; -HitParams getHitParams(const ItemGroupList &groups, +HitParams getHitParams(const ItemGroupList &armor_groups, const ToolCapabilities *tp, float time_from_last_punch); -HitParams getHitParams(const ItemGroupList &groups, +HitParams getHitParams(const ItemGroupList &armor_groups, const ToolCapabilities *tp); struct PunchDamageResult { - bool did_punch; - int damage; - int wear; - std::string main_group; + bool did_punch = false; + int damage = 0; + int wear = 0; - PunchDamageResult(): - did_punch(false), - damage(0), - wear(0) - {} + PunchDamageResult() = default; }; struct ItemStack; @@ -140,6 +129,3 @@ PunchDamageResult getPunchDamage( const ItemStack *punchitem, float time_from_last_punch ); - -#endif -