diff options
author | Star Rauchenberger <fefferburbia@gmail.com> | 2023-12-12 14:48:42 -0500 |
---|---|---|
committer | Star Rauchenberger <fefferburbia@gmail.com> | 2023-12-12 14:48:42 -0500 |
commit | 1e34d9d675a50f1ccc1a43d3c2fed94ba3e5351b (patch) | |
tree | 71be5a368ff26a859dfa2a84076b76aba2a14497 | |
parent | fa2a7d48ae0f357e5b87619d0727868e54c34258 (diff) | |
download | lingo-randomizer-1e34d9d675a50f1ccc1a43d3c2fed94ba3e5351b.tar.gz lingo-randomizer-1e34d9d675a50f1ccc1a43d3c2fed94ba3e5351b.tar.bz2 lingo-randomizer-1e34d9d675a50f1ccc1a43d3c2fed94ba3e5351b.zip |
Removed some trivial puzzles
-rw-r--r-- | generator/CMakeLists.txt | 2 | ||||
-rw-r--r-- | generator/generator.cpp | 13 |
2 files changed, 14 insertions, 1 deletions
diff --git a/generator/CMakeLists.txt b/generator/CMakeLists.txt index 3b66720..fb5dc3c 100644 --- a/generator/CMakeLists.txt +++ b/generator/CMakeLists.txt | |||
@@ -3,7 +3,7 @@ project (generator) | |||
3 | 3 | ||
4 | add_subdirectory(vendor/fmt) | 4 | add_subdirectory(vendor/fmt) |
5 | 5 | ||
6 | include_directories(../vendor/hkutil vendor/fmt/include) | 6 | include_directories(vendor/hkutil vendor/fmt/include) |
7 | 7 | ||
8 | add_executable(generator generator.cpp main.cpp) | 8 | add_executable(generator generator.cpp main.cpp) |
9 | set_property(TARGET generator PROPERTY CXX_STANDARD 17) | 9 | set_property(TARGET generator PROPERTY CXX_STANDARD 17) |
diff --git a/generator/generator.cpp b/generator/generator.cpp index 49018c8..0639492 100644 --- a/generator/generator.cpp +++ b/generator/generator.cpp | |||
@@ -374,6 +374,10 @@ void generator::run() { | |||
374 | for (size_t f_id2 : all_forms) { | 374 | for (size_t f_id2 : all_forms) { |
375 | if (f_id1 != f_id2) { | 375 | if (f_id1 != f_id2) { |
376 | Form& form = forms_.at(f_id1); | 376 | Form& form = forms_.at(f_id1); |
377 | Form& form2 = forms_.at(f_id2); | ||
378 | if (form.anagram_set_id == form2.anagram_set_id) { | ||
379 | continue; | ||
380 | } | ||
377 | form.puzzles[kYellowTop].insert(f_id2); | 381 | form.puzzles[kYellowTop].insert(f_id2); |
378 | } | 382 | } |
379 | } | 383 | } |
@@ -427,6 +431,9 @@ void generator::run() { | |||
427 | for (size_t f_id1 : pronunciation.form_ids) { | 431 | for (size_t f_id1 : pronunciation.form_ids) { |
428 | for (size_t f_id2 : all_forms) { | 432 | for (size_t f_id2 : all_forms) { |
429 | Form& form = forms_.at(f_id1); | 433 | Form& form = forms_.at(f_id1); |
434 | if (form.reverse_form_id == f_id2) { | ||
435 | continue; | ||
436 | } | ||
430 | form.puzzles[kBlackTop].insert(f_id2); | 437 | form.puzzles[kBlackTop].insert(f_id2); |
431 | } | 438 | } |
432 | } | 439 | } |
@@ -573,6 +580,12 @@ void generator::run() { | |||
573 | for (size_t mero_form_id : merophone.form_ids) { | 580 | for (size_t mero_form_id : merophone.form_ids) { |
574 | Form& mero_form = forms_.at(mero_form_id); | 581 | Form& mero_form = forms_.at(mero_form_id); |
575 | 582 | ||
583 | if (holo_form.text.find(mero_form.text) != | ||
584 | std::string::npos) { | ||
585 | // We don't want top puzzles that are also middle puzzles. | ||
586 | continue; | ||
587 | } | ||
588 | |||
576 | bool word_overlap = false; | 589 | bool word_overlap = false; |
577 | for (size_t holo_word_id : holo_form.word_ids) { | 590 | for (size_t holo_word_id : holo_form.word_ids) { |
578 | for (size_t mero_word_id : mero_form.word_ids) { | 591 | for (size_t mero_word_id : mero_form.word_ids) { |