about summary refs log tree commit diff stats
path: root/tools/datapacker
diff options
context:
space:
mode:
Diffstat (limited to 'tools/datapacker')
-rw-r--r--tools/datapacker/container.cpp34
-rw-r--r--tools/datapacker/container.h6
-rw-r--r--tools/datapacker/main.cpp110
3 files changed, 145 insertions, 5 deletions
diff --git a/tools/datapacker/container.cpp b/tools/datapacker/container.cpp index 2c68552..4a656b3 100644 --- a/tools/datapacker/container.cpp +++ b/tools/datapacker/container.cpp
@@ -331,6 +331,40 @@ uint64_t Container::FindOrAddDoor(std::optional<std::string> map_name,
331 } 331 }
332} 332}
333 333
334uint64_t Container::FindOrAddProgressive(std::string prog_name) {
335 auto it = progressive_id_by_name_.find(prog_name);
336
337 if (it == progressive_id_by_name_.end()) {
338 uint64_t new_id = all_objects_.progressives_size();
339 Progressive* progressive = all_objects_.add_progressives();
340 progressive->set_id(new_id);
341 progressive->set_name(prog_name);
342
343 progressive_id_by_name_[prog_name] = new_id;
344
345 return new_id;
346 } else {
347 return it->second;
348 }
349}
350
351uint64_t Container::FindOrAddDoorGroup(std::string group_name) {
352 auto it = door_group_id_by_name_.find(group_name);
353
354 if (it == door_group_id_by_name_.end()) {
355 uint64_t new_id = all_objects_.door_groups_size();
356 DoorGroup* door_group = all_objects_.add_door_groups();
357 door_group->set_id(new_id);
358 door_group->set_name(group_name);
359
360 door_group_id_by_name_[group_name] = new_id;
361
362 return new_id;
363 } else {
364 return it->second;
365 }
366}
367
334void Container::AddConnection(const Connection& connection) { 368void Container::AddConnection(const Connection& connection) {
335 *all_objects_.add_connections() = connection; 369 *all_objects_.add_connections() = connection;
336} 370}
diff --git a/tools/datapacker/container.h b/tools/datapacker/container.h index 68f5875..bc02ba4 100644 --- a/tools/datapacker/container.h +++ b/tools/datapacker/container.h
@@ -60,6 +60,10 @@ class Container {
60 60
61 void AddConnection(const Connection& connection); 61 void AddConnection(const Connection& connection);
62 62
63 uint64_t FindOrAddProgressive(std::string prog_name);
64
65 uint64_t FindOrAddDoorGroup(std::string group_name);
66
63 AllObjects& all_objects() { return all_objects_; } 67 AllObjects& all_objects() { return all_objects_; }
64 68
65 private: 69 private:
@@ -82,6 +86,8 @@ class Container {
82 std::map<std::string, std::map<std::string, uint64_t>> 86 std::map<std::string, std::map<std::string, uint64_t>>
83 door_id_by_map_door_names_; 87 door_id_by_map_door_names_;
84 std::map<std::string, uint64_t> ending_id_by_name_; 88 std::map<std::string, uint64_t> ending_id_by_name_;
89 std::map<std::string, uint64_t> progressive_id_by_name_;
90 std::map<std::string, uint64_t> door_group_id_by_name_;
85}; 91};
86 92
87} // namespace com::fourisland::lingo2_archipelago 93} // namespace com::fourisland::lingo2_archipelago
diff --git a/tools/datapacker/main.cpp b/tools/datapacker/main.cpp index d820360..6bbb461 100644 --- a/tools/datapacker/main.cpp +++ b/tools/datapacker/main.cpp
@@ -43,6 +43,9 @@ class DataPacker {
43 43
44 ProcessConnectionsFile(datadir_path / "connections.txtpb", std::nullopt); 44 ProcessConnectionsFile(datadir_path / "connections.txtpb", std::nullopt);
45 ProcessMaps(datadir_path); 45 ProcessMaps(datadir_path);
46 ProcessProgressivesFile(datadir_path / "progressives.txtpb");
47 ProcessDoorGroupsFile(datadir_path / "door_groups.txtpb");
48 ProcessGlobalMetadataFile(datadir_path / "metadata.txtpb");
46 ProcessIdsFile(datadir_path / "ids.yaml"); 49 ProcessIdsFile(datadir_path / "ids.yaml");
47 50
48 { 51 {
@@ -104,7 +107,11 @@ class DataPacker {
104 container_.FindOrAddRoom(current_map_name, h_room.name(), std::nullopt); 107 container_.FindOrAddRoom(current_map_name, h_room.name(), std::nullopt);
105 Room& room = *container_.all_objects().mutable_rooms(room_id); 108 Room& room = *container_.all_objects().mutable_rooms(room_id);
106 109
107 room.set_display_name(h_room.display_name()); 110 // room.set_display_name(h_room.display_name());
111
112 if (h_room.has_panel_display_name()) {
113 room.set_panel_display_name(h_room.panel_display_name());
114 }
108 115
109 for (const HumanPanel& h_panel : h_room.panels()) { 116 for (const HumanPanel& h_panel : h_room.panels()) {
110 room.add_panels(ProcessPanel(h_panel, current_map_name, room.name())); 117 room.add_panels(ProcessPanel(h_panel, current_map_name, room.name()));
@@ -175,6 +182,10 @@ class DataPacker {
175 map_name, h_panel.required_room().name(), current_map_name)); 182 map_name, h_panel.required_room().name(), current_map_name));
176 } 183 }
177 184
185 if (h_panel.has_display_name()) {
186 panel.set_display_name(h_panel.display_name());
187 }
188
178 return panel_id; 189 return panel_id;
179 } 190 }
180 191
@@ -284,6 +295,10 @@ class DataPacker {
284 295
285 keyholder.set_path(h_keyholder.path()); 296 keyholder.set_path(h_keyholder.path());
286 297
298 if (h_keyholder.has_key()) {
299 keyholder.set_key(h_keyholder.key());
300 }
301
287 return keyholder_id; 302 return keyholder_id;
288 } 303 }
289 304
@@ -330,9 +345,6 @@ class DataPacker {
330 std::copy( 345 std::copy(
331 h_door.receivers().begin(), h_door.receivers().end(), 346 h_door.receivers().begin(), h_door.receivers().end(),
332 google::protobuf::RepeatedFieldBackInserter(door.mutable_receivers())); 347 google::protobuf::RepeatedFieldBackInserter(door.mutable_receivers()));
333 std::copy(
334 h_door.switches().begin(), h_door.switches().end(),
335 google::protobuf::RepeatedFieldBackInserter(door.mutable_switches()));
336 348
337 for (const PaintingIdentifier& pi : h_door.move_paintings()) { 349 for (const PaintingIdentifier& pi : h_door.move_paintings()) {
338 std::optional<std::string> map_name = 350 std::optional<std::string> map_name =
@@ -380,7 +392,7 @@ class DataPacker {
380 door.add_doors( 392 door.add_doors(
381 container_.FindOrAddDoor(map_name, di.name(), current_map_name)); 393 container_.FindOrAddDoor(map_name, di.name(), current_map_name));
382 } 394 }
383 395
384 for (const std::string& ending_name : h_door.endings()) { 396 for (const std::string& ending_name : h_door.endings()) {
385 door.add_endings(container_.FindOrAddEnding(ending_name)); 397 door.add_endings(container_.FindOrAddEnding(ending_name));
386 } 398 }
@@ -394,6 +406,14 @@ class DataPacker {
394 } 406 }
395 407
396 door.set_type(h_door.type()); 408 door.set_type(h_door.type());
409
410 if (h_door.has_location_name()) {
411 door.set_location_name(h_door.location_name());
412 }
413
414 if (h_door.has_double_letters()) {
415 door.set_double_letters(h_door.double_letters());
416 }
397 } 417 }
398 418
399 void ProcessConnectionsFile(std::filesystem::path path, 419 void ProcessConnectionsFile(std::filesystem::path path,
@@ -445,6 +465,11 @@ class DataPacker {
445 r_connection.set_required_door(door_id); 465 r_connection.set_required_door(door_id);
446 } 466 }
447 467
468 if (human_connection.has_roof_access()) {
469 f_connection.set_roof_access(human_connection.roof_access());
470 r_connection.set_roof_access(human_connection.roof_access());
471 }
472
448 container_.AddConnection(f_connection); 473 container_.AddConnection(f_connection);
449 if (!human_connection.oneway()) { 474 if (!human_connection.oneway()) {
450 container_.AddConnection(r_connection); 475 container_.AddConnection(r_connection);
@@ -528,6 +553,63 @@ class DataPacker {
528 } 553 }
529 } 554 }
530 555
556 void ProcessProgressivesFile(std::filesystem::path path) {
557 if (!std::filesystem::exists(path)) {
558 return;
559 }
560
561 auto h_progs = ReadMessageFromFile<HumanProgressives>(path.string());
562
563 for (const HumanProgressive& h_prog : h_progs.progressives()) {
564 ProcessProgressive(h_prog);
565 }
566 }
567
568 void ProcessProgressive(const HumanProgressive& h_prog) {
569 uint64_t prog_id = container_.FindOrAddProgressive(h_prog.name());
570 Progressive& prog = *container_.all_objects().mutable_progressives(prog_id);
571
572 for (const DoorIdentifier& di : h_prog.doors()) {
573 uint64_t door_id =
574 container_.FindOrAddDoor(di.map(), di.name(), std::nullopt);
575 prog.add_doors(door_id);
576 }
577 }
578
579 void ProcessDoorGroupsFile(std::filesystem::path path) {
580 if (!std::filesystem::exists(path)) {
581 return;
582 }
583
584 auto h_groups = ReadMessageFromFile<HumanDoorGroups>(path.string());
585
586 for (const HumanDoorGroup& h_group : h_groups.door_groups()) {
587 ProcessDoorGroup(h_group);
588 }
589 }
590
591 void ProcessDoorGroup(const HumanDoorGroup& h_group) {
592 uint64_t group_id = container_.FindOrAddDoorGroup(h_group.name());
593 DoorGroup& group = *container_.all_objects().mutable_door_groups(group_id);
594
595 group.set_type(h_group.type());
596
597 for (const DoorIdentifier& di : h_group.doors()) {
598 uint64_t door_id =
599 container_.FindOrAddDoor(di.map(), di.name(), std::nullopt);
600 group.add_doors(door_id);
601 }
602 }
603
604 void ProcessGlobalMetadataFile(std::filesystem::path path) {
605 if (!std::filesystem::exists(path)) {
606 return;
607 }
608
609 auto h_metadata = ReadMessageFromFile<HumanGlobalMetadata>(path.string());
610 container_.all_objects().set_version(h_metadata.version());
611 }
612
531 void ProcessIdsFile(std::filesystem::path path) { 613 void ProcessIdsFile(std::filesystem::path path) {
532 auto ids = ReadIdsFromYaml(path.string()); 614 auto ids = ReadIdsFromYaml(path.string());
533 615
@@ -552,6 +634,14 @@ class DataPacker {
552 .mutable_masteries(mastery_id) 634 .mutable_masteries(mastery_id)
553 ->set_ap_id(ap_id); 635 ->set_ap_id(ap_id);
554 } 636 }
637
638 for (const auto& [keyholder_name, ap_id] : room.keyholders()) {
639 uint64_t keyholder_id = container_.FindOrAddKeyholder(
640 map_name, room_name, keyholder_name, std::nullopt, std::nullopt);
641 container_.all_objects()
642 .mutable_keyholders(keyholder_id)
643 ->set_ap_id(ap_id);
644 }
555 } 645 }
556 } 646 }
557 647
@@ -569,6 +659,16 @@ class DataPacker {
569 uint64_t ending_id = container_.FindOrAddEnding(ending_name); 659 uint64_t ending_id = container_.FindOrAddEnding(ending_name);
570 container_.all_objects().mutable_endings(ending_id)->set_ap_id(ap_id); 660 container_.all_objects().mutable_endings(ending_id)->set_ap_id(ap_id);
571 } 661 }
662
663 for (const auto& [prog_name, ap_id] : ids.progressives()) {
664 uint64_t prog_id = container_.FindOrAddProgressive(prog_name);
665 container_.all_objects().mutable_progressives(prog_id)->set_ap_id(ap_id);
666 }
667
668 for (const auto& [group_name, ap_id] : ids.door_groups()) {
669 uint64_t group_id = container_.FindOrAddDoorGroup(group_name);
670 container_.all_objects().mutable_door_groups(group_id)->set_ap_id(ap_id);
671 }
572 } 672 }
573 673
574 std::string mapdir_; 674 std::string mapdir_;