mirror of
https://github.com/EngineHub/WorldGuard.git
synced 2025-01-13 11:41:43 +01:00
Reimplemented the quirks of the old flag code.
This commit is contained in:
parent
d9d665ab14
commit
cab42af53b
@ -22,6 +22,7 @@
|
||||
import com.sk89q.worldguard.LocalPlayer;
|
||||
import com.sk89q.worldguard.protection.ApplicableRegionSet;
|
||||
import com.sk89q.worldguard.protection.GlobalRegionManager;
|
||||
import com.sk89q.worldguard.protection.flags.DefaultFlag;
|
||||
import com.sk89q.worldguard.protection.flags.Flag;
|
||||
import com.sk89q.worldguard.protection.flags.StateFlag;
|
||||
import com.sk89q.worldguard.protection.flags.StateFlag.State;
|
||||
@ -96,10 +97,12 @@ public ApplicableRegionSet getApplicableRegions(Location location) {
|
||||
}
|
||||
|
||||
/**
|
||||
* Test whether the given player is permitted to modify or interact with
|
||||
* blocks at the given location. Additional flags to be considered can be
|
||||
* provided. The {@code BUILD} flag is already included in the list of
|
||||
* flags considered.
|
||||
* Test whether the given flags evaluate to {@code ALLOW}, implicitly also
|
||||
* considering the {@link DefaultFlag#BUILD} flag.
|
||||
*
|
||||
* <p>This method is equivalent to calling
|
||||
* {@link #testState(Location, Player, StateFlag...)} with
|
||||
* {@code flags} plus the {@code BUILD} flag.</p>
|
||||
*
|
||||
* @param location the location
|
||||
* @param player the player
|
||||
@ -128,19 +131,14 @@ public boolean testBuild(Location location, Player player, StateFlag... flags) {
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the effective value for a flag. If there are multiple values
|
||||
* (for example, if there are multiple regions with the same priority
|
||||
* but with different farewell messages set, there would be multiple
|
||||
* completing values), then the selected (or "winning") value will depend
|
||||
* on the flag type.
|
||||
* Test whether the (effective) value for a list of state flags equals
|
||||
* {@code ALLOW}.
|
||||
*
|
||||
* <p>This method does <strong>not</strong> properly process build
|
||||
* permissions. Instead, use {@link #testBuild(Location, Player, StateFlag...)}
|
||||
* for that purpose.</p>
|
||||
*
|
||||
* <p>This method does the same as
|
||||
* {@link #queryState(Location, Player, StateFlag...)} except that it
|
||||
* returns a boolean when the result is {@code ALLOW}.</p>
|
||||
* <p>{@code player} can be non-null to satisfy region group requirements,
|
||||
* otherwise it will be assumed that the caller that is not a member of any
|
||||
* regions. (Flags on a region can be changed so that they only apply
|
||||
* to certain users.) The player argument is required if the
|
||||
* {@link DefaultFlag#BUILD} flag is in the list of flags.</p>
|
||||
*
|
||||
* @param location the location
|
||||
* @param player an optional player, which would be used to determine the region group to apply
|
||||
@ -148,21 +146,20 @@ public boolean testBuild(Location location, Player player, StateFlag... flags) {
|
||||
* @return true if the result was {@code ALLOW}
|
||||
* @see ApplicableRegionSet#queryValue(LocalPlayer, Flag)
|
||||
*/
|
||||
public boolean testState(Location location, @Nullable Player player, StateFlag flag) {
|
||||
public boolean testState(Location location, @Nullable Player player, StateFlag... flag) {
|
||||
return StateFlag.test(queryState(location, player, flag));
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the effective value for a list of state flags. The rules of
|
||||
* Get the (effective) value for a list of state flags. The rules of
|
||||
* states is observed here; that is, {@code DENY} overrides {@code ALLOW},
|
||||
* and {@code ALLOW} overrides {@code NONE}.
|
||||
* and {@code ALLOW} overrides {@code NONE}. One flag may override another.
|
||||
*
|
||||
* <p>This method does <strong>not</strong> properly process build
|
||||
* permissions. Instead, use {@link #testBuild(Location, Player, StateFlag...)}
|
||||
* for that purpose.</p>
|
||||
*
|
||||
* See {@link ApplicableRegionSet#queryState(LocalPlayer, StateFlag...)}
|
||||
* for more information.
|
||||
* <p>{@code player} can be non-null to satisfy region group requirements,
|
||||
* otherwise it will be assumed that the caller that is not a member of any
|
||||
* regions. (Flags on a region can be changed so that they only apply
|
||||
* to certain users.) The player argument is required if the
|
||||
* {@link DefaultFlag#BUILD} flag is in the list of flags.</p>
|
||||
*
|
||||
* @param location the location
|
||||
* @param player an optional player, which would be used to determine the region groups that apply
|
||||
@ -178,17 +175,21 @@ public State queryState(Location location, @Nullable Player player, StateFlag...
|
||||
|
||||
/**
|
||||
* Get the effective value for a flag. If there are multiple values
|
||||
* (for example, if there are multiple regions with the same priority
|
||||
* but with different farewell messages set, there would be multiple
|
||||
* completing values), then the selected (or "winning") value will depend
|
||||
* on the flag type.
|
||||
* (for example, multiple overlapping regions with
|
||||
* the same priority may have the same flag set), then the selected
|
||||
* (or "winning") value will depend on the flag type.
|
||||
*
|
||||
* <p>This method does <strong>not</strong> properly process build
|
||||
* permissions. Instead, use {@link #testBuild(Location, Player, StateFlag...)}
|
||||
* for that purpose.</p>
|
||||
* <p>Only some flag types actually have a strategy for picking the
|
||||
* "best value." For most types, the actual value that is chosen to be
|
||||
* returned is undefined (it could be any value). As of writing, the only
|
||||
* type of flag that actually has a strategy for picking a value is the
|
||||
* {@link StateFlag}.</p>
|
||||
*
|
||||
* <p>See {@link ApplicableRegionSet#queryValue(LocalPlayer, Flag)} for
|
||||
* more information.</p>
|
||||
* <p>{@code player} can be non-null to satisfy region group requirements,
|
||||
* otherwise it will be assumed that the caller that is not a member of any
|
||||
* regions. (Flags on a region can be changed so that they only apply
|
||||
* to certain users.) The player argument is required if the
|
||||
* {@link DefaultFlag#BUILD} flag is the flag being queried.</p>
|
||||
*
|
||||
* @param location the location
|
||||
* @param player an optional player, which would be used to determine the region group to apply
|
||||
@ -207,12 +208,11 @@ public <V> V queryValue(Location location, @Nullable Player player, Flag<V> flag
|
||||
* values. It is up to the caller to determine which value, if any,
|
||||
* from the collection will be used.
|
||||
*
|
||||
* <p>This method does <strong>not</strong> properly process build
|
||||
* permissions. Instead, use {@link #testBuild(Location, Player, StateFlag...)}
|
||||
* for that purpose.</p>
|
||||
*
|
||||
* <p>See {@link ApplicableRegionSet#queryAllValues(LocalPlayer, Flag)}
|
||||
* for more information.</p>
|
||||
* <p>{@code player} can be non-null to satisfy region group requirements,
|
||||
* otherwise it will be assumed that the caller that is not a member of any
|
||||
* regions. (Flags on a region can be changed so that they only apply
|
||||
* to certain users.) The player argument is required if the
|
||||
* {@link DefaultFlag#BUILD} flag is the flag being queried.</p>
|
||||
*
|
||||
* @param location the location
|
||||
* @param player an optional player, which would be used to determine the region group to apply
|
||||
|
@ -97,43 +97,56 @@ public ApplicableRegionSet(SortedSet<ProtectedRegion> applicable, @Nullable Prot
|
||||
@Deprecated
|
||||
public boolean canBuild(LocalPlayer player) {
|
||||
checkNotNull(player);
|
||||
return test(flagValueCalculator.queryPermission(player, DefaultFlag.BUILD));
|
||||
return test(flagValueCalculator.queryState(player, DefaultFlag.BUILD));
|
||||
}
|
||||
|
||||
/**
|
||||
* Test whether the given player is permitted to modify or interact with
|
||||
* blocks. Additional flags to be considered can be provided. The
|
||||
* {@code BUILD} flag is already included in the list of flags considered.
|
||||
* Test whether the given flags evaluate to {@code ALLOW}, implicitly also
|
||||
* considering the {@link DefaultFlag#BUILD} flag.
|
||||
*
|
||||
* <p>This method is equivalent to calling
|
||||
* {@link #testState(LocalPlayer, StateFlag...)} with {@code flags} plus
|
||||
* the {@code BUILD} flag.</p>
|
||||
*
|
||||
* @param player the player
|
||||
* @param flags zero or more flags
|
||||
* @return true if permission is granted
|
||||
* @see #queryState(LocalPlayer, StateFlag...)
|
||||
*/
|
||||
public boolean testBuild(LocalPlayer player, StateFlag... flags) {
|
||||
return test(flagValueCalculator.queryPermission(player, ObjectArrays.concat(flags, DefaultFlag.BUILD)));
|
||||
checkNotNull(player);
|
||||
return test(flagValueCalculator.queryState(player, ObjectArrays.concat(flags, DefaultFlag.BUILD)));
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the effective value for a list of state flags. The rules of
|
||||
* Test whether the (effective) value for a list of state flags equals
|
||||
* {@code ALLOW}.
|
||||
*
|
||||
* <p>{@code player} can be non-null to satisfy region group requirements,
|
||||
* otherwise it will be assumed that the caller that is not a member of any
|
||||
* regions. (Flags on a region can be changed so that they only apply
|
||||
* to certain users.) The player argument is required if the
|
||||
* {@link DefaultFlag#BUILD} flag is in the list of flags.</p>
|
||||
*
|
||||
* @param player an optional player, which would be used to determine the region groups that apply
|
||||
* @param flags a list of flags to check
|
||||
* @return true if the result was {@code ALLOW}
|
||||
* @see #queryState(LocalPlayer, StateFlag...)
|
||||
*/
|
||||
public boolean testState(@Nullable LocalPlayer player, StateFlag... flags) {
|
||||
return test(flagValueCalculator.queryState(player, flags));
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the (effective) value for a list of state flags. The rules of
|
||||
* states is observed here; that is, {@code DENY} overrides {@code ALLOW},
|
||||
* and {@code ALLOW} overrides {@code NONE}.
|
||||
* and {@code ALLOW} overrides {@code NONE}. One flag may override another.
|
||||
*
|
||||
* <p>This method does <strong>not</strong> properly process build
|
||||
* permissions. Instead, use {@link #testBuild(LocalPlayer, StateFlag...)}
|
||||
* for that purpose. This method is ideal for testing non-build related
|
||||
* state flags (although a rarity), an example of which would be whether
|
||||
* to play a song to players that enter an area.</p>
|
||||
*
|
||||
* <p>A player can be provided that is used to determine whether the value
|
||||
* of a flag on a particular region should be used. For example, if a
|
||||
* flag's region group is set to {@link RegionGroup#MEMBERS} and the given
|
||||
* player is not a member, then the region would be skipped when
|
||||
* querying that flag. If {@code null} is provided for the player, then
|
||||
* only flags that use {@link RegionGroup#ALL},
|
||||
* {@link RegionGroup#NON_MEMBERS}, etc. will apply.</p>
|
||||
*
|
||||
* <p>This method does <strong>not</strong> use a {@link StateFlag}'s
|
||||
* default value ({@link StateFlag#getDefault()}).</p>
|
||||
* <p>{@code player} can be non-null to satisfy region group requirements,
|
||||
* otherwise it will be assumed that the caller that is not a member of any
|
||||
* regions. (Flags on a region can be changed so that they only apply
|
||||
* to certain users.) The player argument is required if the
|
||||
* {@link DefaultFlag#BUILD} flag is in the list of flags.</p>
|
||||
*
|
||||
* @param player an optional player, which would be used to determine the region groups that apply
|
||||
* @param flags a list of flags to check
|
||||
@ -144,51 +157,23 @@ public State queryState(@Nullable LocalPlayer player, StateFlag... flags) {
|
||||
return flagValueCalculator.queryState(player, flags);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the effective value for a list of state flags. The rules of
|
||||
* states is observed here; that is, {@code DENY} overrides {@code ALLOW},
|
||||
* and {@code ALLOW} overrides {@code NONE}.
|
||||
*
|
||||
* <p>This method is the same as
|
||||
* {@link #queryState(LocalPlayer, StateFlag...)} except that it returns
|
||||
* a boolean when the return value is {@code ALLOW}.</p>
|
||||
*
|
||||
* @param player an optional player, which would be used to determine the region groups that apply
|
||||
* @param flags a list of flags to check
|
||||
* @return true if the result was {@code ALLOW}
|
||||
*/
|
||||
public boolean testState(@Nullable LocalPlayer player, StateFlag... flags) {
|
||||
return test(flagValueCalculator.queryState(player, flags));
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the effective value for a flag. If there are multiple values
|
||||
* (for example, if there are multiple regions with the same priority
|
||||
* but with different farewell messages set, there would be multiple
|
||||
* completing values), then the selected (or "winning") value will depend
|
||||
* on the flag type.
|
||||
* (for example, multiple overlapping regions with
|
||||
* the same priority may have the same flag set), then the selected
|
||||
* (or "winning") value will depend on the flag type.
|
||||
*
|
||||
* <p>Only some flag types actually have a strategy for picking the
|
||||
* "best value." For most types, the actual value that is chosen to be
|
||||
* returned is undefined (it could be any value). As of writing, the only
|
||||
* type of flag that can consistently return the same 'best' value is
|
||||
* type of flag that actually has a strategy for picking a value is the
|
||||
* {@link StateFlag}.</p>
|
||||
*
|
||||
* <p>This method does <strong>not</strong> properly process build
|
||||
* permissions. Instead, use {@link #testBuild(LocalPlayer, StateFlag...)}
|
||||
* for that purpose.</p>
|
||||
*
|
||||
* <p>A player can be provided that is used to determine whether the value
|
||||
* of a flag on a particular region should be used. For example, if a
|
||||
* flag's region group is set to {@link RegionGroup#MEMBERS} and the given
|
||||
* player is not a member, then the region would be skipped when
|
||||
* querying that flag. If {@code null} is provided for the player, then
|
||||
* only flags that use {@link RegionGroup#ALL},
|
||||
* {@link RegionGroup#NON_MEMBERS}, etc. will apply.</p>
|
||||
*
|
||||
* <p>This method does <strong>not</strong> use a {@link StateFlag}'s
|
||||
* default value ({@link StateFlag#getDefault()}) if the provided flag is
|
||||
* a {@code StateFlag}.</p>
|
||||
* <p>{@code player} can be non-null to satisfy region group requirements,
|
||||
* otherwise it will be assumed that the caller that is not a member of any
|
||||
* regions. (Flags on a region can be changed so that they only apply
|
||||
* to certain users.) The player argument is required if the
|
||||
* {@link DefaultFlag#BUILD} flag is the flag being queried.</p>
|
||||
*
|
||||
* @param player an optional player, which would be used to determine the region group to apply
|
||||
* @param flag the flag
|
||||
@ -204,21 +189,11 @@ public <V> V queryValue(@Nullable LocalPlayer player, Flag<V> flag) {
|
||||
* values. It is up to the caller to determine which value, if any,
|
||||
* from the collection will be used.
|
||||
*
|
||||
* <p>This method does <strong>not</strong> properly process build
|
||||
* permissions. Instead, use {@link #testBuild(LocalPlayer, StateFlag...)}
|
||||
* for that purpose.</p>
|
||||
*
|
||||
* <p>A player can be provided that is used to determine whether the value
|
||||
* of a flag on a particular region should be used. For example, if a
|
||||
* flag's region group is set to {@link RegionGroup#MEMBERS} and the given
|
||||
* player is not a member, then the region would be skipped when
|
||||
* querying that flag. If {@code null} is provided for the player, then
|
||||
* only flags that use {@link RegionGroup#ALL},
|
||||
* {@link RegionGroup#NON_MEMBERS}, etc. will apply.</p>
|
||||
*
|
||||
* <p>This method does <strong>not</strong> include a {@link StateFlag}'s
|
||||
* default value ({@link StateFlag#getDefault()}) if the provided flag is
|
||||
* a {@code StateFlag}.</p>
|
||||
* <p>{@code player} can be non-null to satisfy region group requirements,
|
||||
* otherwise it will be assumed that the caller that is not a member of any
|
||||
* regions. (Flags on a region can be changed so that they only apply
|
||||
* to certain users.) The player argument is required if the
|
||||
* {@link DefaultFlag#BUILD} flag is the flag being queried.</p>
|
||||
*
|
||||
* @param player an optional player, which would be used to determine the region group to apply
|
||||
* @param flag the flag
|
||||
@ -249,12 +224,7 @@ public boolean canConstruct(LocalPlayer player) {
|
||||
* @param flag flag to check
|
||||
* @return whether it is allowed
|
||||
* @throws IllegalArgumentException if the build flag is given
|
||||
* @deprecated Use {@link #queryState(LocalPlayer, StateFlag...)} instead, although
|
||||
* be aware that the default value of the flag is <strong>not</strong>
|
||||
* considered in that method. Default values, however, are being
|
||||
* deprecated (except when using it in the context of testing
|
||||
* build permissions) because they have historically been applied
|
||||
* very inconsistently.
|
||||
* @deprecated use {@link #queryState(LocalPlayer, StateFlag...)} instead
|
||||
*/
|
||||
@Deprecated
|
||||
public boolean allows(StateFlag flag) {
|
||||
@ -274,12 +244,7 @@ public boolean allows(StateFlag flag) {
|
||||
* @param player player (used by some flags)
|
||||
* @return whether the state is allows for it
|
||||
* @throws IllegalArgumentException if the build flag is given
|
||||
* @deprecated Use {@link #queryState(LocalPlayer, StateFlag...)} instead, although
|
||||
* be aware that the default value of the flag is <strong>not</strong>
|
||||
* considered in that method. Default values, however, are being
|
||||
* deprecated (except when using it in the context of testing
|
||||
* build permissions) because they have historically been applied
|
||||
* very inconsistently.
|
||||
* @deprecated use {@link #queryState(LocalPlayer, StateFlag...)} instead
|
||||
*/
|
||||
@Deprecated
|
||||
public boolean allows(StateFlag flag, @Nullable LocalPlayer player) {
|
||||
|
@ -169,75 +169,12 @@ public Result getMembership(LocalPlayer player) {
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Test whether the given player is permitted to place, break, or
|
||||
* modify any block, entity, or other object. A list of flags is to be
|
||||
* provided (one of which should probably be {@link DefaultFlag#BUILD})
|
||||
* so that the calculation can consider all of those flags.
|
||||
*
|
||||
* <p>For example, if we are checking for the ability to interact
|
||||
* with a chest, we would want to give permission if (1) the player is
|
||||
* a member of the region, (2) the {@code build} flag is set to
|
||||
* {@code ALLOW}, or (3) the {@code chest-access} flag is set to
|
||||
* {@code ALLOW}. However, if any of the two flags are set
|
||||
* to {@code DENY}, that must override everything else and deny access.</p>
|
||||
*
|
||||
* <p>This method handles that example perfectly. To use the method for
|
||||
* the example, the call would look like this:</p>
|
||||
*
|
||||
* <pre>queryPermission(player, DefaultFlag.BUILD, DefaultFlag.CHEST_ACCESS)</pre>
|
||||
*
|
||||
* @param player the player
|
||||
* @param flags zero or more flags
|
||||
* @return true if permission is granted
|
||||
*/
|
||||
public State queryPermission(LocalPlayer player, StateFlag... flags) {
|
||||
checkNotNull(player);
|
||||
checkNotNull(flags);
|
||||
|
||||
// Legacy behavior dictates that the global region is really a
|
||||
// "wilderness" region. It has no effect when there are one or more
|
||||
// regions without the PASSTHROUGH flag set.
|
||||
//
|
||||
// In addition, the global region can never override any PASSTHROUGH
|
||||
// region.
|
||||
//
|
||||
// Lastly, if the global region has members, then permission will
|
||||
// be denied by default except to those members that are a part of
|
||||
// the global region, turning the global region into a region itself
|
||||
// that covers the entire world. Unfortunately, this is really a hack
|
||||
// and we support it for legacy reasons.
|
||||
|
||||
switch (getMembership(player)) {
|
||||
case SUCCESS:
|
||||
return StateFlag.combine(queryState(player, flags), State.ALLOW);
|
||||
case FAIL:
|
||||
return queryState(player, flags);
|
||||
case NO_REGIONS:
|
||||
default:
|
||||
State fallback = null;
|
||||
for (StateFlag flag : flags) {
|
||||
if (flag.getDefault()) {
|
||||
fallback = State.ALLOW;
|
||||
break;
|
||||
}
|
||||
}
|
||||
return StateFlag.combine(queryState(player, flags), fallback);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the effective value for a list of state flags. The rules of
|
||||
* states is observed here; that is, {@code DENY} overrides {@code ALLOW},
|
||||
* and {@code ALLOW} overrides {@code NONE}.
|
||||
*
|
||||
* <p>This method does <strong>not</strong> properly process build
|
||||
* permissions. Instead, use {@link #queryPermission(LocalPlayer, StateFlag...)}
|
||||
* for that purpose. This method is ideal for testing non-build related
|
||||
* state flags (although a rarity), an example of which would be whether
|
||||
* to play a song to players that enter an area.</p>
|
||||
*
|
||||
* <p>A player can be provided that is used to determine whether the value
|
||||
* of a flag on a particular region should be used. For example, if a
|
||||
* flag's region group is set to {@link RegionGroup#MEMBERS} and the given
|
||||
@ -277,10 +214,6 @@ public State queryState(@Nullable LocalPlayer player, StateFlag... flags) {
|
||||
* type of flag that can consistently return the same 'best' value is
|
||||
* {@link StateFlag}.</p>
|
||||
*
|
||||
* <p>This method does <strong>not</strong> properly process build
|
||||
* permissions. Instead, use {@link #queryPermission(LocalPlayer, StateFlag...)}
|
||||
* for that purpose.</p>
|
||||
*
|
||||
* <p>A player can be provided that is used to determine whether the value
|
||||
* of a flag on a particular region should be used. For example, if a
|
||||
* flag's region group is set to {@link RegionGroup#MEMBERS} and the given
|
||||
@ -304,10 +237,6 @@ public <V> V queryValue(@Nullable LocalPlayer player, Flag<V> flag) {
|
||||
* values. It is up to the caller to determine which value, if any,
|
||||
* from the collection will be used.
|
||||
*
|
||||
* <p>This method does <strong>not</strong> properly process build
|
||||
* permissions. Instead, use {@link #queryPermission(LocalPlayer, StateFlag...)}
|
||||
* for that purpose.</p>
|
||||
*
|
||||
* <p>A player can be provided that is used to determine whether the value
|
||||
* of a flag on a particular region should be used. For example, if a
|
||||
* flag's region group is set to {@link RegionGroup#MEMBERS} and the given
|
||||
@ -320,6 +249,7 @@ public <V> V queryValue(@Nullable LocalPlayer player, Flag<V> flag) {
|
||||
* @param flag the flag
|
||||
* @return a collection of values
|
||||
*/
|
||||
@SuppressWarnings("unchecked")
|
||||
public <V> Collection<V> queryAllValues(@Nullable LocalPlayer player, Flag<V> flag) {
|
||||
checkNotNull(flag);
|
||||
|
||||
@ -383,6 +313,28 @@ public <V> Collection<V> queryAllValues(@Nullable LocalPlayer player, Flag<V> fl
|
||||
}
|
||||
}
|
||||
|
||||
if (flag == DefaultFlag.BUILD && consideredValues.isEmpty()) {
|
||||
if (player == null) {
|
||||
throw new NullPointerException("The BUILD flag is handled in a special fashion and requires a non-null player parameter");
|
||||
}
|
||||
|
||||
switch (getMembership(player)) {
|
||||
case FAIL:
|
||||
return ImmutableList.of();
|
||||
case SUCCESS:
|
||||
return (Collection<V>) ImmutableList.of(State.ALLOW);
|
||||
}
|
||||
}
|
||||
|
||||
if (consideredValues.isEmpty()) {
|
||||
if (flag instanceof StateFlag) {
|
||||
//noinspection unchecked
|
||||
return (Collection<V>) (((StateFlag) flag).getDefault()
|
||||
? ImmutableList.of(State.ALLOW)
|
||||
: ImmutableList.of());
|
||||
}
|
||||
}
|
||||
|
||||
return consideredValues.values();
|
||||
}
|
||||
|
||||
|
@ -29,27 +29,32 @@
|
||||
public final class DefaultFlag {
|
||||
|
||||
public static final StateFlag PASSTHROUGH = new StateFlag("passthrough", false);
|
||||
public static final StateFlag BUILD = new StateFlag("build", true);
|
||||
public static final RegionGroupFlag CONSTRUCT = new RegionGroupFlag("construct", RegionGroup.MEMBERS);
|
||||
public static final StateFlag PVP = new StateFlag("pvp", true);
|
||||
|
||||
// This flag is unlike the others. It forces the checking of region
|
||||
// membership.
|
||||
public static final StateFlag BUILD = new StateFlag("build", true);
|
||||
|
||||
public static final StateFlag USE = new StateFlag("use", false);
|
||||
public static final StateFlag PVP = new StateFlag("pvp", false);
|
||||
public static final StateFlag SLEEP = new StateFlag("sleep", false);
|
||||
public static final StateFlag TNT = new StateFlag("tnt", false);
|
||||
public static final StateFlag CHEST_ACCESS = new StateFlag("chest-access", false);
|
||||
public static final StateFlag PLACE_VEHICLE = new StateFlag("vehicle-place", false);
|
||||
public static final StateFlag DESTROY_VEHICLE = new StateFlag("vehicle-destroy", false);
|
||||
public static final StateFlag LIGHTER = new StateFlag("lighter", false);
|
||||
|
||||
public static final StateFlag MOB_DAMAGE = new StateFlag("mob-damage", true);
|
||||
public static final StateFlag MOB_SPAWNING = new StateFlag("mob-spawning", true);
|
||||
public static final StateFlag CREEPER_EXPLOSION = new StateFlag("creeper-explosion", true);
|
||||
public static final StateFlag ENDERDRAGON_BLOCK_DAMAGE = new StateFlag("enderdragon-block-damage", true);
|
||||
public static final StateFlag GHAST_FIREBALL = new StateFlag("ghast-fireball", true);
|
||||
public static final StateFlag OTHER_EXPLOSION = new StateFlag("other-explosion", true);
|
||||
public static final StateFlag SLEEP = new StateFlag("sleep", true);
|
||||
public static final StateFlag TNT = new StateFlag("tnt", true);
|
||||
public static final StateFlag LIGHTER = new StateFlag("lighter", true);
|
||||
public static final StateFlag FIRE_SPREAD = new StateFlag("fire-spread", true);
|
||||
public static final StateFlag LAVA_FIRE = new StateFlag("lava-fire", true);
|
||||
public static final StateFlag LIGHTNING = new StateFlag("lightning", true);
|
||||
public static final StateFlag CHEST_ACCESS = new StateFlag("chest-access", true);
|
||||
public static final StateFlag WATER_FLOW = new StateFlag("water-flow", true);
|
||||
public static final StateFlag LAVA_FLOW = new StateFlag("lava-flow", true);
|
||||
public static final StateFlag USE = new StateFlag("use", true);
|
||||
public static final StateFlag PLACE_VEHICLE = new StateFlag("vehicle-place", true);
|
||||
public static final StateFlag DESTROY_VEHICLE = new StateFlag("vehicle-destroy", true);
|
||||
public static final StateFlag PISTONS = new StateFlag("pistons", true);
|
||||
public static final StateFlag SNOW_FALL = new StateFlag("snow-fall", true);
|
||||
public static final StateFlag SNOW_MELT = new StateFlag("snow-melt", true);
|
||||
@ -73,6 +78,7 @@ public final class DefaultFlag {
|
||||
public static final StateFlag ENTITY_PAINTING_DESTROY = new StateFlag("entity-painting-destroy", true);
|
||||
public static final StateFlag ENTITY_ITEM_FRAME_DESTROY = new StateFlag("entity-item-frame-destroy", true);
|
||||
public static final StateFlag POTION_SPLASH = new StateFlag("potion-splash", true);
|
||||
|
||||
public static final StringFlag GREET_MESSAGE = new StringFlag("greeting");
|
||||
public static final StringFlag FAREWELL_MESSAGE = new StringFlag("farewell");
|
||||
public static final BooleanFlag NOTIFY_ENTER = new BooleanFlag("notify-enter");
|
||||
@ -98,20 +104,20 @@ public final class DefaultFlag {
|
||||
public static final SetFlag<String> ALLOWED_CMDS = new SetFlag<String>("allowed-cmds", new CommandStringFlag(null));
|
||||
|
||||
public static final Flag<?>[] flagsList = new Flag<?>[] {
|
||||
PASSTHROUGH, BUILD, CONSTRUCT, PVP, CHEST_ACCESS, PISTONS,
|
||||
TNT, LIGHTER, USE, PLACE_VEHICLE, DESTROY_VEHICLE, SLEEP,
|
||||
MOB_DAMAGE, MOB_SPAWNING, DENY_SPAWN, INVINCIBILITY, EXP_DROPS,
|
||||
CREEPER_EXPLOSION, OTHER_EXPLOSION, ENDERDRAGON_BLOCK_DAMAGE, GHAST_FIREBALL, ENDER_BUILD,
|
||||
GREET_MESSAGE, FAREWELL_MESSAGE, NOTIFY_ENTER, NOTIFY_LEAVE,
|
||||
EXIT, ENTRY, LIGHTNING, ENTITY_PAINTING_DESTROY, ENDERPEARL,
|
||||
ENTITY_ITEM_FRAME_DESTROY, ITEM_DROP, /*MAX_PLAYERS, MAX_PLAYERS_MESSAGE,*/
|
||||
HEAL_AMOUNT, HEAL_DELAY, MIN_HEAL, MAX_HEAL,
|
||||
FEED_DELAY, FEED_AMOUNT, MIN_FOOD, MAX_FOOD,
|
||||
SNOW_FALL, SNOW_MELT, ICE_FORM, ICE_MELT, SOIL_DRY, GAME_MODE,
|
||||
MUSHROOMS, LEAF_DECAY, GRASS_SPREAD, MYCELIUM_SPREAD, VINE_GROWTH,
|
||||
SEND_CHAT, RECEIVE_CHAT, FIRE_SPREAD, LAVA_FIRE, LAVA_FLOW, WATER_FLOW,
|
||||
TELE_LOC, SPAWN_LOC, POTION_SPLASH,
|
||||
BLOCKED_CMDS, ALLOWED_CMDS, PRICE, BUYABLE, ENABLE_SHOP
|
||||
PASSTHROUGH, BUILD, CONSTRUCT, PVP, CHEST_ACCESS, PISTONS,
|
||||
TNT, LIGHTER, USE, PLACE_VEHICLE, DESTROY_VEHICLE, SLEEP,
|
||||
MOB_DAMAGE, MOB_SPAWNING, DENY_SPAWN, INVINCIBILITY, EXP_DROPS,
|
||||
CREEPER_EXPLOSION, OTHER_EXPLOSION, ENDERDRAGON_BLOCK_DAMAGE, GHAST_FIREBALL, ENDER_BUILD,
|
||||
GREET_MESSAGE, FAREWELL_MESSAGE, NOTIFY_ENTER, NOTIFY_LEAVE,
|
||||
EXIT, ENTRY, LIGHTNING, ENTITY_PAINTING_DESTROY, ENDERPEARL,
|
||||
ENTITY_ITEM_FRAME_DESTROY, ITEM_DROP, /*MAX_PLAYERS, MAX_PLAYERS_MESSAGE,*/
|
||||
HEAL_AMOUNT, HEAL_DELAY, MIN_HEAL, MAX_HEAL,
|
||||
FEED_DELAY, FEED_AMOUNT, MIN_FOOD, MAX_FOOD,
|
||||
SNOW_FALL, SNOW_MELT, ICE_FORM, ICE_MELT, SOIL_DRY, GAME_MODE,
|
||||
MUSHROOMS, LEAF_DECAY, GRASS_SPREAD, MYCELIUM_SPREAD, VINE_GROWTH,
|
||||
SEND_CHAT, RECEIVE_CHAT, FIRE_SPREAD, LAVA_FIRE, LAVA_FLOW, WATER_FLOW,
|
||||
TELE_LOC, SPAWN_LOC, POTION_SPLASH,
|
||||
BLOCKED_CMDS, ALLOWED_CMDS, PRICE, BUYABLE, ENABLE_SHOP
|
||||
};
|
||||
|
||||
private DefaultFlag() {
|
||||
|
@ -73,24 +73,25 @@ public void testWildernessBuildWithRegion() {
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testFlags() {
|
||||
public void testWildernessFlags() {
|
||||
MockApplicableRegionSet mock = new MockApplicableRegionSet();
|
||||
|
||||
LocalPlayer player = mock.createPlayer();
|
||||
|
||||
ApplicableRegionSet set = mock.getApplicableSet();
|
||||
assertThat(set.testState(player, DefaultFlag.PVP), is(true));
|
||||
assertThat(set.testState(player, DefaultFlag.MOB_DAMAGE), is(true));
|
||||
|
||||
assertThat(set.testState(player, DefaultFlag.MOB_DAMAGE), is(true));
|
||||
assertThat(set.testState(player, DefaultFlag.ENTRY), is(true));
|
||||
assertThat(set.testState(player, DefaultFlag.EXIT), is(true));
|
||||
assertThat(set.testState(player, DefaultFlag.CHEST_ACCESS), is(true));
|
||||
assertThat(set.testState(player, DefaultFlag.SLEEP), is(true));
|
||||
assertThat(set.testState(player, DefaultFlag.TNT), is(true));
|
||||
assertThat(set.testState(player, DefaultFlag.LEAF_DECAY), is(true));
|
||||
assertThat(set.testState(player, DefaultFlag.RECEIVE_CHAT), is(true));
|
||||
assertThat(set.testState(player, DefaultFlag.SEND_CHAT), is(true));
|
||||
assertThat(set.testState(player, DefaultFlag.INVINCIBILITY), is(false));
|
||||
|
||||
assertThat(set.testBuild(player, DefaultFlag.CHEST_ACCESS), is(true));
|
||||
assertThat(set.testBuild(player, DefaultFlag.SLEEP), is(true));
|
||||
assertThat(set.testBuild(player, DefaultFlag.TNT), is(true));
|
||||
assertThat(set.testBuild(player, DefaultFlag.PVP), is(true));
|
||||
}
|
||||
|
||||
@Test
|
||||
@ -102,18 +103,19 @@ public void testWildernessFlagsWithGlobalRegion() {
|
||||
ProtectedRegion global = mock.global();
|
||||
|
||||
ApplicableRegionSet set = mock.getApplicableSet();
|
||||
assertThat(set.testState(player, DefaultFlag.PVP), is(true));
|
||||
assertThat(set.testState(player, DefaultFlag.MOB_DAMAGE), is(true));
|
||||
|
||||
assertThat(set.testState(player, DefaultFlag.MOB_DAMAGE), is(true));
|
||||
assertThat(set.testState(player, DefaultFlag.ENTRY), is(true));
|
||||
assertThat(set.testState(player, DefaultFlag.EXIT), is(true));
|
||||
assertThat(set.testState(player, DefaultFlag.CHEST_ACCESS), is(true));
|
||||
assertThat(set.testState(player, DefaultFlag.SLEEP), is(true));
|
||||
assertThat(set.testState(player, DefaultFlag.TNT), is(true));
|
||||
assertThat(set.testState(player, DefaultFlag.LEAF_DECAY), is(true));
|
||||
assertThat(set.testState(player, DefaultFlag.RECEIVE_CHAT), is(true));
|
||||
assertThat(set.testState(player, DefaultFlag.SEND_CHAT), is(true));
|
||||
assertThat(set.testState(player, DefaultFlag.INVINCIBILITY), is(false));
|
||||
|
||||
assertThat(set.testBuild(player, DefaultFlag.CHEST_ACCESS), is(true));
|
||||
assertThat(set.testBuild(player, DefaultFlag.SLEEP), is(true));
|
||||
assertThat(set.testBuild(player, DefaultFlag.TNT), is(true));
|
||||
assertThat(set.testBuild(player, DefaultFlag.PVP), is(true));
|
||||
}
|
||||
|
||||
@Test
|
||||
@ -127,18 +129,32 @@ public void testFlagsWithRegion() {
|
||||
region.getMembers().addPlayer(member);
|
||||
|
||||
ApplicableRegionSet set = mock.getApplicableSet();
|
||||
|
||||
assertThat(set.testState(member, DefaultFlag.MOB_DAMAGE), is(true));
|
||||
assertThat(set.testState(member, DefaultFlag.ENTRY), is(true));
|
||||
assertThat(set.testState(member, DefaultFlag.EXIT), is(true));
|
||||
assertThat(set.testState(member, DefaultFlag.LEAF_DECAY), is(true));
|
||||
assertThat(set.testState(member, DefaultFlag.RECEIVE_CHAT), is(true));
|
||||
assertThat(set.testState(member, DefaultFlag.SEND_CHAT), is(true));
|
||||
assertThat(set.testState(member, DefaultFlag.INVINCIBILITY), is(false));
|
||||
|
||||
assertThat(set.testBuild(member, DefaultFlag.CHEST_ACCESS), is(true));
|
||||
assertThat(set.testBuild(member, DefaultFlag.SLEEP), is(true));
|
||||
assertThat(set.testBuild(member, DefaultFlag.TNT), is(true));
|
||||
assertThat(set.testBuild(member, DefaultFlag.PVP), is(true));
|
||||
|
||||
assertThat(set.testState(nonMember, DefaultFlag.MOB_DAMAGE), is(true));
|
||||
assertThat(set.testState(nonMember, DefaultFlag.ENTRY), is(true));
|
||||
assertThat(set.testState(nonMember, DefaultFlag.EXIT), is(true));
|
||||
assertThat(set.testState(nonMember, DefaultFlag.LEAF_DECAY), is(true));
|
||||
assertThat(set.testState(nonMember, DefaultFlag.RECEIVE_CHAT), is(true));
|
||||
assertThat(set.testState(nonMember, DefaultFlag.SEND_CHAT), is(true));
|
||||
assertThat(set.testState(nonMember, DefaultFlag.INVINCIBILITY), is(false));
|
||||
|
||||
assertThat(set.testBuild(nonMember, DefaultFlag.CHEST_ACCESS), is(false));
|
||||
assertThat(set.testBuild(nonMember, DefaultFlag.SLEEP), is(false));
|
||||
assertThat(set.testBuild(nonMember, DefaultFlag.TNT), is(false));
|
||||
assertThat(set.testBuild(nonMember, DefaultFlag.PVP), is(false));
|
||||
}
|
||||
|
||||
@Test
|
||||
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user