Rewrote CommandTeleportPlayer
Rewrote CommandTeleportPlayer for the same reason as usual. There were a few bugs before, such as that lookups for players were limited to within the world from which the command sender was using the command. Players in other dimensions could not be teleported. The command would also place people in the ground because it did not adjust its coordinates for the way that DDTeleporter interprets them - as the location of the top block of a door and the player's head.
This commit is contained in:
parent
1e3b32a15c
commit
16f0a8303a
2 changed files with 110 additions and 94 deletions
|
@ -1,8 +1,10 @@
|
||||||
package StevenDimDoors.mod_pocketDim.commands;
|
package StevenDimDoors.mod_pocketDim.commands;
|
||||||
|
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraftforge.common.DimensionManager;
|
import net.minecraft.server.MinecraftServer;
|
||||||
|
import net.minecraft.world.World;
|
||||||
import StevenDimDoors.mod_pocketDim.core.DDTeleporter;
|
import StevenDimDoors.mod_pocketDim.core.DDTeleporter;
|
||||||
|
import StevenDimDoors.mod_pocketDim.core.NewDimData;
|
||||||
import StevenDimDoors.mod_pocketDim.core.PocketManager;
|
import StevenDimDoors.mod_pocketDim.core.PocketManager;
|
||||||
import StevenDimDoors.mod_pocketDim.util.Point4D;
|
import StevenDimDoors.mod_pocketDim.util.Point4D;
|
||||||
|
|
||||||
|
@ -12,7 +14,10 @@ public class CommandTeleportPlayer extends DDCommandBase
|
||||||
|
|
||||||
private CommandTeleportPlayer()
|
private CommandTeleportPlayer()
|
||||||
{
|
{
|
||||||
super("dd-tp", new String[] {"<Player Name> <Dimension ID> <X Coord> <Y Coord> <Z Coord>","<Player Name> <Dimension ID>"} );
|
super("dd-tp", new String[] {
|
||||||
|
"<player name> <dimension number>",
|
||||||
|
"<player name> <x> <y> <z>",
|
||||||
|
"<player name> <dimension number> <x> <y> <z>"} );
|
||||||
}
|
}
|
||||||
|
|
||||||
public static CommandTeleportPlayer instance()
|
public static CommandTeleportPlayer instance()
|
||||||
|
@ -23,110 +28,120 @@ public class CommandTeleportPlayer extends DDCommandBase
|
||||||
return instance;
|
return instance;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* TODO- Change to accept variety of input, like just coords, just dim ID, or two player names.
|
|
||||||
*/
|
|
||||||
@Override
|
@Override
|
||||||
protected DDCommandResult processCommand(EntityPlayer sender, String[] command)
|
protected DDCommandResult processCommand(EntityPlayer sender, String[] command)
|
||||||
{
|
{
|
||||||
EntityPlayer targetPlayer = sender;
|
int x;
|
||||||
int dimDestinationID = sender.worldObj.provider.dimensionId;
|
int y;
|
||||||
|
int z;
|
||||||
|
World world;
|
||||||
|
int dimensionID;
|
||||||
|
Point4D destination;
|
||||||
|
NewDimData dimension;
|
||||||
|
boolean checkOrientation;
|
||||||
|
EntityPlayer targetPlayer;
|
||||||
|
|
||||||
if(command.length == 5)
|
if (command.length < 2)
|
||||||
{
|
{
|
||||||
for(int i= 1; i <5;i++)
|
return DDCommandResult.TOO_FEW_ARGUMENTS;
|
||||||
{
|
|
||||||
if(!isInteger(command[i]))
|
|
||||||
{
|
|
||||||
return DDCommandResult.INVALID_ARGUMENTS;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if(sender.worldObj.getPlayerEntityByName(command[0])!=null) //Gets the targeted player
|
|
||||||
{
|
|
||||||
targetPlayer = sender.worldObj.getPlayerEntityByName(command[0]);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return DDCommandResult.INVALID_ARGUMENTS;
|
|
||||||
}
|
|
||||||
dimDestinationID=Integer.parseInt(command[1]);//gets the target dim ID from the command string
|
|
||||||
|
|
||||||
if(!DimensionManager.isDimensionRegistered(dimDestinationID))
|
|
||||||
{
|
|
||||||
return DDCommandResult.INVALID_DIMENSION_ID;
|
|
||||||
}
|
|
||||||
|
|
||||||
PocketManager.loadDimension(dimDestinationID);
|
|
||||||
Point4D destination = new Point4D(Integer.parseInt(command[2]),Integer.parseInt(command[3]),Integer.parseInt(command[4]),dimDestinationID);
|
|
||||||
DDTeleporter.teleportEntity(targetPlayer, destination, false);
|
|
||||||
}
|
}
|
||||||
else if(command.length == 2 && isInteger(command[1]))
|
if (command.length > 5)
|
||||||
{
|
{
|
||||||
if(sender.worldObj.getPlayerEntityByName(command[0])!=null) //Gets the targeted player
|
return DDCommandResult.TOO_MANY_ARGUMENTS;
|
||||||
{
|
|
||||||
targetPlayer = sender.worldObj.getPlayerEntityByName(command[0]);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return DDCommandResult.INVALID_ARGUMENTS;
|
|
||||||
}
|
|
||||||
dimDestinationID=Integer.parseInt(command[1]);//gets the target dim ID from the command string
|
|
||||||
|
|
||||||
if(!DimensionManager.isDimensionRegistered(dimDestinationID))
|
|
||||||
{
|
|
||||||
return DDCommandResult.INVALID_DIMENSION_ID;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
Point4D destination = PocketManager.getDimensionData(dimDestinationID).origin();
|
|
||||||
if(!PocketManager.getDimensionData(dimDestinationID).isPocketDimension())
|
|
||||||
{
|
|
||||||
destination = new Point4D(destination.getX(),PocketManager.loadDimension(dimDestinationID).getTopSolidOrLiquidBlock(
|
|
||||||
destination.getX(), destination.getZ()),
|
|
||||||
destination.getZ(),destination.getDimension());
|
|
||||||
}
|
|
||||||
DDTeleporter.teleportEntity(targetPlayer, destination, false);
|
|
||||||
}
|
}
|
||||||
else if(command.length == 1 && isInteger(command[0]))
|
if (command.length == 3)
|
||||||
{
|
|
||||||
|
|
||||||
targetPlayer = sender;
|
|
||||||
|
|
||||||
dimDestinationID=Integer.parseInt(command[0]);//gets the target dim ID from the command string
|
|
||||||
|
|
||||||
if(!DimensionManager.isDimensionRegistered(dimDestinationID))
|
|
||||||
{
|
|
||||||
return DDCommandResult.INVALID_DIMENSION_ID;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
Point4D destination = PocketManager.getDimensionData(dimDestinationID).origin();
|
|
||||||
if(!PocketManager.getDimensionData(dimDestinationID).isPocketDimension())
|
|
||||||
{
|
|
||||||
destination = new Point4D(destination.getX(),PocketManager.loadDimension(dimDestinationID).getTopSolidOrLiquidBlock(
|
|
||||||
destination.getX(), destination.getZ()),
|
|
||||||
destination.getZ(),destination.getDimension());
|
|
||||||
}
|
|
||||||
DDTeleporter.teleportEntity(targetPlayer, destination, false);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
return DDCommandResult.INVALID_ARGUMENTS;
|
return DDCommandResult.INVALID_ARGUMENTS;
|
||||||
}
|
}
|
||||||
|
// Check that all arguments after the username are integers
|
||||||
|
for (int k = 1; k < command.length; k++)
|
||||||
|
{
|
||||||
|
if (!isInteger(command[k]))
|
||||||
|
{
|
||||||
|
return DDCommandResult.INVALID_ARGUMENTS;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Check if the target player is logged in
|
||||||
|
targetPlayer = MinecraftServer.getServer().getConfigurationManager().getPlayerForUsername(command[0]);
|
||||||
|
if (targetPlayer == null)
|
||||||
|
{
|
||||||
|
return DDCommandResult.PLAYER_OFFLINE;
|
||||||
|
}
|
||||||
|
// If a dimension ID was provided, try to load it
|
||||||
|
if (command.length != 4)
|
||||||
|
{
|
||||||
|
dimensionID = Integer.parseInt(command[1]);
|
||||||
|
world = PocketManager.loadDimension(dimensionID);
|
||||||
|
if (world == null)
|
||||||
|
{
|
||||||
|
return DDCommandResult.UNREGISTERED_DIMENSION;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
dimensionID = targetPlayer.worldObj.provider.dimensionId;
|
||||||
|
// SenseiKiwi: Will not be used, but I prefer not to leave 'world' as null
|
||||||
|
world = targetPlayer.worldObj;
|
||||||
|
}
|
||||||
|
|
||||||
|
// If we teleport to a pocket dimension, set checkOrientation to true
|
||||||
|
// so the player is placed correctly relative to the entrance door.
|
||||||
|
checkOrientation = false;
|
||||||
|
|
||||||
|
// Parse or calculate the destination as necessary
|
||||||
|
// The Y coordinate must be increased by 1 because of the way that
|
||||||
|
// DDTeleporter considers destination points. It assumes that the
|
||||||
|
// point provided is the upper block of a door.
|
||||||
|
if (command.length == 2)
|
||||||
|
{
|
||||||
|
// Check if the destination is a pocket dimension
|
||||||
|
dimension = PocketManager.getDimensionData(dimensionID);
|
||||||
|
if (dimension.isPocketDimension())
|
||||||
|
{
|
||||||
|
// The destination is a pocket dimension.
|
||||||
|
// Teleport the player to its original entrance (the origin).
|
||||||
|
destination = dimension.origin();
|
||||||
|
checkOrientation = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// The destination is not a pocket dimension, which means we
|
||||||
|
// don't automatically know a safe location where we can send
|
||||||
|
// the player. Send the player to (0, Y, 0), where Y is chosen
|
||||||
|
// by searching. Add 2 to place the player ABOVE the top block.
|
||||||
|
y = world.getTopSolidOrLiquidBlock(0, 0) + 2;
|
||||||
|
destination = new Point4D(0, y, 0, dimensionID);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (command.length == 4)
|
||||||
|
{
|
||||||
|
x = Integer.parseInt(command[1]);
|
||||||
|
y = Integer.parseInt(command[2]) + 1;
|
||||||
|
z = Integer.parseInt(command[3]);
|
||||||
|
destination = new Point4D(x, y, z, dimensionID);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
x = Integer.parseInt(command[2]);
|
||||||
|
y = Integer.parseInt(command[3]) + 1;
|
||||||
|
z = Integer.parseInt(command[4]);
|
||||||
|
destination = new Point4D(x, y, z, dimensionID);
|
||||||
|
}
|
||||||
|
// Teleport!
|
||||||
|
DDTeleporter.teleportEntity(targetPlayer, destination, checkOrientation);
|
||||||
return DDCommandResult.SUCCESS;
|
return DDCommandResult.SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean isInteger( String input )
|
private static boolean isInteger(String input)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
Integer.parseInt( input );
|
Integer.parseInt(input);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
catch(Exception e )
|
catch(Exception e)
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -9,6 +9,7 @@ public class DDCommandResult {
|
||||||
public static final DDCommandResult INVALID_DIMENSION_ID = new DDCommandResult(3, "Error: Invalid dimension ID", true);
|
public static final DDCommandResult INVALID_DIMENSION_ID = new DDCommandResult(3, "Error: Invalid dimension ID", true);
|
||||||
public static final DDCommandResult UNREGISTERED_DIMENSION = new DDCommandResult(4, "Error: Dimension is not registered", false);
|
public static final DDCommandResult UNREGISTERED_DIMENSION = new DDCommandResult(4, "Error: Dimension is not registered", false);
|
||||||
public static final DDCommandResult INVALID_ARGUMENTS = new DDCommandResult(5, "Error: Invalid arguments passed to the command", true);
|
public static final DDCommandResult INVALID_ARGUMENTS = new DDCommandResult(5, "Error: Invalid arguments passed to the command", true);
|
||||||
|
public static final DDCommandResult PLAYER_OFFLINE = new DDCommandResult(6, "Error: Player is not online", false);
|
||||||
|
|
||||||
public static final int CUSTOM_ERROR_CODE = -1;
|
public static final int CUSTOM_ERROR_CODE = -1;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue