mirror of
https://github.com/IntellectualSites/PlotSquared.git
synced 2024-11-23 05:36:45 +01:00
More ported flag types, and additions to the flag API.
This commit is contained in:
parent
364c693b8c
commit
b3db67ab76
@ -6,11 +6,12 @@ import com.github.intellectualsites.plotsquared.plot.config.Captions;
|
|||||||
import com.github.intellectualsites.plotsquared.plot.config.Settings;
|
import com.github.intellectualsites.plotsquared.plot.config.Settings;
|
||||||
import com.github.intellectualsites.plotsquared.plot.database.DBFunc;
|
import com.github.intellectualsites.plotsquared.plot.database.DBFunc;
|
||||||
import com.github.intellectualsites.plotsquared.plot.flag.BlockStateListFlag;
|
import com.github.intellectualsites.plotsquared.plot.flag.BlockStateListFlag;
|
||||||
import com.github.intellectualsites.plotsquared.plot.flag.Flag;
|
|
||||||
import com.github.intellectualsites.plotsquared.plot.flag.FlagManager;
|
import com.github.intellectualsites.plotsquared.plot.flag.FlagManager;
|
||||||
import com.github.intellectualsites.plotsquared.plot.flag.Flags;
|
import com.github.intellectualsites.plotsquared.plot.flag.Flags;
|
||||||
import com.github.intellectualsites.plotsquared.plot.flag.IntegerFlag;
|
import com.github.intellectualsites.plotsquared.plot.flags.GlobalFlagContainer;
|
||||||
import com.github.intellectualsites.plotsquared.plot.flag.ListFlag;
|
import com.github.intellectualsites.plotsquared.plot.flags.PlotFlag;
|
||||||
|
import com.github.intellectualsites.plotsquared.plot.flags.types.BlockTypeListFlag;
|
||||||
|
import com.github.intellectualsites.plotsquared.plot.flags.types.IntegerFlag;
|
||||||
import com.github.intellectualsites.plotsquared.plot.object.Location;
|
import com.github.intellectualsites.plotsquared.plot.object.Location;
|
||||||
import com.github.intellectualsites.plotsquared.plot.object.Plot;
|
import com.github.intellectualsites.plotsquared.plot.object.Plot;
|
||||||
import com.github.intellectualsites.plotsquared.plot.object.PlotPlayer;
|
import com.github.intellectualsites.plotsquared.plot.object.PlotPlayer;
|
||||||
@ -37,7 +38,7 @@ import java.util.Set;
|
|||||||
"setflag"}, usage = "/plot flag <set|remove|add|list|info> <flag> <value>", description = "Set plot flags", category = CommandCategory.SETTINGS, requiredType = RequiredType.NONE, permission = "plots.flag")
|
"setflag"}, usage = "/plot flag <set|remove|add|list|info> <flag> <value>", description = "Set plot flags", category = CommandCategory.SETTINGS, requiredType = RequiredType.NONE, permission = "plots.flag")
|
||||||
public class FlagCmd extends SubCommand {
|
public class FlagCmd extends SubCommand {
|
||||||
|
|
||||||
private boolean checkPermValue(PlotPlayer player, Flag flag, String key, String value) {
|
private boolean checkPermValue(PlotPlayer player, PlotFlag<?> flag, String key, String value) {
|
||||||
key = key.toLowerCase();
|
key = key.toLowerCase();
|
||||||
value = value.toLowerCase();
|
value = value.toLowerCase();
|
||||||
String perm = Captions
|
String perm = Captions
|
||||||
@ -62,20 +63,24 @@ public class FlagCmd extends SubCommand {
|
|||||||
|
|
||||||
} catch (NumberFormatException ignore) {
|
} catch (NumberFormatException ignore) {
|
||||||
}
|
}
|
||||||
} else if (flag instanceof BlockStateListFlag) {
|
} else if (flag instanceof BlockTypeListFlag) {
|
||||||
final BlockStateListFlag blockListFlag = (BlockStateListFlag) flag;
|
final BlockTypeListFlag blockListFlag = (BlockTypeListFlag) flag;
|
||||||
Set<BlockType> parsedBlocks = blockListFlag.parseValue(value);
|
try {
|
||||||
for (final BlockType block : parsedBlocks) {
|
List<BlockType> parsedBlocks = blockListFlag.parse(value);
|
||||||
final String permission = Captions
|
for (final BlockType block : parsedBlocks) {
|
||||||
.format(Captions.PERMISSION_SET_FLAG_KEY_VALUE.getTranslated(),
|
final String permission = Captions
|
||||||
key.toLowerCase(), block.toString().toLowerCase());
|
|
||||||
final boolean result = Permissions.hasPermission(player, permission);
|
|
||||||
if (!result) {
|
|
||||||
MainUtil.sendMessage(player, Captions.NO_PERMISSION, Captions
|
|
||||||
.format(Captions.PERMISSION_SET_FLAG_KEY_VALUE.getTranslated(),
|
.format(Captions.PERMISSION_SET_FLAG_KEY_VALUE.getTranslated(),
|
||||||
key.toLowerCase(), value.toLowerCase()));
|
key.toLowerCase(), block.toString().toLowerCase());
|
||||||
return false;
|
final boolean result = Permissions.hasPermission(player, permission);
|
||||||
|
if (!result) {
|
||||||
|
MainUtil.sendMessage(player, Captions.NO_PERMISSION, Captions
|
||||||
|
.format(Captions.PERMISSION_SET_FLAG_KEY_VALUE.getTranslated(),
|
||||||
|
key.toLowerCase(), value.toLowerCase()));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
} catch (final Exception e) {
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -117,13 +122,13 @@ public class FlagCmd extends SubCommand {
|
|||||||
.sendMessage(player, Captions.NO_PERMISSION, Captions.PERMISSION_SET_FLAG_OTHER);
|
.sendMessage(player, Captions.NO_PERMISSION, Captions.PERMISSION_SET_FLAG_OTHER);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
Flag<?> flag = null;
|
PlotFlag<?> flag = null;
|
||||||
if (args.length > 1) {
|
if (args.length > 1) {
|
||||||
flag = FlagManager.getFlag(args[1]);
|
flag = GlobalFlagContainer.getInstance().getFlagFromString(args[1]);
|
||||||
if (flag == null || flag.isReserved()) {
|
if (flag == null || flag.isReserved()) {
|
||||||
boolean suggested = false;
|
boolean suggested = false;
|
||||||
try {
|
try {
|
||||||
StringComparison<Flag<?>> stringComparison =
|
StringComparison<PlotFlag<?>> stringComparison =
|
||||||
new StringComparison<>(args[1], Flags.getFlags());
|
new StringComparison<>(args[1], Flags.getFlags());
|
||||||
String best = stringComparison.getBestMatch();
|
String best = stringComparison.getBestMatch();
|
||||||
if (best != null) {
|
if (best != null) {
|
||||||
|
@ -548,6 +548,9 @@ public enum Captions {
|
|||||||
FLAG_CATEGORY_BOOLEAN("Boolean Flags", "Flags"),
|
FLAG_CATEGORY_BOOLEAN("Boolean Flags", "Flags"),
|
||||||
FLAG_CATEGORY_MIXED("Mixed Value Flags", "Flags"),
|
FLAG_CATEGORY_MIXED("Mixed Value Flags", "Flags"),
|
||||||
//</editor-fold>
|
//</editor-fold>
|
||||||
|
//<editor-fold desc="Flag descriptions">
|
||||||
|
FLAG_DESCRIPTION_EXPLOSION("Set to 'true' to enable explosions in the plot, and 'false' to disable them", "Flags"),
|
||||||
|
//</editor-fold>
|
||||||
//<editor-fold desc="Flag category errors">
|
//<editor-fold desc="Flag category errors">
|
||||||
FLAG_ERROR_BOOLEAN("Flag value must be a boolean (true|false)", "Flags"),
|
FLAG_ERROR_BOOLEAN("Flag value must be a boolean (true|false)", "Flags"),
|
||||||
FLAG_ERROR_ENUM("Must be one of: %s", "Flags"),
|
FLAG_ERROR_ENUM("Must be one of: %s", "Flags"),
|
||||||
@ -558,6 +561,7 @@ public enum Captions {
|
|||||||
FLAG_ERROR_KEEP("Flag value must be a timestamp or a boolean", "Flags"),
|
FLAG_ERROR_KEEP("Flag value must be a timestamp or a boolean", "Flags"),
|
||||||
FLAG_ERROR_LONG("Flag value must be a whole number (large numbers allowed)", "Flags"),
|
FLAG_ERROR_LONG("Flag value must be a whole number (large numbers allowed)", "Flags"),
|
||||||
FLAG_ERROR_PLOTBLOCKLIST("Flag value must be a block list", "Flags"),
|
FLAG_ERROR_PLOTBLOCKLIST("Flag value must be a block list", "Flags"),
|
||||||
|
FLAG_ERROR_INVALID_BLOCK("The provided value is not a valid block", "Flags"),
|
||||||
FLAG_ERROR_PRICE("Flag value must be a positive number.", "Flags"),
|
FLAG_ERROR_PRICE("Flag value must be a positive number.", "Flags"),
|
||||||
FLAG_ERROR_STRING("Flag value must be alphanumeric. Some special characters are allowed.", "Flags"),
|
FLAG_ERROR_STRING("Flag value must be alphanumeric. Some special characters are allowed.", "Flags"),
|
||||||
FLAG_ERROR_STRINGLIST("Flag value must be a string list", "Flags"),
|
FLAG_ERROR_STRINGLIST("Flag value must be a string list", "Flags"),
|
||||||
|
@ -50,6 +50,18 @@ import java.util.Map;
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public PlotFlag<?> getFlagErased(Class<?> flagClass) {
|
||||||
|
final PlotFlag<?> flag = this.flagMap.get(flagClass);
|
||||||
|
if (flag != null) {
|
||||||
|
return flag;
|
||||||
|
} else {
|
||||||
|
if (getParentContainer() != null) {
|
||||||
|
return getParentContainer().getFlagErased(flagClass);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
public <T> PlotFlag<T> getFlag(final Class<? extends PlotFlag<T>> flagClass) {
|
public <T> PlotFlag<T> getFlag(final Class<? extends PlotFlag<T>> flagClass) {
|
||||||
final PlotFlag<?> flag = this.flagMap.get(flagClass);
|
final PlotFlag<?> flag = this.flagMap.get(flagClass);
|
||||||
if (flag != null) {
|
if (flag != null) {
|
||||||
|
@ -1,15 +1,19 @@
|
|||||||
package com.github.intellectualsites.plotsquared.plot.flags;
|
package com.github.intellectualsites.plotsquared.plot.flags;
|
||||||
|
|
||||||
|
import com.github.intellectualsites.plotsquared.plot.config.Captions;
|
||||||
|
|
||||||
public class FlagParseException extends Exception {
|
public class FlagParseException extends Exception {
|
||||||
|
|
||||||
private final PlotFlag<?> flag;
|
private final PlotFlag<?> flag;
|
||||||
private final String value;
|
private final String value;
|
||||||
|
private final Captions errorMessage;
|
||||||
|
|
||||||
public FlagParseException(final PlotFlag<?> flag, final String value) {
|
public FlagParseException(final PlotFlag<?> flag, final String value, final Captions errorMessage) {
|
||||||
super(String.format("Failed to parse flag of type '%s'. Value '%s' was not accepted.",
|
super(String.format("Failed to parse flag of type '%s'. Value '%s' was not accepted.",
|
||||||
flag.getName(), value));
|
flag.getName(), value));
|
||||||
this.flag = flag;
|
this.flag = flag;
|
||||||
this.value = value;
|
this.value = value;
|
||||||
|
this.errorMessage = errorMessage;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -30,4 +34,7 @@ public class FlagParseException extends Exception {
|
|||||||
return this.flag;
|
return this.flag;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Captions getErrorMessage() {
|
||||||
|
return errorMessage;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -4,11 +4,26 @@ import com.github.intellectualsites.plotsquared.plot.flags.implementations.Explo
|
|||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
|
|
||||||
import javax.annotation.Nonnull;
|
import javax.annotation.Nonnull;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Locale;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
public final class GlobalFlagContainer extends FlagContainer {
|
public final class GlobalFlagContainer extends FlagContainer {
|
||||||
|
|
||||||
@Getter private static final GlobalFlagContainer instance = new GlobalFlagContainer();
|
@Getter private static final GlobalFlagContainer instance = new GlobalFlagContainer();
|
||||||
|
|
||||||
|
private final Map<String, Class<?>> stringClassMap = new HashMap<>();
|
||||||
|
|
||||||
|
@Override public PlotFlag<?> getFlagErased(Class<?> flagClass) {
|
||||||
|
final PlotFlag<?> flag = super.getFlagErased(flagClass);
|
||||||
|
if (flag != null) {
|
||||||
|
return flag;
|
||||||
|
} else {
|
||||||
|
throw new IllegalStateException(String.format("Unrecognized flag '%s'. All flag types"
|
||||||
|
+ " must be present in the global flag container.", flagClass.getSimpleName()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Nonnull @Override public <T> PlotFlag<T> getFlag(Class<? extends PlotFlag<T>> flagClass) {
|
@Nonnull @Override public <T> PlotFlag<T> getFlag(Class<? extends PlotFlag<T>> flagClass) {
|
||||||
final PlotFlag<?> flag = super.getFlag(flagClass);
|
final PlotFlag<?> flag = super.getFlag(flagClass);
|
||||||
if (flag != null) {
|
if (flag != null) {
|
||||||
@ -25,4 +40,21 @@ public final class GlobalFlagContainer extends FlagContainer {
|
|||||||
this.addFlag(new ExplosionFlag());
|
this.addFlag(new ExplosionFlag());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override public void addFlag(PlotFlag<?> flag) {
|
||||||
|
super.addFlag(flag);
|
||||||
|
this.stringClassMap.put(flag.getName().toLowerCase(Locale.ENGLISH), flag.getClass());
|
||||||
|
}
|
||||||
|
|
||||||
|
public Class<?> getFlagClassFromString(final String name) {
|
||||||
|
return this.stringClassMap.get(name.toLowerCase(Locale.ENGLISH));
|
||||||
|
}
|
||||||
|
|
||||||
|
public PlotFlag<?> getFlagFromString(final String name) {
|
||||||
|
final Class<?> flagClass = this.getFlagClassFromString(name);
|
||||||
|
if (flagClass == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
return getFlagErased(flagClass);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,9 +1,12 @@
|
|||||||
package com.github.intellectualsites.plotsquared.plot.flags;
|
package com.github.intellectualsites.plotsquared.plot.flags;
|
||||||
|
|
||||||
|
import com.github.intellectualsites.plotsquared.plot.config.Captions;
|
||||||
import com.google.common.base.Preconditions;
|
import com.google.common.base.Preconditions;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
import java.util.Locale;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A plot flag is any property that can be assigned
|
* A plot flag is any property that can be assigned
|
||||||
* to a plot, that will alter its functionality in some way.
|
* to a plot, that will alter its functionality in some way.
|
||||||
@ -14,14 +17,19 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
@EqualsAndHashCode(of = "value") public abstract class PlotFlag<T> {
|
@EqualsAndHashCode(of = "value") public abstract class PlotFlag<T> {
|
||||||
|
|
||||||
private T value;
|
private T value;
|
||||||
|
private final Captions flagCategory;
|
||||||
|
private final Captions flagDescription;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Construct a new flag instance.
|
* Construct a new flag instance.
|
||||||
*
|
*
|
||||||
* @param value Flag value
|
* @param value Flag value
|
||||||
*/
|
*/
|
||||||
protected PlotFlag(@NotNull final T value) {
|
protected PlotFlag(@NotNull final T value, @NotNull final Captions flagCategory,
|
||||||
this.value = Preconditions.checkNotNull(value, "flag values may not be null");
|
@NotNull final Captions flagDescription) {
|
||||||
|
this.value = Preconditions.checkNotNull(value, "flag value may not be null");
|
||||||
|
this.flagCategory = Preconditions.checkNotNull(flagCategory, "flag category may not be null");
|
||||||
|
this.flagDescription = Preconditions.checkNotNull(flagDescription, "flag description may not be null");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -72,7 +80,17 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
public abstract String toString();
|
public abstract String toString();
|
||||||
|
|
||||||
public final String getName() {
|
public final String getName() {
|
||||||
return this.getClass().getSimpleName();
|
return this.getClass().getSimpleName().toLowerCase(Locale.ENGLISH);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Captions getFlagDescription() {
|
||||||
|
return this.flagDescription;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Captions getFlagCategory() {
|
||||||
|
return this.flagCategory;
|
||||||
|
}
|
||||||
|
|
||||||
|
public abstract String getExample();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,16 @@
|
|||||||
package com.github.intellectualsites.plotsquared.plot.flags.implementations;
|
package com.github.intellectualsites.plotsquared.plot.flags.implementations;
|
||||||
|
|
||||||
|
import com.github.intellectualsites.plotsquared.plot.config.Captions;
|
||||||
import com.github.intellectualsites.plotsquared.plot.flags.types.BooleanFlag;
|
import com.github.intellectualsites.plotsquared.plot.flags.types.BooleanFlag;
|
||||||
|
|
||||||
public class ExplosionFlag extends BooleanFlag {
|
public class ExplosionFlag extends BooleanFlag {
|
||||||
|
|
||||||
|
public ExplosionFlag() {
|
||||||
|
super(Captions.FLAG_DESCRIPTION_EXPLOSION);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override public String getExample() {
|
||||||
|
return "true";
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,40 @@
|
|||||||
|
package com.github.intellectualsites.plotsquared.plot.flags.types;
|
||||||
|
|
||||||
|
import com.github.intellectualsites.plotsquared.plot.config.Captions;
|
||||||
|
import com.github.intellectualsites.plotsquared.plot.flags.FlagParseException;
|
||||||
|
import com.github.intellectualsites.plotsquared.plot.util.world.BlockUtil;
|
||||||
|
import com.sk89q.worldedit.world.block.BlockState;
|
||||||
|
import com.sk89q.worldedit.world.block.BlockType;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class BlockTypeListFlag extends ListFlag<BlockType> {
|
||||||
|
|
||||||
|
public BlockTypeListFlag(Captions description) {
|
||||||
|
super(Captions.FLAG_CATEGORY_BLOCK_LIST, description);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override public List<BlockType> parse(@NotNull String input) throws FlagParseException {
|
||||||
|
final List<BlockType> parsedBlocks = new ArrayList<>();
|
||||||
|
final String[] split = input.split(",(?![^\\(\\[]*[\\]\\)])");
|
||||||
|
if (split.length == 0) {
|
||||||
|
return parsedBlocks;
|
||||||
|
}
|
||||||
|
for (final String blockString : split) {
|
||||||
|
final BlockState blockState = BlockUtil.get(blockString);
|
||||||
|
if (blockState == null) {
|
||||||
|
throw new FlagParseException(this, blockString, Captions.FLAG_ERROR_INVALID_BLOCK);
|
||||||
|
} else {
|
||||||
|
parsedBlocks.add(blockState.getBlockType());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return parsedBlocks;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override public String getExample() {
|
||||||
|
return "air,grass_block";
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -1,5 +1,6 @@
|
|||||||
package com.github.intellectualsites.plotsquared.plot.flags.types;
|
package com.github.intellectualsites.plotsquared.plot.flags.types;
|
||||||
|
|
||||||
|
import com.github.intellectualsites.plotsquared.plot.config.Captions;
|
||||||
import com.github.intellectualsites.plotsquared.plot.flags.FlagParseException;
|
import com.github.intellectualsites.plotsquared.plot.flags.FlagParseException;
|
||||||
import com.github.intellectualsites.plotsquared.plot.flags.PlotFlag;
|
import com.github.intellectualsites.plotsquared.plot.flags.PlotFlag;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
@ -17,26 +18,29 @@ public abstract class BooleanFlag extends PlotFlag<Boolean> {
|
|||||||
* Construct a new flag instance.
|
* Construct a new flag instance.
|
||||||
*
|
*
|
||||||
* @param value Flag value
|
* @param value Flag value
|
||||||
|
* @param description Flag description
|
||||||
*/
|
*/
|
||||||
protected BooleanFlag(boolean value) {
|
protected BooleanFlag(final boolean value, final Captions description) {
|
||||||
super(value);
|
super(value, Captions.FLAG_CATEGORY_BOOLEAN, description);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Construct a new boolean flag, with
|
* Construct a new boolean flag, with
|
||||||
* {@code false} as the default value.
|
* {@code false} as the default value.
|
||||||
|
*
|
||||||
|
* @param description Flag description
|
||||||
*/
|
*/
|
||||||
protected BooleanFlag() {
|
protected BooleanFlag(final Captions description) {
|
||||||
this(false);
|
this(false, description);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override public Boolean parse(@NotNull String input) throws FlagParseException {
|
@Override public Boolean parse(@NotNull String input) throws FlagParseException {
|
||||||
if (positiveValues.contains(input.toLowerCase(Locale.ENGLISH))) {
|
if (positiveValues.contains(input.toLowerCase(Locale.ENGLISH))) {
|
||||||
return this.setFlagValue(true);
|
return true;
|
||||||
} else if (negativeValues.contains(input.toLowerCase(Locale.ENGLISH))) {
|
} else if (negativeValues.contains(input.toLowerCase(Locale.ENGLISH))) {
|
||||||
return this.setFlagValue(false);
|
return false;
|
||||||
} else {
|
} else {
|
||||||
throw new FlagParseException(this, input);
|
throw new FlagParseException(this, input, Captions.FLAG_ERROR_BOOLEAN);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -0,0 +1,38 @@
|
|||||||
|
package com.github.intellectualsites.plotsquared.plot.flags.types;
|
||||||
|
|
||||||
|
import com.github.intellectualsites.plotsquared.plot.config.Captions;
|
||||||
|
import com.github.intellectualsites.plotsquared.plot.flags.FlagParseException;
|
||||||
|
import com.github.intellectualsites.plotsquared.plot.flags.PlotFlag;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
public class IntegerFlag extends PlotFlag<Integer> {
|
||||||
|
|
||||||
|
protected IntegerFlag(final int defaultValue, @NotNull Captions flagDescription) {
|
||||||
|
super(defaultValue, Captions.FLAG_CATEGORY_INTEGERS, flagDescription);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected IntegerFlag(@NotNull Captions flagDescription) {
|
||||||
|
this(0, flagDescription);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override public Integer parse(@NotNull String input) throws FlagParseException {
|
||||||
|
try {
|
||||||
|
return Integer.parseInt(input);
|
||||||
|
} catch (final Throwable throwable) {
|
||||||
|
throw new FlagParseException(this, input, Captions.FLAG_ERROR_INTEGER);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override public Integer merge(@NotNull Integer oldValue, @NotNull Integer newValue) {
|
||||||
|
return oldValue + newValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override public String toString() {
|
||||||
|
return this.getValue().toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override public String getExample() {
|
||||||
|
return "10";
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,27 @@
|
|||||||
|
package com.github.intellectualsites.plotsquared.plot.flags.types;
|
||||||
|
|
||||||
|
import com.github.intellectualsites.plotsquared.plot.config.Captions;
|
||||||
|
import com.github.intellectualsites.plotsquared.plot.flags.PlotFlag;
|
||||||
|
import com.github.intellectualsites.plotsquared.plot.util.StringMan;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public abstract class ListFlag<V> extends PlotFlag<List<V>> {
|
||||||
|
|
||||||
|
public ListFlag(final Captions category, final Captions description) {
|
||||||
|
super(new ArrayList<>(), category, description);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override public List<V> merge(@NotNull List<V> oldValue, @NotNull List<V> newValue) {
|
||||||
|
final List<V> mergedList = new ArrayList<>();
|
||||||
|
mergedList.addAll(oldValue);
|
||||||
|
mergedList.addAll(newValue);
|
||||||
|
return this.setFlagValue(mergedList);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override public String toString() {
|
||||||
|
return StringMan.join(this.getValue(), ",");
|
||||||
|
}
|
||||||
|
}
|
@ -18,9 +18,9 @@ import java.util.Map;
|
|||||||
public final class BlockUtil {
|
public final class BlockUtil {
|
||||||
private BlockUtil(){}
|
private BlockUtil(){}
|
||||||
|
|
||||||
private static final ParserContext PARSER_CONTEXT = new ParserContext();
|
private static ParserContext PARSER_CONTEXT = new ParserContext();
|
||||||
|
|
||||||
private static final InputParser<BaseBlock> PARSER;
|
private static InputParser<BaseBlock> PARSER;
|
||||||
|
|
||||||
static {
|
static {
|
||||||
PARSER_CONTEXT.setRestricted(false);
|
PARSER_CONTEXT.setRestricted(false);
|
||||||
@ -29,15 +29,15 @@ public final class BlockUtil {
|
|||||||
PARSER = WorldEdit.getInstance().getBlockFactory().getParsers().get(0);
|
PARSER = WorldEdit.getInstance().getBlockFactory().getParsers().get(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static final BlockState get(int id) {
|
public static BlockState get(int id) {
|
||||||
return LegacyMapper.getInstance().getBlockFromLegacy(id);
|
return LegacyMapper.getInstance().getBlockFromLegacy(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static final BlockState get(int id, int data) {
|
public static BlockState get(int id, int data) {
|
||||||
return LegacyMapper.getInstance().getBlockFromLegacy(id, data);
|
return LegacyMapper.getInstance().getBlockFromLegacy(id, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static final BlockState get(String id) {
|
public static BlockState get(String id) {
|
||||||
if (id.length() == 1 && id.charAt(0) == '*') {
|
if (id.length() == 1 && id.charAt(0) == '*') {
|
||||||
return FuzzyBlockState.builder().type(BlockTypes.AIR).build();
|
return FuzzyBlockState.builder().type(BlockTypes.AIR).build();
|
||||||
}
|
}
|
||||||
@ -66,7 +66,7 @@ public final class BlockUtil {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static final BlockState[] parse(String commaDelimited) {
|
public static BlockState[] parse(String commaDelimited) {
|
||||||
String[] split = commaDelimited.split(",(?![^\\(\\[]*[\\]\\)])");
|
String[] split = commaDelimited.split(",(?![^\\(\\[]*[\\]\\)])");
|
||||||
BlockState[] result = new BlockState[split.length];
|
BlockState[] result = new BlockState[split.length];
|
||||||
for (int i = 0; i < split.length; i++) {
|
for (int i = 0; i < split.length; i++) {
|
||||||
|
Loading…
Reference in New Issue
Block a user