minetest/src/tool.h

147 lines
3.6 KiB
C
Raw Normal View History

2012-02-28 18:45:23 +01:00
/*
2013-02-24 18:40:43 +01:00
Minetest
2013-02-24 19:38:45 +01:00
Copyright (C) 2010-2013 celeron55, Perttu Ahola <celeron55@gmail.com>
2012-02-28 18:45:23 +01:00
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation; either version 2.1 of the License, or
2012-02-28 18:45:23 +01:00
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Lesser General Public License for more details.
2012-02-28 18:45:23 +01:00
You should have received a copy of the GNU Lesser General Public License along
2012-02-28 18:45:23 +01:00
with this program; if not, write to the Free Software Foundation, Inc.,
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
#pragma once
2012-02-28 18:45:23 +01:00
2012-06-17 03:00:31 +02:00
#include "irrlichttypes.h"
2012-02-28 18:45:23 +01:00
#include <string>
#include <iostream>
2012-03-04 13:22:35 +01:00
#include "itemgroup.h"
2023-03-25 19:48:50 +01:00
#include "json-forwards.h"
2012-02-28 18:45:23 +01:00
struct ItemDefinition;
2012-02-28 18:45:23 +01:00
struct ToolGroupCap
{
std::unordered_map<int, float> times;
int maxlevel = 1;
int uses = 20;
2012-02-28 18:45:23 +01:00
ToolGroupCap() = default;
2012-02-28 18:45:23 +01:00
bool getTime(int rating, float *time) const
{
std::unordered_map<int, float>::const_iterator i = times.find(rating);
if (i == times.end()) {
2012-02-28 18:45:23 +01:00
*time = 0;
return false;
}
*time = i->second;
return true;
}
void toJson(Json::Value &object) const;
void fromJson(const Json::Value &json);
2012-02-28 18:45:23 +01:00
};
2012-03-22 23:44:43 +01:00
typedef std::unordered_map<std::string, struct ToolGroupCap> ToolGCMap;
typedef std::unordered_map<std::string, s16> DamageGroup;
2012-03-22 23:44:43 +01:00
2012-02-28 18:45:23 +01:00
struct ToolCapabilities
{
float full_punch_interval;
int max_drop_level;
2012-03-22 23:44:43 +01:00
ToolGCMap groupcaps;
DamageGroup damageGroups;
2019-09-22 22:12:21 +02:00
int punch_attack_uses;
2012-02-28 18:45:23 +01:00
ToolCapabilities(
2019-09-22 22:12:21 +02:00
float full_punch_interval_ = 1.4f,
int max_drop_level_ = 1,
const ToolGCMap &groupcaps_ = ToolGCMap(),
2019-09-22 22:12:21 +02:00
const DamageGroup &damageGroups_ = DamageGroup(),
int punch_attack_uses_ = 0
2012-02-28 18:45:23 +01:00
):
full_punch_interval(full_punch_interval_),
max_drop_level(max_drop_level_),
groupcaps(groupcaps_),
2019-09-22 22:12:21 +02:00
damageGroups(damageGroups_),
punch_attack_uses(punch_attack_uses_)
2012-02-28 18:45:23 +01:00
{}
void serialize(std::ostream &os, u16 version) const;
2012-02-28 18:45:23 +01:00
void deSerialize(std::istream &is);
void serializeJson(std::ostream &os) const;
void deserializeJson(std::istream &is);
2012-02-28 18:45:23 +01:00
};
struct DigParams
{
bool diggable;
// Digging time in seconds
float time;
// Caused wear
u32 wear; // u32 because wear could be 65536 (single-use tool)
2012-03-23 23:33:58 +01:00
std::string main_group;
2012-02-28 18:45:23 +01:00
DigParams(bool a_diggable = false, float a_time = 0.0f, u32 a_wear = 0,
const std::string &a_main_group = ""):
2012-02-28 18:45:23 +01:00
diggable(a_diggable),
time(a_time),
2012-03-23 23:33:58 +01:00
wear(a_wear),
main_group(a_main_group)
2012-02-28 18:45:23 +01:00
{}
};
2012-03-04 13:22:35 +01:00
DigParams getDigParams(const ItemGroupList &groups,
const ToolCapabilities *tp,
const u16 initial_wear = 0);
2012-02-28 18:45:23 +01:00
struct HitParams
{
s32 hp;
// Caused wear
u32 wear; // u32 because wear could be 65536 (single-use weapon)
2012-02-28 18:45:23 +01:00
HitParams(s32 hp_ = 0, u32 wear_ = 0):
2012-02-28 18:45:23 +01:00
hp(hp_),
wear(wear_)
2012-02-28 18:45:23 +01:00
{}
};
HitParams getHitParams(const ItemGroupList &armor_groups,
const ToolCapabilities *tp, float time_from_last_punch,
u16 initial_wear = 0);
2012-02-28 18:45:23 +01:00
HitParams getHitParams(const ItemGroupList &armor_groups,
2012-02-28 18:45:23 +01:00
const ToolCapabilities *tp);
2012-03-05 00:30:55 +01:00
struct PunchDamageResult
{
bool did_punch = false;
int damage = 0;
int wear = 0;
PunchDamageResult() = default;
2012-03-05 00:30:55 +01:00
};
struct ItemStack;
PunchDamageResult getPunchDamage(
const ItemGroupList &armor_groups,
const ToolCapabilities *toolcap,
const ItemStack *punchitem,
float time_from_last_punch,
u16 initial_wear = 0
2012-03-05 00:30:55 +01:00
);
u32 calculateResultWear(const u32 uses, const u16 initial_wear);
f32 getToolRange(const ItemDefinition &def_selected, const ItemDefinition &def_hand);