/* * This file is part of the L2J Mobius project. * * 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.l2jmobius.gameserver.engines; import java.io.File; import java.util.Collections; import java.util.LinkedList; import java.util.List; import java.util.Map; import java.util.logging.Logger; import com.l2jmobius.Config; import com.l2jmobius.commons.util.file.filter.XMLFilter; import com.l2jmobius.gameserver.data.xml.impl.SkillData; import com.l2jmobius.gameserver.engines.items.DocumentItem; import com.l2jmobius.gameserver.model.items.L2Item; import com.l2jmobius.gameserver.model.skills.Skill; /** * @author mkizub */ public class DocumentEngine { private static final Logger LOGGER = Logger.getLogger(DocumentEngine.class.getName()); private final List _itemFiles = new LinkedList<>(); private final List _skillFiles = new LinkedList<>(); public static DocumentEngine getInstance() { return SingletonHolder._instance; } protected 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) { final File dir = new File(Config.DATAPACK_ROOT, dirname); if (!dir.exists()) { LOGGER.warning("Dir " + dir.getAbsolutePath() + " not exists"); return; } final File[] files = dir.listFiles(new XMLFilter()); for (File f : files) { hash.add(f); } } public List loadSkills(File file) { if (file == null) { LOGGER.warning("Skill file not found."); return null; } return Collections.emptyList(); } public void loadAllSkills(Map allSkills) { int count = 0; for (File file : _skillFiles) { final List s = loadSkills(file); if (s == null) { continue; } for (Skill skill : s) { allSkills.put(SkillData.getSkillHashCode(skill), skill); count++; } } LOGGER.info("Loaded " + count + " Skill templates from XML files."); } /** * Return created items * @return List of {@link L2Item} */ public List loadItems() { final List list = new LinkedList<>(); for (File f : _itemFiles) { final DocumentItem document = new DocumentItem(f); document.parse(); list.addAll(document.getItemList()); } return list; } private static class SingletonHolder { protected static final DocumentEngine _instance = new DocumentEngine(); } }