/*
* 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.datatables;
import gnu.trove.map.hash.TIntIntHashMap;
import gnu.trove.map.hash.TIntObjectHashMap;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.logging.Level;
import java.util.logging.Logger;
import com.l2jserver.Config;
import com.l2jserver.L2DatabaseFactory;
public class NpcBufferTable
{
protected static Logger _log = Logger.getLogger(NpcBufferTable.class.getName());
private TIntObjectHashMap _buffers = new TIntObjectHashMap();
private static class NpcBufferSkills
{
private TIntIntHashMap _skillId = new TIntIntHashMap();
private TIntIntHashMap _skillLevels = new TIntIntHashMap();
private TIntIntHashMap _skillFeeIds = new TIntIntHashMap();
private TIntIntHashMap _skillFeeAmounts = new TIntIntHashMap();
public NpcBufferSkills(int npcId)
{
}
public void addSkill(int skillId, int skillLevel, int skillFeeId, int skillFeeAmount,
int buffGroup)
{
_skillId.put(buffGroup, skillId);
_skillLevels.put(buffGroup, skillLevel);
_skillFeeIds.put(buffGroup, skillFeeId);
_skillFeeAmounts.put(buffGroup, skillFeeAmount);
}
public int[] getSkillGroupInfo(int buffGroup)
{
Integer skillId = _skillId.get(buffGroup);
Integer skillLevel = _skillLevels.get(buffGroup);
Integer skillFeeId = _skillFeeIds.get(buffGroup);
Integer skillFeeAmount = _skillFeeAmounts.get(buffGroup);
if (skillId == null || skillLevel == null || skillFeeId == null
|| skillFeeAmount == null)
return null;
return new int[] { skillId, skillLevel, skillFeeId, skillFeeAmount };
}
}
private NpcBufferTable()
{
Connection con = null;
int skillCount = 0;
try
{
try
{
con = L2DatabaseFactory.getInstance().getConnection();
PreparedStatement statement = con.prepareStatement("SELECT `npc_id`,`skill_id`,`skill_level`,`skill_fee_id`,`skill_fee_amount`,`buff_group` FROM `npc_buffer` ORDER BY `npc_id` ASC");
ResultSet rset = statement.executeQuery();
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
skills.addSkill(skillId, skillLevel, skillFeeId, skillFeeAmount, buffGroup);
lastNpcId = npcId;
skillCount++;
}
if (lastNpcId != 0)
_buffers.put(lastNpcId, skills);
rset.close();
statement.close();
}
catch (Exception e)
{
_log.log(Level.SEVERE, "NpcBufferTable: Error reading npc_buffer table: " + e.getMessage(), e);
}
if (Config.CUSTOM_NPCBUFFER_TABLES)
{
try
{
PreparedStatement statement = con.prepareStatement("SELECT `npc_id`,`skill_id`,`skill_level`,`skill_fee_id`,`skill_fee_amount`,`buff_group` FROM `custom_npc_buffer` ORDER BY `npc_id` ASC");
ResultSet rset = statement.executeQuery();
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
skills.addSkill(skillId, skillLevel, skillFeeId, skillFeeAmount, buffGroup);
lastNpcId = npcId;
skillCount++;
}
if (lastNpcId != 0)
_buffers.put(lastNpcId, skills);
rset.close();
statement.close();
}
catch (Exception e)
{
_log.log(Level.SEVERE, "NpcBufferTable: Error reading custom_npc_buffer table: " + e.getMessage(), e);
}
}
}
finally
{
L2DatabaseFactory.close(con);
}
_log.info("NpcBufferSkillIdsTable: Loaded " + _buffers.size() + " buffers and " + skillCount + " skills.");
}
public static NpcBufferTable getInstance()
{
return SingletonHolder._instance;
}
public int[] getSkillInfo(int npcId, int buffGroup)
{
NpcBufferSkills skills = _buffers.get(npcId);
if (skills == null)
return null;
return skills.getSkillGroupInfo(buffGroup);
}
@SuppressWarnings("synthetic-access")
private static class SingletonHolder
{
protected static final NpcBufferTable _instance = new NpcBufferTable();
}
}