Added /wfind command
This commit is contained in:
parent
f2266270cb
commit
883b6d57ac
3 changed files with 116 additions and 0 deletions
|
@ -92,6 +92,7 @@ import cr0s.warpdrive.block.weapon.TileEntityWeaponController;
|
||||||
import cr0s.warpdrive.command.CommandDebug;
|
import cr0s.warpdrive.command.CommandDebug;
|
||||||
import cr0s.warpdrive.command.CommandDump;
|
import cr0s.warpdrive.command.CommandDump;
|
||||||
import cr0s.warpdrive.command.CommandEntity;
|
import cr0s.warpdrive.command.CommandEntity;
|
||||||
|
import cr0s.warpdrive.command.CommandFind;
|
||||||
import cr0s.warpdrive.command.CommandGenerate;
|
import cr0s.warpdrive.command.CommandGenerate;
|
||||||
import cr0s.warpdrive.command.CommandInvisible;
|
import cr0s.warpdrive.command.CommandInvisible;
|
||||||
import cr0s.warpdrive.command.CommandJumpgates;
|
import cr0s.warpdrive.command.CommandJumpgates;
|
||||||
|
@ -750,6 +751,7 @@ public class WarpDrive implements LoadingCallback {
|
||||||
event.registerServerCommand(new CommandDebug());
|
event.registerServerCommand(new CommandDebug());
|
||||||
event.registerServerCommand(new CommandDump());
|
event.registerServerCommand(new CommandDump());
|
||||||
event.registerServerCommand(new CommandEntity());
|
event.registerServerCommand(new CommandEntity());
|
||||||
|
event.registerServerCommand(new CommandFind());
|
||||||
event.registerServerCommand(new CommandGenerate());
|
event.registerServerCommand(new CommandGenerate());
|
||||||
event.registerServerCommand(new CommandInvisible());
|
event.registerServerCommand(new CommandInvisible());
|
||||||
event.registerServerCommand(new CommandJumpgates());
|
event.registerServerCommand(new CommandJumpgates());
|
||||||
|
|
48
src/main/java/cr0s/warpdrive/command/CommandFind.java
Normal file
48
src/main/java/cr0s/warpdrive/command/CommandFind.java
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
package cr0s.warpdrive.command;
|
||||||
|
|
||||||
|
import cr0s.warpdrive.Commons;
|
||||||
|
import cr0s.warpdrive.WarpDrive;
|
||||||
|
|
||||||
|
import net.minecraft.command.CommandBase;
|
||||||
|
import net.minecraft.command.ICommandSender;
|
||||||
|
|
||||||
|
public class CommandFind extends CommandBase {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getRequiredPermissionLevel() {
|
||||||
|
return 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getCommandName() {
|
||||||
|
return "wfind";
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void processCommand(ICommandSender commandSender, String[] params) {
|
||||||
|
if (commandSender == null) { return; }
|
||||||
|
|
||||||
|
// parse arguments
|
||||||
|
//noinspection StatementWithEmptyBody
|
||||||
|
String nameToken = "";
|
||||||
|
if (params.length == 0) {
|
||||||
|
Commons.addChatMessage(commandSender, getCommandUsage(commandSender));
|
||||||
|
return;
|
||||||
|
} else if (params.length == 1) {
|
||||||
|
if (params[0].equalsIgnoreCase("help") || params[0].equalsIgnoreCase("?")) {
|
||||||
|
Commons.addChatMessage(commandSender, getCommandUsage(commandSender));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
nameToken = params[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
final String result = WarpDrive.starMap.find(nameToken);
|
||||||
|
Commons.addChatMessage(commandSender, result);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getCommandUsage(final ICommandSender commandSender) {
|
||||||
|
return getCommandName() + " (<shipName>)"
|
||||||
|
+ "\nshipName: name of the ship to find. Exact casing is preferred.";
|
||||||
|
}
|
||||||
|
}
|
|
@ -95,6 +95,72 @@ public class StarMapRegistry {
|
||||||
// not found => ignore it
|
// not found => ignore it
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String find(final String nameShip) {
|
||||||
|
final int MAX_LENGTH = 2000;
|
||||||
|
final StringBuilder resultMatch = new StringBuilder();
|
||||||
|
final StringBuilder resultCaseInsensitive = new StringBuilder();
|
||||||
|
final StringBuilder resultContains = new StringBuilder();
|
||||||
|
for (final Integer dimensionId : registry.keySet()) {
|
||||||
|
final CopyOnWriteArraySet<StarMapRegistryItem> setStarMapRegistryItems = registry.get(dimensionId);
|
||||||
|
if (setStarMapRegistryItems == null) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (final StarMapRegistryItem starMapRegistryItem : setStarMapRegistryItems) {
|
||||||
|
if (starMapRegistryItem.type == EnumStarMapEntryType.SHIP) {
|
||||||
|
if (starMapRegistryItem.name.equals(nameShip)) {
|
||||||
|
if (resultMatch.length() < MAX_LENGTH) {
|
||||||
|
if (resultMatch.length() > 0) {
|
||||||
|
resultMatch.append("\n");
|
||||||
|
}
|
||||||
|
resultMatch.append(String.format("Ship '%s' found in DIM%d @ (%d %d %d)",
|
||||||
|
starMapRegistryItem.name,
|
||||||
|
starMapRegistryItem.dimensionId,
|
||||||
|
starMapRegistryItem.x, starMapRegistryItem.y, starMapRegistryItem.z));
|
||||||
|
} else {
|
||||||
|
resultMatch.append(".");
|
||||||
|
}
|
||||||
|
} else if (starMapRegistryItem.name.equalsIgnoreCase(nameShip)) {
|
||||||
|
if (resultMatch.length() < MAX_LENGTH) {
|
||||||
|
if (resultCaseInsensitive.length() > 0) {
|
||||||
|
resultCaseInsensitive.append("\n");
|
||||||
|
}
|
||||||
|
resultCaseInsensitive.append(String.format("Ship '%s' found in DIM%d @ (%d %d %d)",
|
||||||
|
starMapRegistryItem.name,
|
||||||
|
starMapRegistryItem.dimensionId,
|
||||||
|
starMapRegistryItem.x, starMapRegistryItem.y, starMapRegistryItem.z));
|
||||||
|
} else {
|
||||||
|
resultCaseInsensitive.append(".");
|
||||||
|
}
|
||||||
|
} else if (starMapRegistryItem.name.contains(nameShip)) {
|
||||||
|
if (resultMatch.length() < MAX_LENGTH) {
|
||||||
|
if (resultContains.length() > 0) {
|
||||||
|
resultContains.append("\n");
|
||||||
|
}
|
||||||
|
resultContains.append(String.format("Ship '%s' found in DIM%d @ (%d %d %d)",
|
||||||
|
starMapRegistryItem.name,
|
||||||
|
starMapRegistryItem.dimensionId,
|
||||||
|
starMapRegistryItem.x, starMapRegistryItem.y, starMapRegistryItem.z));
|
||||||
|
} else {
|
||||||
|
resultContains.append(".");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (resultMatch.length() > 0) {
|
||||||
|
return resultMatch.toString();
|
||||||
|
}
|
||||||
|
if (resultCaseInsensitive.length() > 0) {
|
||||||
|
return resultCaseInsensitive.toString();
|
||||||
|
}
|
||||||
|
if (resultContains.length() > 0) {
|
||||||
|
return resultMatch.toString();
|
||||||
|
}
|
||||||
|
return String.format("No ship found with name '%s'", nameShip);
|
||||||
|
}
|
||||||
|
|
||||||
public void onBlockUpdated(final World world, final int x, final int y, final int z, final Block block, final int metadata) {
|
public void onBlockUpdated(final World world, final int x, final int y, final int z, final Block block, final int metadata) {
|
||||||
final CopyOnWriteArraySet<StarMapRegistryItem> setStarMapRegistryItems = registry.get(world.provider.dimensionId);
|
final CopyOnWriteArraySet<StarMapRegistryItem> setStarMapRegistryItems = registry.get(world.provider.dimensionId);
|
||||||
if (setStarMapRegistryItems == null) {
|
if (setStarMapRegistryItems == null) {
|
||||||
|
|
Loading…
Add table
Reference in a new issue