205 lines
5.8 KiB
Java
205 lines
5.8 KiB
Java
/*
|
|
* 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.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 LOGGER = Logger.getLogger(NpcBufferTable.class.getName());
|
|
|
|
private final Map<Integer, NpcBufferSkills> _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<Integer, NpcBufferData> _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)
|
|
{
|
|
LOGGER.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)
|
|
{
|
|
LOGGER.log(Level.SEVERE, getClass().getSimpleName() + ": Error reading custom_npc_buffer table: " + e.getMessage(), e);
|
|
}
|
|
}
|
|
LOGGER.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();
|
|
}
|
|
} |