From a3972a65b9b443a6085a6ac40b153442e190f382 Mon Sep 17 00:00:00 2001 From: Star Rauchenberger Date: Mon, 1 Sep 2025 12:54:46 -0400 Subject: Added progressive doors --- tools/validator/human_processor.cpp | 28 ++++++++++++++++++++++++++++ tools/validator/structs.h | 8 ++++++++ tools/validator/validator.cpp | 16 ++++++++++++++++ 3 files changed, 52 insertions(+) (limited to 'tools/validator') diff --git a/tools/validator/human_processor.cpp b/tools/validator/human_processor.cpp index 0f63936..49e7578 100644 --- a/tools/validator/human_processor.cpp +++ b/tools/validator/human_processor.cpp @@ -41,6 +41,7 @@ class HumanProcessor { ProcessConnectionsFile(datadir_path / "connections.txtpb", std::nullopt); ProcessMaps(datadir_path); + ProcessProgressivesFile(datadir_path / "progressives.txtpb"); ProcessIdsFile(datadir_path / "ids.txtpb"); } @@ -481,6 +482,33 @@ class HumanProcessor { } } + void ProcessProgressivesFile(std::filesystem::path path) { + if (!std::filesystem::exists(path)) { + return; + } + + auto h_progs = ReadMessageFromFile(path.string()); + + for (const HumanProgressive& h_prog : h_progs.progressives()) { + ProcessProgressive(h_prog); + } + } + + void ProcessProgressive(const HumanProgressive& h_prog) { + ProgressiveInfo& prog_info = info_.progressives[h_prog.name()]; + prog_info.definitions.push_back(h_prog); + + for (const DoorIdentifier& di : h_prog.doors()) { + if (!di.has_map()) { + prog_info.malformed_doors.push_back(di); + continue; + } + + DoorInfo& door_info = info_.doors[di]; + door_info.progressives_referenced_by.push_back(h_prog.name()); + } + } + void ProcessIdsFile(std::filesystem::path path) { // Ignore this for now. } diff --git a/tools/validator/structs.h b/tools/validator/structs.h index 0ca96fe..717fccf 100644 --- a/tools/validator/structs.h +++ b/tools/validator/structs.h @@ -45,6 +45,7 @@ struct DoorInfo { std::vector panels_referenced_by; std::vector paintings_referenced_by; std::vector ports_referenced_by; + std::vector progressives_referenced_by; MalformedIdentifiers malformed_identifiers; }; @@ -102,6 +103,12 @@ struct PanelNameInfo { std::vector panels_used_by; }; +struct ProgressiveInfo { + std::vector definitions; + + std::vector malformed_doors; +}; + struct CollectedInfo { std::map maps; std::map rooms; @@ -114,6 +121,7 @@ struct CollectedInfo { std::map letters; std::map endings; std::map panel_names; + std::map progressives; }; } // namespace com::fourisland::lingo2_archipelago diff --git a/tools/validator/validator.cpp b/tools/validator/validator.cpp index 9c66e09..fd004d7 100644 --- a/tools/validator/validator.cpp +++ b/tools/validator/validator.cpp @@ -45,6 +45,9 @@ class Validator { for (const auto& [panel_name, panel_info] : info_.panel_names) { ValidatePanelName(panel_name, panel_info); } + for (const auto& [prog_name, prog_info] : info_.progressives) { + ValidateProgressive(prog_name, prog_info); + } } private: @@ -164,6 +167,11 @@ class Validator { std::cout << " CONNECTION " << connection.ShortDebugString() << std::endl; } + + for (const std::string& prog_name : + door_info.progressives_referenced_by) { + std::cout << " PROGRESSIVE " << prog_name << std::endl; + } } else if (door_info.definitions.size() > 1) { std::cout << "Door " << door_identifier.ShortDebugString() << " was defined multiple times." << std::endl; @@ -369,6 +377,14 @@ class Validator { } } + void ValidateProgressive(const std::string& prog_name, + const ProgressiveInfo& prog_info) const { + if (prog_info.definitions.size() > 1) { + std::cout << "Progressive \"" << prog_name + << "\" has multiple definitions." << std::endl; + } + } + const CollectedInfo& info_; }; -- cgit 1.4.1