Skip to content

Commit

Permalink
Merge pull request CleverRaven#76968 from GuardianDll/math_volume_and…
Browse files Browse the repository at this point in the history
…_weight

move volume and weight vals to math
  • Loading branch information
Maleclypse authored Oct 14, 2024
2 parents 32eb1d6 + c2a171d commit 1380795
Show file tree
Hide file tree
Showing 7 changed files with 50 additions and 10 deletions.
8 changes: 4 additions & 4 deletions data/json/effects_on_condition/example_eocs.json
Original file line number Diff line number Diff line change
Expand Up @@ -109,17 +109,17 @@
"type": "effect_on_condition",
"id": "EOC_variable_weight_volume_test1",
"effect": [
{ "math": [ "u_weight_test", "=", "u_val('weight')" ] },
{ "math": [ "u_volume_test", "=", "u_val('volume')" ] },
{ "math": [ "u_weight_test", "=", "u_weight()" ] },
{ "math": [ "u_volume_test", "=", "u_volume()" ] },
{ "u_message": "<u_name> weight: <u_val:weight_test> volume: <u_val:volume_test>" }
]
},
{
"type": "effect_on_condition",
"id": "EOC_variable_weight_volume_test2",
"effect": [
{ "math": [ "u_weight_test", "=", "n_val('weight')" ] },
{ "math": [ "u_volume_test", "=", "n_val('volume')" ] },
{ "math": [ "u_weight_test", "=", "n_weight()" ] },
{ "math": [ "u_volume_test", "=", "n_volume()" ] },
{ "u_message": "<npc_name> weight: <u_val:weight_test> volume: <u_val:volume_test>" }
]
},
Expand Down
8 changes: 4 additions & 4 deletions data/mods/MindOverMatter/powers/telekinesis_eoc.json
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@
"math": [
"u_weight_ratio",
"=",
"(((u_telekinesis_power_level * 25) * u_telekinesis_intelligence * u_nether_attunement_telekinesis_scaling) + 10) / (u_val('weight') / 1000000)"
"(((u_telekinesis_power_level * 25) * u_telekinesis_intelligence * u_nether_attunement_telekinesis_scaling) + 10) / (u_weight() / 1000000)"
]
},
{ "math": [ "u_telekinesis_shove_spell_level", "=", "clamp(((u_weight_ratio - 1) * 2), 0, 30)" ] },
Expand Down Expand Up @@ -90,7 +90,7 @@
"math": [
"u_weight_ratio",
"=",
"(((u_telekinesis_power_level * 25) * u_telekinesis_intelligence * u_nether_attunement_telekinesis_scaling) + 10) / (u_val('weight') / 1000000)"
"(((u_telekinesis_power_level * 25) * u_telekinesis_intelligence * u_nether_attunement_telekinesis_scaling) + 10) / (u_weight() / 1000000)"
]
},
{ "math": [ "u_telekinesis_pull_spell_level", "=", "clamp(((u_weight_ratio - 1) * 2), 0, 30)" ] },
Expand Down Expand Up @@ -150,7 +150,7 @@
"math": [
"u_weight_ratio",
"=",
"(((u_telekinesis_power_level * 150) * u_telekinesis_intelligence * u_nether_attunement_telekinesis_scaling) + 100) / (u_val('weight') / 1000000)"
"(((u_telekinesis_power_level * 150) * u_telekinesis_intelligence * u_nether_attunement_telekinesis_scaling) + 100) / (u_weight() / 1000000)"
]
},
{ "math": [ "u_telekinesis_shove_spell_level", "=", "clamp(((u_weight_ratio - 1) * 2), 0, 20)" ] },
Expand Down Expand Up @@ -180,7 +180,7 @@
"math": [
"u_weight_ratio",
"=",
"(((u_telekinesis_power_level * 150) * u_telekinesis_intelligence * u_nether_attunement_telekinesis_scaling) + 100) / (u_val('weight') / 1000000)"
"(((u_telekinesis_power_level * 150) * u_telekinesis_intelligence * u_nether_attunement_telekinesis_scaling) + 100) / (u_weight() / 1000000)"
]
},
{ "math": [ "u_telekinesis_pull_spell_level", "=", "clamp(((u_weight_ratio - 1) * 2), 0, 20)" ] },
Expand Down
2 changes: 2 additions & 0 deletions doc/NPCs.md
Original file line number Diff line number Diff line change
Expand Up @@ -1393,6 +1393,8 @@ _some functions support array arguments or kwargs, denoted with square brackets
| npc_fear() ||| u, n | Return NPC fear toward opposite talker. <br/><br/>Example:<br/> `{ "math": [ "n_npc_fear()", "<", "2" ] }`|
| npc_trust() ||| u, n | Return NPC trust toward opposite talker. <br/><br/>Example:<br/> `{ "math": [ "n_npc_trust()", "=", "2" ] }`|
| npc_value() ||| u, n | Return NPC value toward opposite talker. <br/><br/>Example:<br/> `{ "math": [ "n_npc_value()", "+=", "2" ] }`|
| weight() ||| u, n | Return creature or item weight, in miligrams. <br/><br/>Example:<br/> `{ "math": [ "u_weight()", "<", "1000000" ] }`|
| volume() ||| u, n | Return creature or item volume, in mililiters. <br/><br/>Example:<br/> `{ "math": [ "u_volume()", "<", "1000" ] }`|
| vitamin(`s`/`v`) ||| u, n | Return or set the characters vitamin level.<br/>Argument is vitamin ID.<br/><br/>Example:<br/>`{ "math": [ "u_vitamin('mutagen')", "=", "0" ] }`|
| warmth(`s`/`v`) ||| u, n | Return the characters warmth on a body part.<br/>Argument is bodypart ID.<br/><br/>Example:<br/> The value displayed in-game is calculated as follows.<br/> `"{ "math": [ "u_warmth_in_game", "=", "(u_warmth('torso') / 100) * 2 - 100"] }`|
| vision_range() ||| u, n | Return the character's or monsters visual range, adjusted by their mutations, effects, and other issues.<br/><br/>Example:<br/> `"{ "math": [ "n_vision_range()", "<", "30"] }`|
Expand Down
2 changes: 0 additions & 2 deletions src/condition.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2210,8 +2210,6 @@ std::unordered_map<std::string_view, int ( talker::* )() const> const f_get_vals
{ "strength_bonus", &talker::get_str_bonus },
{ "strength", &talker::str_cur },
{ "thirst", &talker::get_thirst },
{ "volume", &talker::get_volume },
{ "weight", &talker::get_weight },
{ "count", &talker::get_count }
};
} // namespace
Expand Down
34 changes: 34 additions & 0 deletions src/math_parser_diag.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1698,6 +1698,38 @@ std::function<void( dialogue &, double )> calories_ass( char scope,
};
}

