2013-06-01 21:43:56 -04:00
|
|
|
package StevenDimDoors.mod_pocketDim.commands;
|
|
|
|
|
2013-06-16 05:59:53 -04:00
|
|
|
import java.io.File;
|
2013-06-15 02:40:00 -04:00
|
|
|
|
2013-06-09 17:23:36 -04:00
|
|
|
import net.minecraft.entity.player.EntityPlayer;
|
2013-06-15 02:40:00 -04:00
|
|
|
import StevenDimDoors.mod_pocketDim.DDProperties;
|
2013-06-15 10:25:50 -04:00
|
|
|
import StevenDimDoors.mod_pocketDim.helpers.DungeonHelper;
|
2013-06-01 21:43:56 -04:00
|
|
|
|
2013-07-26 02:09:14 -04:00
|
|
|
public class CommandExportDungeon extends DDCommandBase
|
2013-06-18 10:23:31 -04:00
|
|
|
{
|
2013-07-26 02:09:14 -04:00
|
|
|
private static CommandExportDungeon instance = null;
|
2013-06-13 19:01:54 -04:00
|
|
|
|
2013-07-26 02:09:14 -04:00
|
|
|
private CommandExportDungeon()
|
2013-06-13 19:01:54 -04:00
|
|
|
{
|
2013-06-25 13:55:13 -04:00
|
|
|
super("dd-export", new String[] {
|
2013-07-26 01:57:18 -04:00
|
|
|
"<dungeon type> <dungeon name> <'open' | 'closed'> [weight]",
|
2013-06-25 13:55:13 -04:00
|
|
|
"<schematic name> override" } );
|
2013-06-13 19:01:54 -04:00
|
|
|
}
|
|
|
|
|
2013-07-26 02:09:14 -04:00
|
|
|
public static CommandExportDungeon instance()
|
2013-06-01 21:43:56 -04:00
|
|
|
{
|
2013-06-18 10:23:31 -04:00
|
|
|
if (instance == null)
|
2013-07-26 02:09:14 -04:00
|
|
|
instance = new CommandExportDungeon();
|
2013-06-18 10:23:31 -04:00
|
|
|
|
|
|
|
return instance;
|
2013-06-01 21:43:56 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2013-06-25 13:55:13 -04:00
|
|
|
protected DDCommandResult processCommand(EntityPlayer sender, String[] command)
|
2013-06-01 21:43:56 -04:00
|
|
|
{
|
2013-06-25 13:55:13 -04:00
|
|
|
/*
|
2013-07-26 01:57:18 -04:00
|
|
|
* There are two versions of this command. One version takes 3 to 4 arguments consisting
|
|
|
|
* of the information needed for a proper schematic name.
|
2013-06-25 13:55:13 -04:00
|
|
|
*
|
|
|
|
* If the user wishes to name his schematic in a different format, then he will have to use
|
|
|
|
* the 2-argument version of this command, which accepts a schematic name and a mandatory
|
|
|
|
* override argument.
|
|
|
|
*/
|
|
|
|
|
2013-06-16 01:00:05 -04:00
|
|
|
DungeonHelper dungeonHelper = DungeonHelper.instance();
|
|
|
|
|
2013-06-25 13:55:13 -04:00
|
|
|
if (command.length < 2)
|
|
|
|
{
|
|
|
|
return DDCommandResult.TOO_FEW_ARGUMENTS;
|
|
|
|
}
|
2013-07-26 01:57:18 -04:00
|
|
|
if (command.length > 4)
|
2013-06-25 13:55:13 -04:00
|
|
|
{
|
|
|
|
return DDCommandResult.TOO_MANY_ARGUMENTS;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Check if we received the 2-argument version
|
|
|
|
if (command.length == 2)
|
2013-06-09 17:23:36 -04:00
|
|
|
{
|
2013-06-25 13:55:13 -04:00
|
|
|
if (command[1].equalsIgnoreCase("override"))
|
2013-06-09 17:23:36 -04:00
|
|
|
{
|
2013-06-25 13:55:13 -04:00
|
|
|
//Check that the schematic name is a legal name
|
2013-08-05 09:48:49 -04:00
|
|
|
if (DungeonHelper.SCHEMATIC_NAME_PATTERN.matcher(command[0]).matches())
|
2013-06-25 13:55:13 -04:00
|
|
|
{
|
|
|
|
//Export the schematic
|
|
|
|
return exportDungeon(sender, command[0]);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
//The schematic name contains illegal characters. Inform the user.
|
|
|
|
return new DDCommandResult("Error: Invalid schematic name. Please use only letters, numbers, dashes, and underscores.");
|
|
|
|
}
|
2013-06-09 17:23:36 -04:00
|
|
|
}
|
2013-06-25 13:55:13 -04:00
|
|
|
else
|
2013-06-09 17:23:36 -04:00
|
|
|
{
|
2013-06-25 13:55:13 -04:00
|
|
|
//The command is malformed in some way. Assume that the user meant to use
|
|
|
|
//the 3-argument version and report an error.
|
|
|
|
return DDCommandResult.TOO_FEW_ARGUMENTS;
|
2013-06-09 17:23:36 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-06-25 13:55:13 -04:00
|
|
|
//The user must have used the 3-argument version of this command
|
|
|
|
//TODO: Why do we check remoteness here but not before? And why not for the other export case?
|
|
|
|
//Something feels wrong... ~SenseiKiwi
|
|
|
|
if (!sender.worldObj.isRemote)
|
2013-06-04 08:52:06 -04:00
|
|
|
{
|
2013-06-25 13:55:13 -04:00
|
|
|
//TODO: This validation should be in DungeonHelper or in another class. We should move it
|
2013-07-26 01:57:18 -04:00
|
|
|
//during the save file format rewrite. ~SenseiKiwi
|
2013-06-25 13:55:13 -04:00
|
|
|
|
2013-08-22 02:25:26 -04:00
|
|
|
if (!dungeonHelper.validateDungeonType(command[0], dungeonHelper.getDungeonPack("ruins")))
|
2013-06-09 17:44:23 -04:00
|
|
|
{
|
2013-06-25 13:55:13 -04:00
|
|
|
return new DDCommandResult("Error: Invalid dungeon type. Please use one of the existing types.");
|
|
|
|
}
|
2013-08-05 09:48:49 -04:00
|
|
|
if (!DungeonHelper.DUNGEON_NAME_PATTERN.matcher(command[1]).matches())
|
2013-06-25 13:55:13 -04:00
|
|
|
{
|
|
|
|
return new DDCommandResult("Error: Invalid dungeon name. Please use only letters, numbers, and dashes.");
|
|
|
|
}
|
|
|
|
if (!command[2].equalsIgnoreCase("open") && !command[2].equalsIgnoreCase("closed"))
|
|
|
|
{
|
|
|
|
return new DDCommandResult("Error: Please specify whether the dungeon is 'open' or 'closed'.");
|
|
|
|
}
|
|
|
|
|
2013-07-26 01:57:18 -04:00
|
|
|
//If there are no more arguments, export the dungeon.
|
2013-06-25 13:55:13 -04:00
|
|
|
if (command.length == 3)
|
|
|
|
{
|
|
|
|
return exportDungeon(sender, join(command, "_", 0, 3));
|
|
|
|
}
|
2013-07-26 01:57:18 -04:00
|
|
|
else
|
2013-06-15 02:40:00 -04:00
|
|
|
{
|
2013-07-26 01:57:18 -04:00
|
|
|
//Validate the weight argument
|
|
|
|
try
|
2013-06-25 13:55:13 -04:00
|
|
|
{
|
2013-07-26 01:57:18 -04:00
|
|
|
int weight = Integer.parseInt(command[3]);
|
2013-08-21 14:26:10 -04:00
|
|
|
if (weight >= DungeonHelper.MIN_DUNGEON_WEIGHT && weight <= DungeonHelper.MAX_DUNGEON_WEIGHT)
|
2013-07-26 01:57:18 -04:00
|
|
|
{
|
|
|
|
return exportDungeon(sender, join(command, "_", 0, 4));
|
|
|
|
}
|
2013-06-25 13:55:13 -04:00
|
|
|
}
|
2013-07-26 01:57:18 -04:00
|
|
|
catch (Exception e) { }
|
2013-06-09 17:44:23 -04:00
|
|
|
}
|
2013-06-25 13:55:13 -04:00
|
|
|
|
|
|
|
//If we've reached this point, then we must have an invalid weight.
|
2013-08-21 14:26:10 -04:00
|
|
|
return new DDCommandResult("Invalid dungeon weight. Please specify a weight between "
|
|
|
|
+ DungeonHelper.MIN_DUNGEON_WEIGHT + " and " + DungeonHelper.MAX_DUNGEON_WEIGHT + ", inclusive.");
|
2013-06-25 13:55:13 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
return DDCommandResult.SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
private static DDCommandResult exportDungeon(EntityPlayer player, String name)
|
|
|
|
{
|
|
|
|
DDProperties properties = DDProperties.instance();
|
|
|
|
DungeonHelper dungeonHelper = DungeonHelper.instance();
|
|
|
|
|
|
|
|
int x = (int) player.posX;
|
|
|
|
int y = (int) player.posY;
|
|
|
|
int z = (int) player.posZ;
|
|
|
|
String exportPath = properties.CustomSchematicDirectory + File.separator + name + ".schematic";
|
|
|
|
if (dungeonHelper.exportDungeon(player.worldObj, x, y, z, exportPath))
|
|
|
|
{
|
|
|
|
player.sendChatToPlayer("Saved dungeon schematic in " + exportPath);
|
2013-08-22 02:25:26 -04:00
|
|
|
dungeonHelper.registerDungeon(exportPath, dungeonHelper.getDungeonPack("ruins"), false, true);
|
2013-06-25 13:55:13 -04:00
|
|
|
return DDCommandResult.SUCCESS;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return new DDCommandResult("Error: Failed to save dungeon schematic!");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private static String join(String[] source, String delimiter, int start, int end)
|
|
|
|
{
|
|
|
|
//TODO: This function should be moved to a helper, but we have several single-function helpers as is.
|
|
|
|
//I find that to be worse than keeping this private. ~SenseiKiwi
|
|
|
|
|
|
|
|
int index;
|
|
|
|
int length = 0;
|
|
|
|
StringBuilder buffer;
|
|
|
|
for (index = start; index < end; index++)
|
|
|
|
{
|
|
|
|
length += source[index].length();
|
|
|
|
}
|
|
|
|
length += (end - start - 1) * delimiter.length();
|
|
|
|
|
|
|
|
buffer = new StringBuilder(length);
|
|
|
|
buffer.append(source[start]);
|
|
|
|
for (index = start + 1; index < end; index++)
|
|
|
|
{
|
|
|
|
buffer.append(delimiter);
|
|
|
|
buffer.append(source[index]);
|
2013-06-04 08:52:06 -04:00
|
|
|
}
|
2013-06-25 13:55:13 -04:00
|
|
|
return buffer.toString();
|
2013-06-01 21:43:56 -04:00
|
|
|
}
|
|
|
|
}
|