This commit is contained in:
@@ -0,0 +1,205 @@
|
||||
/*
|
||||
* 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 <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();
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user