2013-03-23 06:25:50 +01:00
|
|
|
package StevenDimDoors.mod_pocketDim.commands;
|
|
|
|
|
|
|
|
import java.util.ArrayList;
|
|
|
|
import java.util.Collection;
|
|
|
|
|
|
|
|
import net.minecraft.command.CommandBase;
|
|
|
|
import net.minecraft.command.ICommandSender;
|
|
|
|
import StevenDimDoors.mod_pocketDim.DimData;
|
|
|
|
import StevenDimDoors.mod_pocketDim.LinkData;
|
2013-06-10 23:03:52 +02:00
|
|
|
import StevenDimDoors.mod_pocketDim.helpers.dimHelper;
|
2013-03-23 06:25:50 +01:00
|
|
|
|
|
|
|
public class CommandPruneDims extends CommandBase
|
|
|
|
{
|
|
|
|
public String getCommandName()//the name of our command
|
|
|
|
{
|
2013-06-12 23:59:34 +02:00
|
|
|
return "dimdoors-prunePockets";
|
2013-03-23 06:25:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void processCommand(ICommandSender var1, String[] var2)
|
|
|
|
|
|
|
|
{
|
|
|
|
int numRemoved=0;
|
|
|
|
ArrayList dimsWithLinks=new ArrayList();
|
|
|
|
Collection<DimData> allDims = new ArrayList();
|
|
|
|
allDims.addAll(dimHelper.dimList.values());
|
|
|
|
for(DimData data: allDims)
|
|
|
|
{
|
|
|
|
|
|
|
|
for(LinkData link:data.printAllLinkData())
|
|
|
|
{
|
|
|
|
if(!dimsWithLinks.contains(link.destDimID))
|
|
|
|
{
|
|
|
|
dimsWithLinks.add(link.destDimID);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for(LinkData link : dimHelper.instance.interDimLinkList.values())
|
|
|
|
{
|
|
|
|
if(!dimsWithLinks.contains(link.destDimID))
|
|
|
|
{
|
|
|
|
dimsWithLinks.add(link.destDimID);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for(DimData data : allDims)
|
|
|
|
{
|
|
|
|
if(!dimsWithLinks.contains(data.dimID))
|
|
|
|
{
|
|
|
|
dimHelper.dimList.remove(data.dimID);
|
|
|
|
numRemoved++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
dimHelper.instance.save();
|
|
|
|
this.getCommandSenderAsPlayer(var1).sendChatToPlayer("Removed "+numRemoved+" unreachable pocket dims.");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|