123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180 |
- /*
- * Copyright (C) 2004-2015 L2J Server
- *
- * This file is part of L2J Server.
- *
- * L2J Server 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.
- *
- * L2J Server 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.data.xml.impl;
- import java.util.ArrayList;
- import java.util.HashMap;
- import java.util.List;
- import java.util.Map;
- import org.w3c.dom.Document;
- import org.w3c.dom.NamedNodeMap;
- import org.w3c.dom.Node;
- import com.l2jserver.gameserver.model.StatsSet;
- import com.l2jserver.gameserver.model.base.ClassId;
- import com.l2jserver.gameserver.model.items.L2Henna;
- import com.l2jserver.util.data.xml.IXmlReader;
- /**
- * This class holds the henna related information.<br>
- * Cost and required amount to add the henna to the player.<br>
- * Cost and retrieved amount for removing the henna from the player.<br>
- * Allowed classes to wear each henna.
- * @author Zoey76
- */
- public final class HennaData implements IXmlReader
- {
- private final Map<Integer, L2Henna> _hennaList = new HashMap<>();
-
- /**
- * Instantiates a new henna data.
- */
- protected HennaData()
- {
- load();
- }
-
- @Override
- public void load()
- {
- _hennaList.clear();
- parseDatapackFile("data/stats/hennaList.xml");
- LOGGER.info("{}: Loaded {} Henna data.", getClass().getSimpleName(), _hennaList.size());
- }
-
- @Override
- public void parseDocument(Document doc)
- {
- for (Node n = doc.getFirstChild(); n != null; n = n.getNextSibling())
- {
- if ("list".equals(n.getNodeName()))
- {
- for (Node d = n.getFirstChild(); d != null; d = d.getNextSibling())
- {
- if ("henna".equals(d.getNodeName()))
- {
- parseHenna(d);
- }
- }
- }
- }
- }
-
- /**
- * Parses the henna.
- * @param d the d
- */
- private void parseHenna(Node d)
- {
- final StatsSet set = new StatsSet();
- final List<ClassId> wearClassIds = new ArrayList<>();
- NamedNodeMap attrs = d.getAttributes();
- Node attr;
- for (int i = 0; i < attrs.getLength(); i++)
- {
- attr = attrs.item(i);
- set.set(attr.getNodeName(), attr.getNodeValue());
- }
-
- for (Node c = d.getFirstChild(); c != null; c = c.getNextSibling())
- {
- final String name = c.getNodeName();
- attrs = c.getAttributes();
- switch (name)
- {
- case "stats":
- {
- for (int i = 0; i < attrs.getLength(); i++)
- {
- attr = attrs.item(i);
- set.set(attr.getNodeName(), attr.getNodeValue());
- }
- break;
- }
- case "wear":
- {
- attr = attrs.getNamedItem("count");
- set.set("wear_count", attr.getNodeValue());
- attr = attrs.getNamedItem("fee");
- set.set("wear_fee", attr.getNodeValue());
- break;
- }
- case "cancel":
- {
- attr = attrs.getNamedItem("count");
- set.set("cancel_count", attr.getNodeValue());
- attr = attrs.getNamedItem("fee");
- set.set("cancel_fee", attr.getNodeValue());
- break;
- }
- case "classId":
- {
- wearClassIds.add(ClassId.getClassId(Integer.parseInt(c.getTextContent())));
- break;
- }
- }
- }
- final L2Henna henna = new L2Henna(set);
- henna.setWearClassIds(wearClassIds);
- _hennaList.put(henna.getDyeId(), henna);
- }
-
- /**
- * Gets the henna.
- * @param id of the dye.
- * @return the dye with that id.
- */
- public L2Henna getHenna(int id)
- {
- return _hennaList.get(id);
- }
-
- /**
- * Gets the henna list.
- * @param classId the player's class Id.
- * @return the list with all the allowed dyes.
- */
- public List<L2Henna> getHennaList(ClassId classId)
- {
- final List<L2Henna> list = new ArrayList<>();
- for (L2Henna henna : _hennaList.values())
- {
- if (henna.isAllowedClass(classId))
- {
- list.add(henna);
- }
- }
- return list;
- }
-
- /**
- * Gets the single instance of HennaData.
- * @return single instance of HennaData
- */
- public static HennaData getInstance()
- {
- return SingletonHolder._instance;
- }
-
- private static class SingletonHolder
- {
- protected static final HennaData _instance = new HennaData();
- }
- }
|