/* * 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 . */ package com.l2jserver.gameserver.engines; import gnu.trove.map.hash.TIntObjectHashMap; import java.io.File; import java.util.List; import java.util.logging.Logger; import javolution.util.FastList; import com.l2jserver.Config; import com.l2jserver.gameserver.datatables.SkillTable; import com.l2jserver.gameserver.engines.items.DocumentItem; import com.l2jserver.gameserver.engines.skills.DocumentSkill; import com.l2jserver.gameserver.model.items.L2Item; import com.l2jserver.gameserver.model.skills.L2Skill; import com.l2jserver.util.file.filter.XMLFilter; /** * @author mkizub */ public class DocumentEngine { private static final Logger _log = Logger.getLogger(DocumentEngine.class.getName()); private final List _itemFiles = new FastList(); private final List _skillFiles = new FastList(); public static DocumentEngine getInstance() { return SingletonHolder._instance; } private DocumentEngine() { hashFiles("data/stats/items", _itemFiles); if (Config.CUSTOM_ITEMS_LOAD) hashFiles("data/stats/items/custom", _itemFiles); hashFiles("data/stats/skills", _skillFiles); if (Config.CUSTOM_SKILLS_LOAD) hashFiles("data/stats/skills/custom", _skillFiles); } private void hashFiles(String dirname, List hash) { File dir = new File(Config.DATAPACK_ROOT, dirname); if (!dir.exists()) { _log.warning("Dir " + dir.getAbsolutePath() + " not exists"); return; } File[] files = dir.listFiles(new XMLFilter()); for (File f : files) { hash.add(f); } } public List loadSkills(File file) { if (file == null) { _log.warning("Skill file not found."); return null; } DocumentSkill doc = new DocumentSkill(file); doc.parse(); return doc.getSkills(); } public void loadAllSkills(final TIntObjectHashMap allSkills) { int count = 0; for (File file : _skillFiles) { List s = loadSkills(file); if (s == null) { continue; } for (L2Skill skill : s) { allSkills.put(SkillTable.getSkillHashCode(skill), skill); count++; } } _log.info(getClass().getSimpleName() + ": Loaded " + count + " Skill templates from XML files."); } /** * Return created items * @return List of {@link L2Item} */ public List loadItems() { List list = new FastList(); for (File f : _itemFiles) { DocumentItem document = new DocumentItem(f); document.parse(); list.addAll(document.getItemList()); } return list; } @SuppressWarnings("synthetic-access") private static class SingletonHolder { protected static final DocumentEngine _instance = new DocumentEngine(); } }