mirror of
https://github.com/RPCS3/rpcs3.git
synced 2024-12-27 15:26:19 +00:00
patch_manager: Add dropdown labels
This commit is contained in:
parent
080737fd1f
commit
f2ded2fdb7
@ -417,7 +417,7 @@ bool patch_engine::load(patch_map& patches_map, const std::string& path, std::st
|
||||
break;
|
||||
case patch_dynamic_type::long_range:
|
||||
case patch_dynamic_type::long_enum:
|
||||
val = get_yaml_node_value<s64>(node, err);
|
||||
val = static_cast<f64>(get_yaml_node_value<s64>(node, err));
|
||||
break;
|
||||
}
|
||||
|
||||
@ -481,15 +481,27 @@ bool patch_engine::load(patch_map& patches_map, const std::string& path, std::st
|
||||
case patch_dynamic_type::double_enum:
|
||||
case patch_dynamic_type::long_enum:
|
||||
{
|
||||
if (const auto dynamic_value_allowed_values_node = dynamic_value_node.second[patch_key::allowed_values]; dynamic_value_allowed_values_node && dynamic_value_allowed_values_node.IsSequence())
|
||||
if (const auto dynamic_value_allowed_values_node = dynamic_value_node.second[patch_key::allowed_values]; dynamic_value_allowed_values_node && dynamic_value_allowed_values_node.IsMap())
|
||||
{
|
||||
dynamic_value.allowed_values.clear();
|
||||
|
||||
for (const auto allowed_value : dynamic_value_allowed_values_node)
|
||||
{
|
||||
if (allowed_value && allowed_value.IsScalar())
|
||||
if (allowed_value.second && allowed_value.second.IsScalar())
|
||||
{
|
||||
dynamic_value.allowed_values.push_back(get_and_check_dynamic_value(allowed_value));
|
||||
patch_allowed_value new_allowed_value{};
|
||||
new_allowed_value.label = allowed_value.first.Scalar();
|
||||
new_allowed_value.value = get_and_check_dynamic_value(allowed_value.second);
|
||||
|
||||
if (std::any_of(dynamic_value.allowed_values.begin(), dynamic_value.allowed_values.end(), [&new_allowed_value](const patch_allowed_value& other){ return new_allowed_value.value == other.value || new_allowed_value.label == other.label; }))
|
||||
{
|
||||
append_log_message(log_messages, fmt::format("Error: Skipping dynamic allowed value. Another entry with the same label or value already exists. (patch: %s, key: %s, location: %s, file: %s)", description, main_key, get_yaml_node_location(allowed_value), path), &patch_log.error);
|
||||
is_valid = false;
|
||||
}
|
||||
else
|
||||
{
|
||||
dynamic_value.allowed_values.push_back(new_allowed_value);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -504,7 +516,7 @@ bool patch_engine::load(patch_map& patches_map, const std::string& path, std::st
|
||||
is_valid = false;
|
||||
}
|
||||
|
||||
if (std::none_of(dynamic_value.allowed_values.begin(), dynamic_value.allowed_values.end(), [&dynamic_value](const f64& val){ return val == dynamic_value.value; }))
|
||||
if (std::none_of(dynamic_value.allowed_values.begin(), dynamic_value.allowed_values.end(), [&dynamic_value](const patch_allowed_value& other){ return other.value == dynamic_value.value; }))
|
||||
{
|
||||
append_log_message(log_messages, fmt::format("Error: Dynamic value was not found in allowed values (key: %s, location: %s, file: %s)", main_key, get_yaml_node_location(dynamic_value_allowed_values_node), path), &patch_log.error);
|
||||
is_valid = false;
|
||||
@ -790,7 +802,7 @@ static usz apply_modification(std::basic_string<u32>& applied, patch_engine::pat
|
||||
}
|
||||
default:
|
||||
{
|
||||
p.value.long_value = dynamic_value.value;
|
||||
p.value.long_value = static_cast<u64>(dynamic_value.value);
|
||||
patch_log.notice("Using dynamic value (key='%s', value=0x%x=%d, index=%d, hash='%s', description='%s', author='%s', patch_version='%s', file_version='%s')",
|
||||
key, p.value.long_value, p.value.long_value, i, patch.hash, patch.description, patch.author, patch.patch_version, patch.version);
|
||||
break;
|
||||
@ -1580,14 +1592,14 @@ bool patch_engine::save_patches(const patch_map& patches, const std::string& pat
|
||||
break;
|
||||
case patch_dynamic_type::double_enum:
|
||||
case patch_dynamic_type::long_enum:
|
||||
out << patch_key::allowed_values << YAML::BeginSeq;
|
||||
out << patch_key::allowed_values << YAML::BeginMap;
|
||||
|
||||
for (const auto& allowed_value : dynamic_value.allowed_values)
|
||||
{
|
||||
out << allowed_value;
|
||||
out << allowed_value.label << allowed_value.value;
|
||||
}
|
||||
|
||||
out << YAML::EndSeq;
|
||||
out << YAML::EndMap;
|
||||
break;
|
||||
}
|
||||
|
||||
|
@ -78,13 +78,24 @@ public:
|
||||
mutable u32 alloc_addr = 0; // Used to save optional allocation address (if occured)
|
||||
};
|
||||
|
||||
struct patch_allowed_value
|
||||
{
|
||||
std::string label;
|
||||
f64 value{};
|
||||
|
||||
bool operator==(const patch_allowed_value& other) const
|
||||
{
|
||||
return value == other.value && label == other.label;
|
||||
}
|
||||
};
|
||||
|
||||
struct patch_dynamic_value
|
||||
{
|
||||
f64 value{};
|
||||
f64 min{};
|
||||
f64 max{};
|
||||
patch_dynamic_type type{};
|
||||
std::vector<f64> allowed_values;
|
||||
std::vector<patch_allowed_value> allowed_values;
|
||||
|
||||
bool operator==(const patch_dynamic_value& other) const
|
||||
{
|
||||
|
@ -570,13 +570,13 @@ void patch_manager_dialog::update_patch_info(const patch_manager_dialog::gui_pat
|
||||
case patch_dynamic_type::long_enum:
|
||||
ui->dynamic_combo_box->blockSignals(true);
|
||||
ui->dynamic_combo_box->clear();
|
||||
for (const f64& allowed_value : dynamic_value.allowed_values)
|
||||
for (const patch_engine::patch_allowed_value& allowed_value : dynamic_value.allowed_values)
|
||||
{
|
||||
ui->dynamic_combo_box->addItem(QString::number(allowed_value), allowed_value);
|
||||
ui->dynamic_combo_box->addItem(QString::fromStdString(allowed_value.label), allowed_value.value);
|
||||
|
||||
if (allowed_value == dynamic_value.value)
|
||||
if (allowed_value.value == dynamic_value.value)
|
||||
{
|
||||
ui->dynamic_combo_box->setCurrentIndex(ui->dynamic_combo_box->findText(QString::number(allowed_value)));
|
||||
ui->dynamic_combo_box->setCurrentIndex(ui->dynamic_combo_box->findData(allowed_value.value));
|
||||
}
|
||||
}
|
||||
ui->dynamic_combo_box->setEnabled(true);
|
||||
|
Loading…
Reference in New Issue
Block a user