/* * Copyright (C) 2004-2014 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 . */ package com.l2jserver.gameserver.datatables; import java.sql.Connection; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.util.HashMap; import java.util.Map; import java.util.logging.Level; import java.util.logging.Logger; import com.l2jserver.Config; import com.l2jserver.L2DatabaseFactory; import com.l2jserver.gameserver.model.holders.ItemHolder; import com.l2jserver.gameserver.model.holders.SkillHolder; public class NpcBufferTable { private static final Logger _log = Logger.getLogger(NpcBufferTable.class.getName()); private final Map _buffers = new HashMap<>(); public static class NpcBufferData { private final SkillHolder _skill; private final ItemHolder _fee; protected NpcBufferData(int skillId, int skillLevel, int feeId, int feeAmount) { _skill = new SkillHolder(skillId, skillLevel); _fee = new ItemHolder(feeId, feeAmount); } public SkillHolder getSkill() { return _skill; } public ItemHolder getFee() { return _fee; } } private static class NpcBufferSkills { private final int _npcId; private final Map _skills = new HashMap<>(); protected NpcBufferSkills(int npcId) { _npcId = npcId; } public void addSkill(int skillId, int skillLevel, int skillFeeId, int skillFeeAmount, int buffGroup) { _skills.put(buffGroup, new NpcBufferData(skillId, skillLevel, skillFeeId, skillFeeAmount)); } public NpcBufferData getSkillGroupInfo(int buffGroup) { return _skills.get(buffGroup); } @SuppressWarnings("unused") public int getNpcId() { return _npcId; } } protected NpcBufferTable() { int skillCount = 0; try (Connection con = L2DatabaseFactory.getInstance().getConnection(); Statement s = con.createStatement(); ResultSet rset = s.executeQuery("SELECT `npc_id`,`skill_id`,`skill_level`,`skill_fee_id`,`skill_fee_amount`,`buff_group` FROM `npc_buffer` ORDER BY `npc_id` ASC")) { int lastNpcId = 0; NpcBufferSkills skills = null; while (rset.next()) { int npcId = rset.getInt("npc_id"); int skillId = rset.getInt("skill_id"); int skillLevel = rset.getInt("skill_level"); int skillFeeId = rset.getInt("skill_fee_id"); int skillFeeAmount = rset.getInt("skill_fee_amount"); int buffGroup = rset.getInt("buff_group"); if (npcId != lastNpcId) { if (lastNpcId != 0) { _buffers.put(lastNpcId, skills); } skills = new NpcBufferSkills(npcId); skills.addSkill(skillId, skillLevel, skillFeeId, skillFeeAmount, buffGroup); } else if (skills != null) { skills.addSkill(skillId, skillLevel, skillFeeId, skillFeeAmount, buffGroup); } lastNpcId = npcId; skillCount++; } if (lastNpcId != 0) { _buffers.put(lastNpcId, skills); } } catch (SQLException e) { _log.log(Level.SEVERE, getClass().getSimpleName() + ": Error reading npc_buffer table: " + e.getMessage(), e); } if (Config.CUSTOM_NPCBUFFER_TABLES) { try (Connection con = L2DatabaseFactory.getInstance().getConnection(); Statement s = con.createStatement(); ResultSet rset = s.executeQuery("SELECT `npc_id`,`skill_id`,`skill_level`,`skill_fee_id`,`skill_fee_amount`,`buff_group` FROM `custom_npc_buffer` ORDER BY `npc_id` ASC")) { int lastNpcId = 0; NpcBufferSkills skills = null; while (rset.next()) { int npcId = rset.getInt("npc_id"); int skillId = rset.getInt("skill_id"); int skillLevel = rset.getInt("skill_level"); int skillFeeId = rset.getInt("skill_fee_id"); int skillFeeAmount = rset.getInt("skill_fee_amount"); int buffGroup = rset.getInt("buff_group"); if (npcId != lastNpcId) { if (lastNpcId != 0) { _buffers.put(lastNpcId, skills); } skills = new NpcBufferSkills(npcId); skills.addSkill(skillId, skillLevel, skillFeeId, skillFeeAmount, buffGroup); } else if (skills != null) { skills.addSkill(skillId, skillLevel, skillFeeId, skillFeeAmount, buffGroup); } lastNpcId = npcId; skillCount++; } if (lastNpcId != 0) { _buffers.put(lastNpcId, skills); } } catch (SQLException e) { _log.log(Level.SEVERE, getClass().getSimpleName() + ": Error reading custom_npc_buffer table: " + e.getMessage(), e); } } _log.info(getClass().getSimpleName() + ": Loaded " + _buffers.size() + " buffers and " + skillCount + " skills."); } public NpcBufferData getSkillInfo(int npcId, int buffGroup) { final NpcBufferSkills skills = _buffers.get(npcId); if (skills != null) { return skills.getSkillGroupInfo(buffGroup); } return null; } public static NpcBufferTable getInstance() { return SingletonHolder._instance; } private static class SingletonHolder { protected static final NpcBufferTable _instance = new NpcBufferTable(); } }