mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-05 02:22:12 +01:00
AnimalTamer implementations, refactor and clean-up of code
By: Andrew Ardill <andrew.ardill@gmail.com>
This commit is contained in:
parent
7ad3f8b835
commit
1d515d9a86
1 changed files with 66 additions and 18 deletions
|
@ -3,10 +3,14 @@ package org.bukkit.craftbukkit.entity;
|
||||||
|
|
||||||
import net.minecraft.server.EntityWolf;
|
import net.minecraft.server.EntityWolf;
|
||||||
import org.bukkit.craftbukkit.CraftServer;
|
import org.bukkit.craftbukkit.CraftServer;
|
||||||
|
import org.bukkit.entity.AnimalTamer;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.entity.Wolf;
|
import org.bukkit.entity.Wolf;
|
||||||
import net.minecraft.server.PathEntity;
|
import net.minecraft.server.PathEntity;
|
||||||
|
|
||||||
public class CraftWolf extends CraftAnimals implements Wolf {
|
public class CraftWolf extends CraftAnimals implements Wolf {
|
||||||
|
private AnimalTamer owner;
|
||||||
|
|
||||||
public CraftWolf(CraftServer server, EntityWolf wolf) {
|
public CraftWolf(CraftServer server, EntityWolf wolf) {
|
||||||
super(server, wolf);
|
super(server, wolf);
|
||||||
}
|
}
|
||||||
|
@ -25,41 +29,85 @@ public class CraftWolf extends CraftAnimals implements Wolf {
|
||||||
|
|
||||||
public void setSitting(boolean sitting) {
|
public void setSitting(boolean sitting) {
|
||||||
getHandle().setSitting(sitting);
|
getHandle().setSitting(sitting);
|
||||||
|
// TODO determine what the following would do - it is affected every time a player makes their wolf sit or stand
|
||||||
|
//getHandle().ay = false;
|
||||||
|
setPath((PathEntity) null);
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isTame() {
|
public boolean isTamed() {
|
||||||
return getHandle().m_();
|
return getHandle().m_();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setTame(boolean tame) {
|
public void setTamed(boolean tame) {
|
||||||
getHandle().d(tame);
|
getHandle().d(tame);
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getOwner() {
|
public AnimalTamer getOwner() {
|
||||||
|
// If the wolf has a previously set owner use that, otherwise try and find the player who owns it
|
||||||
|
if (owner == null) {
|
||||||
|
// TODO try and recover owner from persistence store before defaulting to playername
|
||||||
|
owner = getServer().getPlayer(getOwnerName());
|
||||||
|
}
|
||||||
|
return owner;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setOwner(AnimalTamer tamer) {
|
||||||
|
owner = tamer;
|
||||||
|
if (owner != null) {
|
||||||
|
setTamed(true); /* Make him tame */
|
||||||
|
setPath((PathEntity) null); /* Clear path */
|
||||||
|
/* Set owner */
|
||||||
|
// TODO persist owner to the persistence store
|
||||||
|
if (owner instanceof Player) {
|
||||||
|
setOwnerName(((Player) owner).getName());
|
||||||
|
} else {
|
||||||
|
setOwnerName("");
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
setTamed(false); /* Make him not tame */
|
||||||
|
setOwnerName(""); /* Clear owner */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The owner's name is how MC knows and persists the Wolf's owner. Since we choose to instead use an AnimalTamer, this functionality
|
||||||
|
* is used only as a backup. If the animal tamer is a player, we will store their name, otherwise we store an empty string.
|
||||||
|
* @return the owner's name, if they are a player; otherwise, the empty string or null.
|
||||||
|
*/
|
||||||
|
String getOwnerName() {
|
||||||
return getHandle().x();
|
return getHandle().x();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setOwner(String player) {
|
|
||||||
EntityWolf e = getHandle();
|
|
||||||
|
|
||||||
if ((player != null) && (player.length() > 0)) {
|
void setOwnerName(String ownerName) {
|
||||||
e.d(true); /* Make him tame */
|
getHandle().a(ownerName);
|
||||||
e.a((PathEntity)null); /* Clear path */
|
|
||||||
e.a(player); /* Set owner */
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
e.d(false); /* Make him not tame */
|
|
||||||
e.a(""); /* Clear owner */
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Only used internally at the moment, and there to set the path to null (that is stop the thing from running around)
|
||||||
|
* TODO use this later to extend the API, when we have Path classes in Bukkit
|
||||||
|
* @param pathentity currently the MC defined PathEntity class. Should be replaced with an API interface at some point.
|
||||||
|
*/
|
||||||
|
private void setPath(PathEntity pathentity) {
|
||||||
|
getHandle().a(pathentity);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This method requires a(boolean) to be made visible. It will allow for hearts to be animated on a successful taming.
|
||||||
|
* TODO add this to the API, and make it visible
|
||||||
|
private void playTamingAnimation(boolean successful){
|
||||||
|
getHandle().a(successful);
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public EntityWolf getHandle() {
|
public EntityWolf getHandle() {
|
||||||
|
// It's somewhat easier to override this here, as many internal methods rely on EntityWolf specific methods.
|
||||||
|
// Doing this has no impact on anything outside this class.
|
||||||
return (EntityWolf) entity;
|
return (EntityWolf) entity;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "CraftWolf[anger=" + isAngry() + ",owner=" + getOwner() + ",tame=" + isTame() + ",sitting=" + isSitting() + "]";
|
return "CraftWolf[anger=" + isAngry() + ",owner=" + getOwner() + ",tame=" + isTamed() + ",sitting=" + isSitting() + "]";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue