From a8f38ad9951914de574b334615e0a43809e81dca Mon Sep 17 00:00:00 2001 From: Melledy <52122272+Melledy@users.noreply.github.com> Date: Wed, 18 May 2022 15:54:55 -0700 Subject: [PATCH] Move chest rewards to new data format --- .../emu/grasscutter/game/world/WorldDataManager.java | 9 ++++++--- .../main/resources/defaults/data}/ChestReward.json | 0 2 files changed, 6 insertions(+), 3 deletions(-) rename {data => src/main/resources/defaults/data}/ChestReward.json (100%) diff --git a/src/main/java/emu/grasscutter/game/world/WorldDataManager.java b/src/main/java/emu/grasscutter/game/world/WorldDataManager.java index c7466880b..3809dce6d 100644 --- a/src/main/java/emu/grasscutter/game/world/WorldDataManager.java +++ b/src/main/java/emu/grasscutter/game/world/WorldDataManager.java @@ -2,8 +2,11 @@ package emu.grasscutter.game.world; import com.google.gson.reflect.TypeToken; import emu.grasscutter.Grasscutter; +import emu.grasscutter.data.DataLoader; import emu.grasscutter.server.game.GameServer; +import java.io.InputStream; +import java.io.InputStreamReader; import java.nio.file.Files; import java.nio.file.Path; import java.util.HashMap; @@ -23,13 +26,13 @@ public class WorldDataManager { } public synchronized void load(){ - try { + try(InputStream is = DataLoader.load("ChestReward.json", false); InputStreamReader isr = new InputStreamReader(is)) { List chestReward = Grasscutter.getGsonFactory().fromJson( - Files.readString(Path.of(DATA("ChestReward.json"))), + isr, TypeToken.getParameterized(List.class, ChestReward.class).getType()); + chestReward.forEach(reward -> reward.getObjNames().forEach(name -> chestRewardMap.put(name, reward))); - } catch (Exception e) { Grasscutter.getLogger().error("Unable to load chest reward config.", e); } diff --git a/data/ChestReward.json b/src/main/resources/defaults/data/ChestReward.json similarity index 100% rename from data/ChestReward.json rename to src/main/resources/defaults/data/ChestReward.json