Dropped CreateItemRandom effect.

This commit is contained in:
MobiusDev
2019-02-27 12:09:40 +00:00
parent 5473448f56
commit a5e6ee19d1
131 changed files with 34281 additions and 17532 deletions

View File

@@ -90,7 +90,6 @@ public final class EffectMasterHandler
EffectHandler.getInstance().registerHandler("CpHealOverTime", CpHealOverTime::new);
EffectHandler.getInstance().registerHandler("CpHealPercent", CpHealPercent::new);
EffectHandler.getInstance().registerHandler("CpRegen", CpRegen::new);
EffectHandler.getInstance().registerHandler("CreateItemRandom", CreateItemRandom::new);
EffectHandler.getInstance().registerHandler("CriticalDamage", CriticalDamage::new);
EffectHandler.getInstance().registerHandler("CriticalDamagePosition", CriticalDamagePosition::new);
EffectHandler.getInstance().registerHandler("CriticalRate", CriticalRate::new);

View File

@@ -1,81 +0,0 @@
/*
* 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 <http://www.gnu.org/licenses/>.
*/
package handlers.effecthandlers;
import java.util.logging.Logger;
import com.l2jmobius.commons.util.Rnd;
import com.l2jmobius.gameserver.model.StatsSet;
import com.l2jmobius.gameserver.model.actor.L2Character;
import com.l2jmobius.gameserver.model.actor.instance.L2PcInstance;
import com.l2jmobius.gameserver.model.effects.AbstractEffect;
import com.l2jmobius.gameserver.model.holders.ItemChanceHolder;
import com.l2jmobius.gameserver.model.items.instance.L2ItemInstance;
import com.l2jmobius.gameserver.model.skills.Skill;
import com.l2jmobius.gameserver.network.SystemMessageId;
/**
* @author UnAfraid
*/
public class CreateItemRandom extends AbstractEffect
{
private static final Logger LOGGER = Logger.getLogger(CreateItemRandom.class.getName());
public CreateItemRandom(StatsSet params)
{
}
@Override
public boolean isInstant()
{
return Boolean.TRUE;
}
@Override
public void instant(L2Character effector, L2Character effected, Skill skill, L2ItemInstance item)
{
final L2PcInstance player = effected.getActingPlayer();
if (player == null)
{
return;
}
else if (item == null)
{
LOGGER.warning("" + player + " Attempting to cast skill: " + skill + " without item defined!");
return;
}
else if (item.getItem().getCreateItems().isEmpty())
{
LOGGER.warning("" + player + " Attempting to cast skill: " + skill + " with item " + item + " without createItems defined!");
return;
}
double cumulativeChance = 0;
final int random = Rnd.get(100);
for (ItemChanceHolder holder : item.getItem().getCreateItems())
{
cumulativeChance += holder.getChance();
if (random < cumulativeChance)
{
player.addItem("CreateItems", holder.getId(), holder.getCount(), player, true);
return;
}
}
player.sendPacket(SystemMessageId.THERE_WAS_NOTHING_FOUND_INSIDE);
}
}

View File

@@ -59,7 +59,6 @@ CpHealOverTime: Increases current CP by a given amount over time.
CpHealPercent: Increases current CP by a given percentage amount.
Cp: Increases current CP by a static amount.
CpRegen: CP Regeneration stat.
CreateItemRandom: Creates an item randomly from a given list. All extractable items with chances to get different items are using this effect.
CriticalDamage: Critical Damage stat.
CriticalDamagePosition: Critical Damage depending on position stat.
CriticalRate: Critical Rate stat.

View File

@@ -18,12 +18,6 @@
</xs:sequence>
</xs:complexType>
<xs:complexType name="createItemsType">
<xs:sequence>
<xs:element name="item" type="createItemType" maxOccurs="unbounded" />
</xs:sequence>
</xs:complexType>
<xs:complexType name="skillType">
<xs:attribute name="id" type="xs:positiveInteger" use="required" />
<xs:attribute name="level" type="xs:positiveInteger" use="required" />
@@ -300,7 +294,6 @@
<xs:element name="set" maxOccurs="unbounded" minOccurs="1" type="setType" />
<xs:element name="unequip_skills" minOccurs="0" type="skillsType" />
<xs:element name="capsuled_items" minOccurs="0" type="capsuledItemsType" />
<xs:element name="createItems" minOccurs="0" type="createItemsType" />
<xs:element name="cond" maxOccurs="2" minOccurs="0" type="condType" />
<xs:element name="skills" minOccurs="0" type="skillsType" />
<xs:element name="stats" maxOccurs="1" minOccurs="0" type="forType" />

View File

@@ -33,7 +33,6 @@ import com.l2jmobius.gameserver.enums.ItemSkillType;
import com.l2jmobius.gameserver.model.L2ExtractableProduct;
import com.l2jmobius.gameserver.model.StatsSet;
import com.l2jmobius.gameserver.model.conditions.Condition;
import com.l2jmobius.gameserver.model.holders.ItemChanceHolder;
import com.l2jmobius.gameserver.model.holders.ItemSkillHolder;
import com.l2jmobius.gameserver.model.items.L2Item;
import com.l2jmobius.gameserver.model.stats.Stats;
@@ -182,20 +181,6 @@ public final class DocumentItem extends DocumentBase implements IGameXmlReader
}
}
}
else if ("createItems".equalsIgnoreCase(n.getNodeName()))
{
makeItem();
for (Node b = n.getFirstChild(); b != null; b = b.getNextSibling())
{
if ("item".equals(b.getNodeName()))
{
final int id = parseInteger(b.getAttributes(), "id");
final int count = parseInteger(b.getAttributes(), "count");
final double chance = parseDouble(b.getAttributes(), "chance");
_currentItem.item.addCreateItem(new ItemChanceHolder(id, chance, count));
}
}
}
else if ("cond".equalsIgnoreCase(n.getNodeName()))
{
makeItem();

View File

@@ -42,7 +42,6 @@ import com.l2jmobius.gameserver.model.ceremonyofchaos.CeremonyOfChaosEvent;
import com.l2jmobius.gameserver.model.commission.CommissionItemType;
import com.l2jmobius.gameserver.model.conditions.Condition;
import com.l2jmobius.gameserver.model.events.ListenersContainer;
import com.l2jmobius.gameserver.model.holders.ItemChanceHolder;
import com.l2jmobius.gameserver.model.holders.ItemSkillHolder;
import com.l2jmobius.gameserver.model.interfaces.IIdentifiable;
import com.l2jmobius.gameserver.model.items.enchant.attribute.AttributeHolder;
@@ -163,7 +162,6 @@ public abstract class L2Item extends ListenersContainer implements IIdentifiable
protected List<FuncTemplate> _funcTemplates;
protected List<Condition> _preConditions;
private List<ItemSkillHolder> _skills;
private List<ItemChanceHolder> _createItems;
private int _useSkillDisTime;
private int _reuseDelay;
@@ -759,20 +757,6 @@ public abstract class L2Item extends ListenersContainer implements IIdentifiable
_skills.add(holder);
}
public List<ItemChanceHolder> getCreateItems()
{
return _createItems != null ? _createItems : Collections.emptyList();
}
public void addCreateItem(ItemChanceHolder item)
{
if (_createItems == null)
{
_createItems = new ArrayList<>();
}
_createItems.add(item);
}
public boolean checkCondition(L2Character activeChar, L2Object object, boolean sendMessage)
{
if (activeChar.canOverrideCond(PcCondOverride.ITEM_CONDITIONS) && !Config.GM_ITEM_RESTRICTION)