16 #include "formula/callable_objects.hpp"
38 #define LOG_SF LOG_STREAM(info, log_scripting_formula)
39 #define ERR_SF LOG_STREAM(err, log_scripting_formula)
48 }
else if(key ==
"y") {
64 if(loc_callable ==
nullptr) {
86 if(key ==
"id" || key ==
"name") {
88 }
else if(key ==
"description") {
90 }
else if(key ==
"base_type") {
92 }
else if(key ==
"type") {
93 return variant(
att_->effective_damage_type().first);
94 }
else if(key ==
"icon") {
96 }
else if(key ==
"range") {
98 }
else if(key ==
"alignment") {
100 }
else if(key ==
"damage") {
102 }
else if(key ==
"number_of_attacks" || key ==
"number" || key ==
"num_attacks" || key ==
"attacks") {
104 }
else if(key ==
"attack_weight") {
106 }
else if(key ==
"defense_weight") {
108 }
else if(key ==
"accuracy") {
110 }
else if(key ==
"parry") {
112 }
else if(key ==
"movement_used") {
114 }
else if(key ==
"attacks_used") {
116 }
else if(key ==
"min_range") {
118 }
else if(key ==
"max_range") {
120 }
else if(key ==
"specials" || key ==
"special") {
121 std::vector<variant> res;
123 for(
const auto [
_, special_cfg] :
att_->specials().all_children_view()) {
124 if(!special_cfg[
"id"].empty()) {
125 res.emplace_back(special_cfg[
"id"].str());
159 if(att_callable ==
nullptr) {
163 if(
att_->damage() != att_callable->
att_->damage()) {
164 return att_->damage() - att_callable->
att_->damage();
167 if(
att_->num_attacks() != att_callable->
att_->num_attacks()) {
168 return att_->num_attacks() - att_callable->
att_->num_attacks();
171 if(
att_->id() != att_callable->
att_->id()) {
172 return att_->id().compare(att_callable->
att_->id());
175 if(
att_->type() != att_callable->
att_->type()) {
176 return att_->type().compare(att_callable->
att_->type());
179 if(
att_->range() != att_callable->
att_->range()) {
180 return att_->range().compare(att_callable->
att_->range());
183 if(
att_->alignment_str() != att_callable->
att_->alignment_str()) {
184 return att_->alignment_str().compare(att_callable->
att_->alignment_str());
187 const auto self_specials =
att_->specials().all_children_range();
188 const auto other_specials = att_callable->
att_->specials().all_children_range();
189 if(self_specials.size() != other_specials.size()) {
190 return self_specials.size() < other_specials.size() ? -1 : 1;
192 for(std::size_t
i = 0;
i < self_specials.size(); ++
i) {
193 const auto&
s = self_specials[
i].cfg[
"id"];
194 const auto& o = other_specials[
i].cfg[
"id"];
196 return s.str().compare(o.str());
217 }
else if(key ==
"y") {
223 }
else if(key ==
"loc") {
228 return variant(std::make_shared<location_callable>(
loc_));
229 }
else if(key ==
"terrain") {
234 }
else if(key ==
"id") {
236 }
else if(key ==
"type") {
238 }
else if(key ==
"name") {
240 }
else if(key ==
"usage") {
242 }
else if(key ==
"leader" || key ==
"canrecruit") {
244 }
else if(key ==
"undead") {
246 }
else if(key ==
"attacks") {
247 std::vector<variant> res;
249 res.emplace_back(std::make_shared<attack_type_callable>(att));
253 }
else if(key ==
"abilities") {
255 }
else if(key ==
"hitpoints") {
257 }
else if(key ==
"max_hitpoints") {
259 }
else if(key ==
"experience") {
261 }
else if(key ==
"max_experience") {
263 }
else if(key ==
"level" || key ==
"full") {
266 }
else if(key ==
"total_movement" || key ==
"max_moves") {
268 }
else if(key ==
"movement_left" || key ==
"moves") {
270 }
else if(key ==
"attacks_left") {
272 }
else if(key ==
"max_attacks") {
274 }
else if(key ==
"traits") {
276 }
else if(key ==
"advancements_taken") {
278 }
else if(key ==
"objects") {
280 }
else if(key ==
"traits_count") {
282 }
else if(key ==
"advancements_taken_count") {
284 }
else if(key ==
"objects_count") {
286 }
else if(key ==
"extra_recruit") {
288 }
else if(key ==
"advances_to") {
290 }
else if(key ==
"states" || key ==
"status") {
292 }
else if(key ==
"side_number") {
294 }
else if(key ==
"cost") {
296 }
else if(key ==
"upkeep") {
298 }
else if(key ==
"loyal") {
301 }
else if(key ==
"hidden") {
303 }
else if(key ==
"petrified") {
305 }
else if(key ==
"resting") {
307 }
else if(key ==
"role") {
309 }
else if(key ==
"race") {
311 }
else if(key ==
"gender") {
313 }
else if(key ==
"variation") {
315 }
else if(key ==
"zoc") {
317 }
else if(key ==
"alignment") {
319 }
else if(key ==
"facing") {
321 }
else if(key ==
"resistance" || key ==
"movement_cost" || key ==
"vision_cost" || key ==
"jamming_cost" || key ==
"defense") {
324 bool needs_flip =
false;
325 if(key ==
"resistance") {
326 mt.get_resistances().write(cfg);
328 }
else if(key ==
"movement_cost") {
329 mt.get_movement().write(cfg);
330 }
else if(key ==
"vision_cost") {
331 mt.get_vision().write(cfg);
332 }
else if(key ==
"jamming_cost") {
333 mt.get_jamming().write(cfg);
334 }
else if(key ==
"defense") {
335 mt.get_defense().write(cfg);
338 std::map<variant, variant> res;
340 int val = value.to_int();
348 }
else if(key ==
"flying") {
350 }
else if(key ==
"fearless") {
352 }
else if(key ==
"healthy") {
354 }
else if(key ==
"vars") {
360 }
else if(key ==
"wml_vars") {
362 }
else if(key ==
"n" || key ==
"s" || key ==
"ne" || key ==
"se" || key ==
"nw" || key ==
"sw" ||
363 key ==
"lawful" || key ==
"neutral" || key ==
"chaotic" || key ==
"liminal" ||
364 key ==
"male" || key ==
"female")
432 if(u_callable ==
nullptr) {
443 }
else if(key ==
"type") {
445 }
else if(key ==
"alignment") {
447 }
else if(key ==
"race") {
449 }
else if(key ==
"abilities") {
451 }
else if(key ==
"traits") {
452 std::vector<variant> res;
454 res.emplace_back(
config[
"id"].str());
458 }
else if(key ==
"attacks") {
459 std::vector<variant> res;
461 res.emplace_back(std::make_shared<attack_type_callable>(att));
465 }
else if(key ==
"hitpoints" || key ==
"max_hitpoints") {
467 }
else if(key ==
"experience" || key ==
"max_experience") {
469 }
else if(key ==
"level") {
471 }
else if(key ==
"total_movement" || key ==
"max_moves" || key ==
"moves") {
473 }
else if(key ==
"undead") {
475 }
else if(key ==
"unpoisonable") {
477 }
else if(key ==
"unslowable") {
479 }
else if(key ==
"unpetrifiable") {
481 }
else if(key ==
"undrainable") {
483 }
else if(key ==
"unplagueable") {
485 }
else if(key ==
"cost") {
487 }
else if(key ==
"recall_cost") {
489 }
else if(key ==
"usage") {
518 if(u_callable ==
nullptr) {
522 return u_.
id().compare(u_callable->
u_.
id());
526 #ifdef USING_BOOST_VARIANT
527 :
public boost::static_visitor<variant>
547 std::vector<variant> result;
549 result.emplace_back(std::make_shared<config_callable>(child));
553 }
else if(key ==
"__all_children") {
554 std::vector<variant> result;
556 const variant cfg_child(std::make_shared<config_callable>(child_cfg));
557 const variant kv(std::make_shared<key_value_pair>(
variant(child_key), cfg_child));
558 result.push_back(kv);
562 }
else if(key ==
"__children") {
563 std::map<std::string, std::vector<variant>> build;
565 const variant cfg_child(std::make_shared<config_callable>(child_cfg));
566 build[child_key].push_back(cfg_child);
569 std::map<variant,variant> result;
570 for(
auto&
p : build) {
575 }
else if(key ==
"__attributes") {
576 std::map<variant,variant> result;
603 if(cfg_callable ==
nullptr) {
623 }
else if(key ==
"y") {
625 }
else if(key ==
"loc") {
626 return variant(std::make_shared<location_callable>(
loc_));
627 }
else if(key ==
"id") {
629 }
else if(key ==
"name") {
631 }
else if(key ==
"editor_name") {
633 }
else if(key ==
"description") {
635 }
else if(key ==
"icon") {
637 }
else if(key ==
"light") {
639 }
else if(key ==
"village") {
641 }
else if(key ==
"castle") {
643 }
else if(key ==
"keep") {
645 }
else if(key ==
"healing") {
647 }
else if(key ==
"owner_side") {
675 if(terr_callable ==
nullptr) {
695 if(key ==
"terrain") {
699 std::vector<variant> vars;
700 for(
int i = 0;
i <
w;
i++) {
701 for(
int j = 0; j <
h; j++) {
703 vars.emplace_back(std::make_shared<terrain_callable>(
board_,
loc));
708 }
else if(key ==
"gamemap") {
712 std::map<variant, variant> vars;
713 for(
int i = 0;
i <
w;
i++) {
714 for(
int j = 0; j <
h; j++) {
716 vars.emplace(std::make_shared<location_callable>(
loc), std::make_shared<terrain_callable>(
board_,
loc));
721 }
else if(key ==
"w") {
723 }
else if(key ==
"h") {
766 }
else if(key ==
"side_number") {
768 }
else if(key ==
"id") {
770 }
else if(key ==
"save_id") {
772 }
else if(key ==
"gold") {
774 }
else if(key ==
"start_gold") {
776 }
else if(key ==
"base_income") {
778 }
else if(key ==
"total_income") {
780 }
else if(key ==
"village_gold") {
782 }
else if(key ==
"village_support") {
784 }
else if(key ==
"recall_cost") {
786 }
else if(key ==
"is_human") {
788 }
else if(key ==
"is_ai") {
790 }
else if(key ==
"is_network") {
792 }
else if(key ==
"fog") {
794 }
else if(key ==
"shroud") {
796 }
else if(key ==
"hidden") {
798 }
else if(key ==
"flag") {
800 }
else if(key ==
"flag_icon") {
802 }
else if(key ==
"team_name") {
804 }
else if(key ==
"faction") {
806 }
else if(key ==
"faction_name") {
808 }
else if(key ==
"color") {
810 }
else if(key ==
"share_vision") {
812 }
else if(key ==
"carryover_bonus") {
814 }
else if(key ==
"carryover_percentage") {
816 }
else if(key ==
"carryover_add") {
818 }
else if(key ==
"recruit") {
819 std::vector<variant> result;
821 result.emplace_back(recruit);
824 }
else if(key ==
"recall") {
825 std::vector<variant> result;
827 result.push_back(std::make_shared<unit_callable>(*u));
830 }
else if(key ==
"wml_vars") {
841 }
else if(
key ==
"value") {
864 ERR_SF <<
"ERROR #" << 5001 <<
" while executing 'set_var' formula function";
873 }
else if(key ==
"backup") {
890 res = action->execute_self(ctxt);
900 callable.
add(
"error", res);
913 if(key ==
"status") {
915 }
else if(key ==
"object") {
950 if(key ==
"turn_number") {
952 }
else if(key ==
"time_of_day") {
954 }
else if(key ==
"side_number") {
956 }
else if(key ==
"sides") {
957 std::vector<variant> vars;
959 vars.emplace_back(std::make_shared<team_callable>(
team));
962 }
else if(key ==
"units") {
963 std::vector<variant> vars;
965 vars.emplace_back(std::make_shared<unit_callable>(
unit));
968 }
else if(key ==
"map") {
992 }
else if(key ==
"event_id") {
994 }
else if(key ==
"loc") {
996 }
else if(key ==
"second_loc") {
998 }
else if(key ==
"event_data") {
1000 }
else if(key ==
"unit") {
1002 return variant(std::make_shared<unit_callable>(*u1));
1004 }
else if(key ==
"second_unit") {
1006 return variant(std::make_shared<unit_callable>(*u2));
1008 }
else if(key ==
"weapon") {
1013 }
else if(key ==
"second_weapon") {
1035 }
else if(key ==
"green") {
1037 }
else if(key ==
"blue") {
1039 }
else if(key ==
"alpha") {
A config object defines a single node in a WML file, with access to child nodes.
config & mandatory_child(config_key_type key, int n=0)
Returns the nth child with the given key, or throws an error if there is none.
const_attr_itors attribute_range() const
auto all_children_view() const
In-order iteration over all children.
bool has_child(config_key_type key) const
Determine whether a config has a child or not.
bool has_attribute(config_key_type key) const
child_itors child_range(config_key_type key)
Abstract class for exposing game data that doesn't depend on the GUI, however which for historical re...
virtual const gamemap & map() const =0
int w() const
Effective map width.
int h() const
Effective map height.
Encapsulates the map of the game.
This class stores all the data for a single 'side' (in game nomenclature).
const std::string & color() const
const std::string & faction() const
int village_support() const
const std::string & team_name() const
bool is_local_human() const
team_shared_vision::type share_vision() const
const t_string & faction_name() const
bool carryover_add() const
int carryover_percentage() const
const std::string & save_id() const
double carryover_bonus() const
const std::string & flag_icon() const
const std::string & flag() const
recall_list_manager & recall_list()
const std::set< std::string > & recruits() const
const std::string & icon_image() const
const t_string & name() const
const std::string & id() const
const t_string & description() const
int light_bonus(int base) const
Returns the light (lawful) bonus for this terrain when the time of day gives a base bonus.
const t_string & editor_name() const
int gives_healing() const
const std::string & id() const
std::string race_id() const
Returns the ID of this type's race without the need to build the type.
const std::string & id() const
The id for this unit_type.
const_attack_itors attacks() const
const std::string & usage() const
int experience_needed(bool with_acceleration=true) const
bool musthave_status(const std::string &status) const
std::vector< std::string > get_ability_list() const
const t_string & type_name() const
The name of the unit in the current language setting.
config::const_child_itors possible_traits() const
unit_alignments::type alignment() const
This class represents a single unit of a specific type.
Represents version numbers.
int do_compare(const formula_callable *callable) const override
variant get_value(const std::string &key) const override
attack_type_callable(const attack_type &attack)
void get_inputs(formula_input_vector &inputs) const override
variant get_value(const std::string &key) const override
void get_inputs(formula_input_vector &inputs) const override
void get_inputs(formula_input_vector &inputs) const override
variant get_value(const std::string &key) const override
int do_compare(const formula_callable *callable) const override
const config & get_config() const
void get_inputs(formula_input_vector &inputs) const override
variant get_value(const std::string &key) const override
std::shared_ptr< attack_type > second_weapon
const game_events::queued_event & event_info
std::shared_ptr< attack_type > first_weapon
const display_context & board_
const gamemap & get_gamemap() const
void get_inputs(formula_input_vector &inputs) const override
variant get_value(const std::string &key) const override
variant get_value(const std::string &key) const override
void get_inputs(formula_input_vector &inputs) const override
const map_location & loc() const
void serialize_to_string(std::string &str) const override
void get_inputs(formula_input_vector &inputs) const override
int do_compare(const formula_callable *callable) const override
variant get_value(const std::string &key) const override
const expression_ptr & get_backup() const
variant execute_self(variant ctxt) override
variant get_value(const std::string &key) const override
void get_inputs(formula_input_vector &inputs) const override
const map_location current_unit_location_
void get_inputs(formula_input_vector &inputs) const override
const_formula_callable_ptr failed_callable_
variant get_value(const std::string &key) const override
void get_inputs(formula_input_vector &inputs) const override
variant get_value(const std::string &key) const override
const std::string & key() const
variant execute_self(variant ctxt) override
void get_inputs(formula_input_vector &inputs) const override
variant get_value(const std::string &key) const override
variant get_value(const std::string &key) const override
terrain_callable(const display_context &m, const map_location &loc)
void get_inputs(formula_input_vector &inputs) const override
int do_compare(const formula_callable *callable) const override
variant get_value(const std::string &key) const override
const map_location & loc_
void get_inputs(formula_input_vector &inputs) const override
unit_callable(const map_location &loc, const unit &u)
int do_compare(const formula_callable *callable) const override
variant get_value(const std::string &key) const override
int do_compare(const formula_callable *callable) const override
void get_inputs(formula_input_vector &inputs) const override
variant execute_variant(const variant &to_exec)
std::shared_ptr< T > try_convert() const
const_formula_callable_ptr as_callable() const
std::string to_debug_string(bool verbose=false, formula_seen_stack *seen=nullptr) const
Definitions for the interface to Wesnoth Markup Language (WML).
std::string deprecated_message(const std::string &elem_name, DEP_LEVEL level, const version_info &version, const std::string &detail)
Interfaces for manipulating version numbers of engine, add-ons, etc.
static std::string _(const char *str)
std::vector< std::string > get_ability_list() const
Get a list of all abilities by ID.
unit_formula_manager & formula_manager() const
Get the unit formula manager.
int max_hitpoints() const
The max number of hitpoints this unit can have.
unit_alignments::type alignment() const
The alignment of this unit.
bool incapacitated() const
Check if the unit has been petrified.
int level() const
The current level of this unit.
std::string usage() const
Gets this unit's usage.
const std::string & get_role() const
Gets this unit's role.
const std::vector< std::string > & recruits() const
The type IDs of the other units this unit may recruit, if possible.
const std::string & variation() const
The ID of the variation of this unit's type.
int hitpoints() const
The current number of hitpoints this unit has.
int cost() const
How much gold is required to recruit this unit.
bool get_state(const std::string &state) const
Check if the unit is affected by a status effect.
const std::string & type_id() const
The id of this unit's type.
bool get_hidden() const
Gets whether this unit is currently hidden on the map.
const std::set< std::string > get_states() const
Get the status effects currently affecting the unit.
const unit_race * race() const
Gets this unit's race.
int experience() const
The current number of experience points this unit has.
bool can_recruit() const
Whether this unit can recruit other units - ie, are they a leader unit.
const std::string & id() const
Gets this unit's id.
int side() const
The side this unit belongs to.
config & variables()
Gets any user-defined variables this unit 'owns'.
std::size_t underlying_id() const
This unit's unique internal ID.
int max_experience() const
The max number of experience points this unit can have.
unit_race::GENDER gender() const
The gender of this unit.
const t_string & name() const
Gets this unit's translatable display name.
const advances_to_t & advances_to() const
Gets the possible types this unit can advance to on level-up.
attack_itors attacks()
Gets an iterator over this unit's attacks.
int max_attacks() const
The maximum number of attacks this unit may perform per turn, usually 1.
int attacks_left() const
Gets the remaining number of attacks this unit can perform this turn.
std::size_t advancements_count() const
std::size_t traits_count() const
std::size_t objects_count() const
bool get_emit_zoc() const
Gets the raw zone-of-control flag, disregarding incapacitated.
const movetype & movement_type() const
Get the unit's movement type.
int movement_left() const
Gets how far a unit can move, considering the incapacitated flag.
int total_movement() const
The maximum moves this unit has.
map_location::direction facing() const
The current direction this unit is facing within its hex.
bool resting() const
Checks whether this unit is 'resting'.
bool is_flying() const
Check if the unit is a flying unit.
std::vector< std::string > get_advancements_list() const
std::vector< std::string > get_objects_list() const
int upkeep() const
Gets the amount of gold this unit costs a side per turn.
bool is_healthy() const
Gets whether this unit is healthy - ie, always rest heals.
bool is_fearless() const
Gets whether this unit is fearless - ie, unaffected by time of day.
std::vector< std::string > get_traits_list() const
Gets a list of the traits this unit currently has, including hidden traits.
Standard logging facilities (interface).
::tod_manager * tod_manager
play_controller * controller
std::vector< formula_input > formula_input_vector
static std::string get_location(const std::string &loc)
Define the game's event mechanism.
const std::string & gender_string(unit_race::GENDER gender)
unit_const_ptr get_unit() const
Encapsulates the map of the game.
static std::string write_direction(direction dir)
static const map_location & null_location()
int do_compare(const map_location &a) const
three-way comparator
static std::string get_string(enum_type key)
Converts a enum to its string equivalent.
variant operator()(utils::monostate) const
variant operator()(bool b) const
variant operator()(const std::string &s) const
variant operator()(int i) const
variant operator()(unsigned long long i) const
variant operator()(const t_string &s) const
variant operator()(double i) const
static map_location::direction s