Rename and clean up MapleSummon

This commit is contained in:
P0nk
2021-09-09 22:39:43 +02:00
parent 03dc665605
commit 8a95459a17
10 changed files with 52 additions and 50 deletions

View File

@@ -189,7 +189,7 @@ public class Character extends AbstractCharacterObject {
private final Map<Integer, Map<BuffStat, MapleBuffStatValueHolder>> buffEffects = new LinkedHashMap<>(); // non-overriding buffs thanks to Ronan
private final Map<Integer, Long> buffExpires = new LinkedHashMap<>();
private final Map<Integer, KeyBinding> keymap = new LinkedHashMap<>();
private final Map<Integer, MapleSummon> summons = new LinkedHashMap<>();
private final Map<Integer, Summon> summons = new LinkedHashMap<>();
private final Map<Integer, MapleCoolDownValueHolder> coolDowns = new LinkedHashMap<>();
private final EnumMap<Disease, Pair<DiseaseValueHolder, MobSkill>> diseases = new EnumMap<>(Disease.class);
private byte[] m_aQuickslotLoaded;
@@ -628,7 +628,7 @@ public class Character extends AbstractCharacterObject {
}
}
public void addSummon(int id, MapleSummon summon) {
public void addSummon(int id, Summon summon) {
summons.put(id, summon);
if (summon.isPuppet()) {
@@ -828,7 +828,7 @@ public class Character extends AbstractCharacterObject {
getMap().broadcastGMMessage(this, PacketCreator.cancelForeignBuff(id, dsstat), false);
getMap().broadcastSpawnPlayerMapObjectMessage(this, this, false);
for (MapleSummon ms : this.getSummonsValues()) {
for (Summon ms : this.getSummonsValues()) {
getMap().broadcastNONGMMessage(this, PacketCreator.spawnSummon(ms, false), false);
}
@@ -3706,7 +3706,7 @@ public class Character extends AbstractCharacterObject {
} else if (mbs == BuffStat.SUMMON || mbs == BuffStat.PUPPET) {
int summonId = mbsvh.effect.getSourceId();
MapleSummon summon = summons.get(summonId);
Summon summon = summons.get(summonId);
if (summon != null) {
getMap().broadcastMessage(PacketCreator.removeSummon(summon, true), summon.getPosition());
getMap().removeMapObject(summon);
@@ -5867,7 +5867,7 @@ public class Character extends AbstractCharacterObject {
return storage;
}
public Collection<MapleSummon> getSummonsValues() {
public Collection<Summon> getSummonsValues() {
return summons.values();
}
@@ -5875,7 +5875,7 @@ public class Character extends AbstractCharacterObject {
summons.clear();
}
public MapleSummon getSummonByKey(int id) {
public Summon getSummonByKey(int id) {
return summons.get(id);
}
@@ -5883,7 +5883,7 @@ public class Character extends AbstractCharacterObject {
return summons.isEmpty();
}
public boolean containsSummon(MapleSummon summon) {
public boolean containsSummon(Summon summon) {
return summons.containsValue(summon);
}

View File

@@ -25,7 +25,7 @@ import client.Client;
import constants.skills.DarkKnight;
import net.AbstractPacketHandler;
import net.packet.InPacket;
import server.maps.MapleSummon;
import server.maps.Summon;
import java.util.Collection;
@@ -38,10 +38,10 @@ public final class BeholderHandler extends AbstractPacketHandler {//Summon Skill
@Override
public final void handlePacket(InPacket p, Client c) {
//System.out.println(slea.toString());
Collection<MapleSummon> summons = c.getPlayer().getSummonsValues();
Collection<Summon> summons = c.getPlayer().getSummonsValues();
int oid = p.readInt();
MapleSummon summon = null;
for (MapleSummon sum : summons) {
Summon summon = null;
for (Summon sum : summons) {
if (sum.getObjectId() == oid) {
summon = sum;
}

View File

@@ -27,7 +27,7 @@ import client.Client;
import net.AbstractPacketHandler;
import net.packet.InPacket;
import server.maps.MapObject;
import server.maps.MapleSummon;
import server.maps.Summon;
import tools.PacketCreator;
public final class DamageSummonHandler extends AbstractPacketHandler {
@@ -41,8 +41,8 @@ public final class DamageSummonHandler extends AbstractPacketHandler {
Character player = c.getPlayer();
MapObject mmo = player.getMap().getMapObject(oid);
if(mmo != null && mmo instanceof MapleSummon) {
MapleSummon summon = (MapleSummon) mmo;
if(mmo != null && mmo instanceof Summon) {
Summon summon = (Summon) mmo;
summon.addHP(-damage);
if (summon.getHP() <= 0) {

View File

@@ -24,7 +24,7 @@ package net.server.channel.handlers;
import client.Character;
import client.Client;
import net.packet.InPacket;
import server.maps.MapleSummon;
import server.maps.Summon;
import tools.PacketCreator;
import tools.exceptions.EmptyMovementException;
@@ -37,9 +37,9 @@ public final class MoveSummonHandler extends AbstractMovementPacketHandler {
int oid = p.readInt();
Point startPos = new Point(p.readShort(), p.readShort());
Character player = c.getPlayer();
Collection<MapleSummon> summons = player.getSummonsValues();
MapleSummon summon = null;
for (MapleSummon sum : summons) {
Collection<Summon> summons = player.getSummonsValues();
Summon summon = null;
for (Summon sum : summons) {
if (sum.getObjectId() == oid) {
summon = sum;
break;

View File

@@ -36,7 +36,7 @@ import server.MapleItemInformationProvider;
import server.MapleStatEffect;
import server.life.Monster;
import server.life.MonsterInformationProvider;
import server.maps.MapleSummon;
import server.maps.Summon;
import tools.FilePrinter;
import tools.PacketCreator;
@@ -72,8 +72,8 @@ public final class SummonDamageHandler extends AbstractDealDamageHandler {
if (!player.isAlive()) {
return;
}
MapleSummon summon = null;
for (MapleSummon sum : player.getSummonsValues()) {
Summon summon = null;
for (Summon sum : player.getSummonsValues()) {
if (sum.getObjectId() == oid) {
summon = sum;
}

View File

@@ -993,7 +993,7 @@ public class MapleStatEffect {
}
if (summonMovementType != null && pos != null) {
final MapleSummon tosummon = new MapleSummon(applyfrom, sourceid, pos, summonMovementType);
final Summon tosummon = new Summon(applyfrom, sourceid, pos, summonMovementType);
applyfrom.getMap().spawnSummon(tosummon);
applyfrom.addSummon(sourceid, tosummon);
tosummon.addHP(x);
@@ -1171,7 +1171,7 @@ public class MapleStatEffect {
chr.registerEffect(this, localStartTime, localStartTime + localDuration, true);
SummonMovementType summonMovementType = getSummonMovementType();
if (summonMovementType != null) {
final MapleSummon tosummon = new MapleSummon(chr, sourceid, chr.getPosition(), summonMovementType);
final Summon tosummon = new Summon(chr, sourceid, chr.getPosition(), summonMovementType);
if (!tosummon.isStationary()) {
chr.addSummon(sourceid, tosummon);
tosummon.addHP(x);

View File

@@ -49,7 +49,7 @@ import server.loot.LootManager;
import server.maps.AbstractAnimatedMapObject;
import server.maps.MapObjectType;
import server.maps.MapleMap;
import server.maps.MapleSummon;
import server.maps.Summon;
import tools.IntervalBuilder;
import tools.PacketCreator;
import tools.Pair;
@@ -1796,14 +1796,14 @@ public class Monster extends AbstractLoadedLife {
// ---------------------------------------------------------------------------------
private boolean isPuppetInVicinity(MapleSummon summon) {
private boolean isPuppetInVicinity(Summon summon) {
return summon.getPosition().distanceSq(this.getPosition()) < 177777;
}
public boolean isCharacterPuppetInVicinity(Character chr) {
MapleStatEffect mse = chr.getBuffEffect(BuffStat.PUPPET);
if (mse != null) {
MapleSummon summon = chr.getSummonByKey(mse.getSourceId());
Summon summon = chr.getSummonByKey(mse.getSourceId());
// check whether mob is currently under a puppet's field of action or not
if (summon != null) {
@@ -2098,7 +2098,7 @@ public class Monster extends AbstractLoadedLife {
c.sendPacket(PacketCreator.controlMonster(mob, false, immediateAggro));
}
private void aggroRefreshPuppetVisibility(Character chrController, MapleSummon puppet) {
private void aggroRefreshPuppetVisibility(Character chrController, Summon puppet) {
// lame patch for client to redirect all aggro to the puppet
List<Monster> puppetControlled = new LinkedList<>();
@@ -2135,7 +2135,7 @@ public class Monster extends AbstractLoadedLife {
MapleStatEffect puppetEffect = chrController.getBuffEffect(BuffStat.PUPPET);
if (puppetEffect != null) {
MapleSummon puppet = chrController.getSummonByKey(puppetEffect.getSourceId());
Summon puppet = chrController.getSummonByKey(puppetEffect.getSourceId());
if (puppet != null && isPuppetInVicinity(puppet)) {
controllerHasPuppet = true;

View File

@@ -2061,7 +2061,7 @@ public class MapleMap {
return doorPortal;
}
public void spawnSummon(final MapleSummon summon) {
public void spawnSummon(final Summon summon) {
spawnAndAddRangedMapObject(summon, c -> {
if (summon != null) {
c.sendPacket(PacketCreator.spawnSummon(summon, true));
@@ -2537,7 +2537,7 @@ public class MapleMap {
MapleStatEffect summonStat = chr.getStatForBuff(BuffStat.SUMMON);
if (summonStat != null) {
MapleSummon summon = chr.getSummonByKey(summonStat.getSourceId());
Summon summon = chr.getSummonByKey(summonStat.getSourceId());
summon.setPosition(chr.getPosition());
chr.getMap().spawnSummon(summon);
updateMapObjectVisibility(chr, summon);
@@ -2699,7 +2699,7 @@ public class MapleMap {
chr.leaveMap();
for (MapleSummon summon : new ArrayList<>(chr.getSummonsValues())) {
for (Summon summon : new ArrayList<>(chr.getSummonsValues())) {
if (summon.isStationary()) {
chr.cancelEffectFromBuffStat(BuffStat.PUPPET);
} else {
@@ -2939,7 +2939,7 @@ public class MapleMap {
if (isNonRangedType(o.getType())) {
o.sendSpawnData(c);
} else if (o.getType() == MapObjectType.SUMMON) {
MapleSummon summon = (MapleSummon) o;
Summon summon = (Summon) o;
if (summon.getOwner() == chr) {
if (chr.isSummonsEmpty() || !chr.containsSummon(summon)) {
objectWLock.lock();

View File

@@ -29,21 +29,23 @@ import tools.PacketCreator;
import java.awt.*;
/**
*
* @author Jan
*/
public class MapleSummon extends AbstractAnimatedMapObject {
private Character owner;
private byte skillLevel;
private int skill, hp;
private SummonMovementType movementType;
public class Summon extends AbstractAnimatedMapObject {
private final Character owner;
private final byte skillLevel;
private final int skill;
private int hp;
private final SummonMovementType movementType;
public MapleSummon(Character owner, int skill, Point pos, SummonMovementType movementType) {
public Summon(Character owner, int skill, Point pos, SummonMovementType movementType) {
this.owner = owner;
this.skill = skill;
this.skillLevel = owner.getSkillLevel(SkillFactory.getSkill(skill));
if (skillLevel == 0) throw new RuntimeException();
if (skillLevel == 0) {
throw new RuntimeException();
}
this.movementType = movementType;
setPosition(pos);
}
@@ -92,12 +94,12 @@ public class MapleSummon extends AbstractAnimatedMapObject {
}
public final boolean isPuppet() {
switch (skill) {
case 3111002:
case 3211002:
case 13111004:
return true;
}
return false;
switch (skill) {
case 3111002:
case 3211002:
case 13111004:
return true;
}
return false;
}
}

View File

@@ -1095,7 +1095,7 @@ public class PacketCreator {
* @param animated Animated spawn?
* @return The spawn packet for the map object.
*/
public static Packet spawnSummon(MapleSummon summon, boolean animated) {
public static Packet spawnSummon(Summon summon, boolean animated) {
OutPacket p = OutPacket.create(SendOpcode.SPAWN_SPECIAL_MAPOBJECT);
p.writeInt(summon.getOwner().getId());
p.writeInt(summon.getObjectId());
@@ -1118,7 +1118,7 @@ public class PacketCreator {
* @param animated Animated removal?
* @return The packet removing the object.
*/
public static Packet removeSummon(MapleSummon summon, boolean animated) {
public static Packet removeSummon(Summon summon, boolean animated) {
OutPacket p = OutPacket.create(SendOpcode.REMOVE_SPECIAL_MAPOBJECT);
p.writeInt(summon.getOwner().getId());
p.writeInt(summon.getObjectId());