|
@@ -0,0 +1,113 @@
|
|
|
+/*
|
|
|
+ * This program is free software: you can redistribute it and/or modify it under
|
|
|
+ * the terms of the GNU General Public License as published by the Free Software
|
|
|
+ * Foundation, either version 3 of the License, or (at your option) any later
|
|
|
+ * version.
|
|
|
+ *
|
|
|
+ * This program is distributed in the hope that it will be useful, but WITHOUT
|
|
|
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
|
+ * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
|
+ * details.
|
|
|
+ *
|
|
|
+ * You should have received a copy of the GNU General Public License along with
|
|
|
+ * this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
+ */
|
|
|
+package com.l2jserver.gameserver.datatables;
|
|
|
+
|
|
|
+import java.util.HashMap;
|
|
|
+import java.util.Map;
|
|
|
+
|
|
|
+import org.w3c.dom.NamedNodeMap;
|
|
|
+import org.w3c.dom.Node;
|
|
|
+
|
|
|
+import com.l2jserver.gameserver.engines.DocumentParser;
|
|
|
+import com.l2jserver.gameserver.model.StatsSet;
|
|
|
+import com.l2jserver.gameserver.model.fishing.L2FishingMonster;
|
|
|
+
|
|
|
+/**
|
|
|
+ * This class holds the Fishing Monsters information.
|
|
|
+ * @author nonom
|
|
|
+ */
|
|
|
+public final class FishingMonstersData extends DocumentParser
|
|
|
+{
|
|
|
+ private static final Map<Integer, L2FishingMonster> _FishingMonsterData = new HashMap<>();
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Instantiates a new fishing monster data.
|
|
|
+ */
|
|
|
+ protected FishingMonstersData()
|
|
|
+ {
|
|
|
+ load();
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public void load()
|
|
|
+ {
|
|
|
+ _FishingMonsterData.clear();
|
|
|
+ parseDatapackFile("data/stats/fishing/FishingMonsters.xml");
|
|
|
+ _log.info(getClass().getSimpleName() + ": Loaded " + _FishingMonsterData.size() + " Fishing Monsters.");
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ protected void parseDocument()
|
|
|
+ {
|
|
|
+ NamedNodeMap attrs;
|
|
|
+ Node att;
|
|
|
+ L2FishingMonster fishingMonster;
|
|
|
+ StatsSet set;
|
|
|
+ for (Node n = getCurrentDocument().getFirstChild(); n != null; n = n.getNextSibling())
|
|
|
+ {
|
|
|
+ if ("list".equalsIgnoreCase(n.getNodeName()))
|
|
|
+ {
|
|
|
+ for (Node d = n.getFirstChild(); d != null; d = d.getNextSibling())
|
|
|
+ {
|
|
|
+ if ("fishingMonster".equalsIgnoreCase(d.getNodeName()))
|
|
|
+ {
|
|
|
+
|
|
|
+ attrs = d.getAttributes();
|
|
|
+
|
|
|
+ set = new StatsSet();
|
|
|
+ for (int i = 0; i < attrs.getLength(); i++)
|
|
|
+ {
|
|
|
+ att = attrs.item(i);
|
|
|
+ set.set(att.getNodeName(), att.getNodeValue());
|
|
|
+ }
|
|
|
+ fishingMonster = new L2FishingMonster(set);
|
|
|
+ _FishingMonsterData.put(fishingMonster.getFishingMonsterId(), fishingMonster);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Gets the fishing monster.
|
|
|
+ * @param lvl the fisher lvl
|
|
|
+ * @return A fishing monster by fisher lvl
|
|
|
+ */
|
|
|
+ public L2FishingMonster getFishingMonster(int lvl)
|
|
|
+ {
|
|
|
+ for (Map.Entry<Integer, L2FishingMonster> fishingMonster : _FishingMonsterData.entrySet())
|
|
|
+ {
|
|
|
+ if ((lvl >= fishingMonster.getValue().getUserMinLevel()) && (lvl <= fishingMonster.getValue().getUserMaxLevel()))
|
|
|
+ {
|
|
|
+ return fishingMonster.getValue();
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return null;
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Gets the single instance of FishingMonsterData.
|
|
|
+ * @return single instance of FishingMonsterData
|
|
|
+ */
|
|
|
+ public static FishingMonstersData getInstance()
|
|
|
+ {
|
|
|
+ return SingletonHolder._instance;
|
|
|
+ }
|
|
|
+
|
|
|
+ private static class SingletonHolder
|
|
|
+ {
|
|
|
+ protected static final FishingMonstersData _instance = new FishingMonstersData();
|
|
|
+ }
|
|
|
+}
|