std::function<double( dialogue & )> weight_eval( char scope,
std::vector<diag_value> const &/* params */, diag_kwargs const &/* kwargs */ )
{
return[beta = is_beta( scope )]( dialogue const & d ) {
if( d.actor( beta )->get_character() || d.actor( beta )->get_monster() ) {
return d.actor( beta )->get_weight();
}
item_location const *it = static_cast<talker const *>( d.actor( beta ) )->get_item();
if( it && *it ) {
return static_cast<int>( to_milligram( it->get_item()->weight() ) );
}
debugmsg( "For weight(), talker is not character nor item" );
return 0;
};
}

std::function<double( dialogue & )> volume_eval( char scope,
std::vector<diag_value> const &/* params */, diag_kwargs const &/* kwargs */ )
{
return[beta = is_beta( scope )]( dialogue const & d ) {
if( d.actor( beta )->get_character() || d.actor( beta )->get_monster() ) {
return d.actor( beta )->get_volume();
}
item_location const *it = static_cast<talker const *>( d.actor( beta ) )->get_item();
if( it && *it ) {
return to_milliliter( it->get_item()->volume() );
}
debugmsg( "For volume(), talker is not character nor item" );
return 0;
};
}

std::function<double( dialogue & )> vitamin_eval( char scope,
std::vector<diag_value> const &params, diag_kwargs const &/* kwargs */ )
{
Expand Down Expand Up @@ -1879,6 +1911,8 @@ std::map<std::string_view, dialogue_func_eval> const dialogue_eval_f{
{ "vision_range", { "un", 0, vision_range_eval } },
{ "vitamin", { "un", 1, vitamin_eval } },
{ "calories", { "un", 0, calories_eval } },
{ "weight", { "un", 0, weight_eval } },
{ "volume", { "un", 0, volume_eval } },
{ "warmth", { "un", 1, warmth_eval } },
{ "weather", { "g", 1, weather_eval } },
{ "climate_control_str_heat", { "un", 0, climate_control_str_heat_eval } },
Expand Down
5 changes: 5 additions & 0 deletions src/talker_character.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1009,6 +1009,11 @@ int talker_character_const::get_weight() const
return units::to_milligram( me_chr_const->get_weight() );
}

int talker_character_const::get_volume() const
{
return units::to_milliliter( me_chr_const->get_total_volume() );
}

void talker_character::set_height( int amount )
{
me_chr->set_base_height( amount );
Expand Down
1 change: 1 addition & 0 deletions src/talker_character.h
Original file line number Diff line number Diff line change
Expand Up @@ -194,6 +194,7 @@ class talker_character_const: public talker_cloner<talker_character_const>
int get_height() const override;
int get_bmi_permil() const override;
int get_weight() const override;
int get_volume() const override;
const move_mode_id &get_move_mode() const override;
int get_fine_detail_vision_mod() const override;
int get_health() const override;
Expand Down

0 comments on commit 1380795

Please sign in to comment.