diff options
author | ExternalTime <84183548+ExternalTime@users.noreply.github.com> | 2021-09-19 18:10:00 +0200 |
---|---|---|
committer | ExternalTime <84183548+ExternalTime@users.noreply.github.com> | 2021-09-19 18:22:25 +0200 |
commit | a0feb55973fc3eb4be4ae0ae2c76c88c9cd9f200 (patch) | |
tree | d9898d2c480d4ee002b35e18b54178ca327c99cf /src/main/java/me/xmrvizzy/skyblocker/skyblock/dungeon/Trivia.java | |
parent | 83747a8bb2553aef5acc5988727de752bac55ffc (diff) | |
download | Skyblocker-a0feb55973fc3eb4be4ae0ae2c76c88c9cd9f200.tar.gz Skyblocker-a0feb55973fc3eb4be4ae0ae2c76c88c9cd9f200.tar.bz2 Skyblocker-a0feb55973fc3eb4be4ae0ae2c76c88c9cd9f200.zip |
Rewrote Trivia solver to use the new interface
Diffstat (limited to 'src/main/java/me/xmrvizzy/skyblocker/skyblock/dungeon/Trivia.java')
-rw-r--r-- | src/main/java/me/xmrvizzy/skyblocker/skyblock/dungeon/Trivia.java | 89 |
1 files changed, 89 insertions, 0 deletions
diff --git a/src/main/java/me/xmrvizzy/skyblocker/skyblock/dungeon/Trivia.java b/src/main/java/me/xmrvizzy/skyblocker/skyblock/dungeon/Trivia.java new file mode 100644 index 00000000..3d3e5c28 --- /dev/null +++ b/src/main/java/me/xmrvizzy/skyblocker/skyblock/dungeon/Trivia.java @@ -0,0 +1,89 @@ +package me.xmrvizzy.skyblocker.skyblock.dungeon; + +import me.xmrvizzy.skyblocker.chat.ChatListener; +import me.xmrvizzy.skyblocker.config.SkyblockerConfig; +import net.minecraft.client.MinecraftClient; +import net.minecraft.client.network.ClientPlayerEntity; +import net.minecraft.text.LiteralText; +import net.minecraft.util.Formatting; + +import java.util.*; + +public class Trivia extends ChatListener { + private static final Map<String, String[]> answers; + private List<String> solutions = Collections.emptyList(); + + public Trivia() { + super("^ +(?:([A-Za-z' ]*\\?)|§6 ([ⓐⓑⓒ]) §a([a-zA-Z0-9 ]+))$"); + } + + @Override + public boolean isEnabled() { + return SkyblockerConfig.get().locations.dungeons.solveTrivia; + } + + @Override + public boolean onMessage(String[] groups) { + if (groups[3] != null) { + if (!solutions.contains(groups[3])) { + ClientPlayerEntity player = MinecraftClient.getInstance().player; + assert player != null; + MinecraftClient.getInstance().player.sendMessage(new LiteralText(" " + Formatting.GOLD + groups[2] + Formatting.RED + " " + groups[3]), false); + return true; + } + } else + updateSolutions(groups[1]); + return false; + } + + private void updateSolutions(String question) { + if (question.equals("What SkyBlock year is it?")) { + long currentTime = System.currentTimeMillis() / 1000L; + long diff = currentTime - 1560276000; + int year = (int) (diff / 446400 + 1); + solutions = Collections.singletonList("Year " + year); + } else { + solutions = Arrays.asList(answers.get(question)); + } + } + + static { + answers = new HashMap<>(); + answers.put("What is the status of The Watcher?", new String[]{"Stalker"}); + answers.put("What is the status of Bonzo?", new String[]{"New Necromancer"}); + answers.put("What is the status of Scarf?", new String[]{"Apprentice Necromancer"}); + answers.put("What is the status of The Professor?", new String[]{"Professor"}); + answers.put("What is the status of Thorn?", new String[]{"Shaman Necromancer"}); + answers.put("What is the status of Livid?", new String[]{"Master Necromancer"}); + answers.put("What is the status of Sadan?", new String[]{"Necromancer Lord"}); + answers.put("What is the status of Maxor?", new String[]{"Young Wither"}); + answers.put("What is the status of Goldor?", new String[]{"Wither Soldier"}); + answers.put("What is the status of Storm?", new String[]{"Elementalist"}); + answers.put("What is the status of Necron?", new String[]{"Wither Lord"}); + answers.put("How many total Fairy Souls are there?", new String[]{"227 Fairy Souls"}); + answers.put("How many Fairy Souls are there in Spider's Den?", new String[]{"19 Fairy Souls"}); + answers.put("How many Fairy Souls are there in The End?", new String[]{"12 Fairy Souls"}); + answers.put("How many Fairy Souls are there in The Barn?", new String[]{"7 Fairy Souls"}); + answers.put("How many Fairy Souls are there in Mushroom Desert?", new String[]{"13 Fairy Souls"}); + answers.put("How many Fairy Souls are there in Blazing Fortress?", new String[]{"19 Fairy Souls"}); + answers.put("How many Fairy Souls are there in The Park?", new String[]{"11 Fairy Souls"}); + answers.put("How many Fairy Souls are there in Jerry's Workshop?", new String[]{"5 Fairy Souls"}); + answers.put("How many Fairy Souls are there in Hub?", new String[]{"79 Fairy Souls"}); + answers.put("How many Fairy Souls are there in The Hub?", new String[]{"79 Fairy Souls"}); + answers.put("How many Fairy Souls are there in Deep Caverns?", new String[]{"21 Fairy Souls"}); + answers.put("How many Fairy Souls are there in Gold Mine?", new String[]{"12 Fairy Souls"}); + answers.put("How many Fairy Souls are there in Dungeon Hub?", new String[]{"7 Fairy Souls"}); + answers.put("Which brother is on the Spider's Den?", new String[]{"Rick"}); + answers.put("What is the name of Rick's brother?", new String[]{"Pat"}); + answers.put("What is the name of the Painter in the Hub?", new String[]{"Marco"}); + answers.put("What is the name of the person that upgrades pets?", new String[]{"Kat"}); + answers.put("What is the name of the lady of the Nether?", new String[]{"Elle"}); + answers.put("Which villager in the Village gives you a Rogue Sword?", new String[]{"Jamie"}); + answers.put("How many unique minions are there?", new String[]{"53 Minions"}); + answers.put("Which of these enemies does not spawn in the Spider's Den?", new String[]{"Zombie Spider", "Cave Spider", "Wither Skeleton", + "Dashing Spooder", "Broodfather", "Night Spider"}); + answers.put("Which of these monsters only spawns at night?", new String[]{"Zombie Villager", "Ghast"}); + answers.put("Which of these is not a dragon in The End?", new String[]{"Zoomer Dragon", "Weak Dragon", "Stonk Dragon", "Holy Dragon", "Boomer Dragon", + "Booger Dragon", "Older Dragon", "Elder Dragon", "Stable Dragon", "Professor Dragon"}); + } +} |