mirror of
https://github.com/CodeMC/WorldGuardWrapper.git
synced 2025-01-18 12:12:37 +01:00
Implement getPlayerSelection() and SelectionUtilities, bump version
This commit is contained in:
parent
4ea70913c5
commit
bd1e41cbb6
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.codemc.worldguardwrapper</groupId>
|
<groupId>org.codemc.worldguardwrapper</groupId>
|
||||||
<artifactId>worldguardwrapper-parent</artifactId>
|
<artifactId>worldguardwrapper-parent</artifactId>
|
||||||
<version>1.1.8-SNAPSHOT</version>
|
<version>1.1.9-SNAPSHOT</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>worldguardwrapper-api</artifactId>
|
<artifactId>worldguardwrapper-api</artifactId>
|
||||||
|
|
|
@ -154,8 +154,9 @@ public interface IWorldGuardImplementation {
|
||||||
} else if (selection instanceof IPolygonalSelection) {
|
} else if (selection instanceof IPolygonalSelection) {
|
||||||
IPolygonalSelection sel = (IPolygonalSelection) selection;
|
IPolygonalSelection sel = (IPolygonalSelection) selection;
|
||||||
return addRegion(id, new ArrayList<>(sel.getPoints()), sel.getMinimumY(), sel.getMaximumY());
|
return addRegion(id, new ArrayList<>(sel.getPoints()), sel.getMinimumY(), sel.getMaximumY());
|
||||||
|
} else {
|
||||||
|
throw new UnsupportedOperationException("Unknown " + selection.getClass().getSimpleName() + " selection type!");
|
||||||
}
|
}
|
||||||
return Optional.empty();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -167,4 +168,12 @@ public interface IWorldGuardImplementation {
|
||||||
*/
|
*/
|
||||||
Optional<Set<IWrappedRegion>> removeRegion(@NonNull World world, @NonNull String id);
|
Optional<Set<IWrappedRegion>> removeRegion(@NonNull World world, @NonNull String id);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the current selection of the given player.
|
||||||
|
*
|
||||||
|
* @param player The player
|
||||||
|
* @return The current player's selection
|
||||||
|
*/
|
||||||
|
Optional<ISelection> getPlayerSelection(@NonNull Player player);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,72 @@
|
||||||
|
package org.codemc.worldguardwrapper.utility;
|
||||||
|
|
||||||
|
import lombok.experimental.UtilityClass;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.codemc.worldguardwrapper.selection.ICuboidSelection;
|
||||||
|
import org.codemc.worldguardwrapper.selection.IPolygonalSelection;
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
@UtilityClass
|
||||||
|
public class SelectionUtilities {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a static cuboid selection.
|
||||||
|
*
|
||||||
|
* @param first the first point of the cuboid
|
||||||
|
* @param second the second point of the cuboid
|
||||||
|
* @return the selection
|
||||||
|
*/
|
||||||
|
public ICuboidSelection createCuboidSelection(Location first, Location second) {
|
||||||
|
Location minimum;
|
||||||
|
Location maximum;
|
||||||
|
if (first.getBlockY() > second.getBlockY()) {
|
||||||
|
maximum = first;
|
||||||
|
minimum = second;
|
||||||
|
} else {
|
||||||
|
maximum = second;
|
||||||
|
minimum = first;
|
||||||
|
}
|
||||||
|
return new ICuboidSelection() {
|
||||||
|
@Override
|
||||||
|
public Location getMinimumPoint() {
|
||||||
|
return minimum;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Location getMaximumPoint() {
|
||||||
|
return maximum;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a static polygonal selection.
|
||||||
|
*
|
||||||
|
* @param points the points of the selection
|
||||||
|
* @param minY the minimum Y coordinate of the selection
|
||||||
|
* @param maxY the maximum Y coordinate of the selection
|
||||||
|
* @return the selection
|
||||||
|
*/
|
||||||
|
public IPolygonalSelection createPolygonalSelection(Collection<Location> points, int minY, int maxY) {
|
||||||
|
return new IPolygonalSelection() {
|
||||||
|
@Override
|
||||||
|
public Set<Location> getPoints() {
|
||||||
|
return new HashSet<>(points);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getMinimumY() {
|
||||||
|
return minY;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getMaximumY() {
|
||||||
|
return maxY;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.codemc.worldguardwrapper</groupId>
|
<groupId>org.codemc.worldguardwrapper</groupId>
|
||||||
<artifactId>worldguardwrapper-implementation</artifactId>
|
<artifactId>worldguardwrapper-implementation</artifactId>
|
||||||
<version>1.1.8-SNAPSHOT</version>
|
<version>1.1.9-SNAPSHOT</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>worldguardwrapper-implementation-legacy</artifactId>
|
<artifactId>worldguardwrapper-implementation-legacy</artifactId>
|
||||||
|
@ -28,7 +28,7 @@
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>${project.groupId}</groupId>
|
<groupId>${project.groupId}</groupId>
|
||||||
<artifactId>worldguardwrapper-api</artifactId>
|
<artifactId>worldguardwrapper-api</artifactId>
|
||||||
<version>1.1.8-SNAPSHOT</version>
|
<version>1.1.9-SNAPSHOT</version>
|
||||||
<scope>provided</scope>
|
<scope>provided</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
|
|
|
@ -1,6 +1,10 @@
|
||||||
package org.codemc.worldguardwrapper.implementation.legacy;
|
package org.codemc.worldguardwrapper.implementation.legacy;
|
||||||
|
|
||||||
import com.google.common.collect.Maps;
|
import com.sk89q.minecraft.util.commands.CommandException;
|
||||||
|
import com.sk89q.worldedit.BlockVector;
|
||||||
|
import com.sk89q.worldedit.bukkit.WorldEditPlugin;
|
||||||
|
import com.sk89q.worldedit.bukkit.selections.CuboidSelection;
|
||||||
|
import com.sk89q.worldedit.bukkit.selections.Polygonal2DSelection;
|
||||||
import com.sk89q.worldguard.LocalPlayer;
|
import com.sk89q.worldguard.LocalPlayer;
|
||||||
import com.sk89q.worldguard.bukkit.WorldGuardPlugin;
|
import com.sk89q.worldguard.bukkit.WorldGuardPlugin;
|
||||||
import com.sk89q.worldguard.protection.ApplicableRegionSet;
|
import com.sk89q.worldguard.protection.ApplicableRegionSet;
|
||||||
|
@ -10,7 +14,6 @@ import com.sk89q.worldguard.protection.managers.RegionManager;
|
||||||
import com.sk89q.worldguard.protection.regions.ProtectedCuboidRegion;
|
import com.sk89q.worldguard.protection.regions.ProtectedCuboidRegion;
|
||||||
import com.sk89q.worldguard.protection.regions.ProtectedPolygonalRegion;
|
import com.sk89q.worldguard.protection.regions.ProtectedPolygonalRegion;
|
||||||
import com.sk89q.worldguard.protection.regions.ProtectedRegion;
|
import com.sk89q.worldguard.protection.regions.ProtectedRegion;
|
||||||
import lombok.NoArgsConstructor;
|
|
||||||
import lombok.NonNull;
|
import lombok.NonNull;
|
||||||
import org.bukkit.Location;
|
import org.bukkit.Location;
|
||||||
import org.bukkit.World;
|
import org.bukkit.World;
|
||||||
|
@ -23,21 +26,33 @@ import org.codemc.worldguardwrapper.implementation.legacy.region.WrappedRegion;
|
||||||
import org.codemc.worldguardwrapper.implementation.legacy.utility.WorldGuardFlagUtilities;
|
import org.codemc.worldguardwrapper.implementation.legacy.utility.WorldGuardFlagUtilities;
|
||||||
import org.codemc.worldguardwrapper.implementation.legacy.utility.WorldGuardVectorUtilities;
|
import org.codemc.worldguardwrapper.implementation.legacy.utility.WorldGuardVectorUtilities;
|
||||||
import org.codemc.worldguardwrapper.region.IWrappedRegion;
|
import org.codemc.worldguardwrapper.region.IWrappedRegion;
|
||||||
|
import org.codemc.worldguardwrapper.selection.ICuboidSelection;
|
||||||
|
import org.codemc.worldguardwrapper.selection.IPolygonalSelection;
|
||||||
|
import org.codemc.worldguardwrapper.selection.ISelection;
|
||||||
|
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
@NoArgsConstructor
|
|
||||||
public class WorldGuardImplementation implements IWorldGuardImplementation {
|
public class WorldGuardImplementation implements IWorldGuardImplementation {
|
||||||
|
|
||||||
private final WorldGuardPlugin plugin = WorldGuardPlugin.inst();
|
private final WorldGuardPlugin worldGuardPlugin;
|
||||||
|
private final WorldEditPlugin worldEditPlugin;
|
||||||
|
|
||||||
|
public WorldGuardImplementation() {
|
||||||
|
worldGuardPlugin = WorldGuardPlugin.inst();
|
||||||
|
try {
|
||||||
|
worldEditPlugin = worldGuardPlugin.getWorldEdit();
|
||||||
|
} catch (CommandException e) {
|
||||||
|
throw new RuntimeException(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private Optional<LocalPlayer> wrapPlayer(Player player) {
|
private Optional<LocalPlayer> wrapPlayer(Player player) {
|
||||||
return Optional.ofNullable(player).map(bukkitPlayer -> plugin.wrapPlayer(player));
|
return Optional.ofNullable(player).map(bukkitPlayer -> worldGuardPlugin.wrapPlayer(player));
|
||||||
}
|
}
|
||||||
|
|
||||||
private Optional<RegionManager> getWorldManager(@NonNull World world) {
|
private Optional<RegionManager> getWorldManager(@NonNull World world) {
|
||||||
return Optional.ofNullable(plugin.getRegionManager(world));
|
return Optional.ofNullable(worldGuardPlugin.getRegionManager(world));
|
||||||
}
|
}
|
||||||
|
|
||||||
private Optional<ApplicableRegionSet> getApplicableRegions(@NonNull Location location) {
|
private Optional<ApplicableRegionSet> getApplicableRegions(@NonNull Location location) {
|
||||||
|
@ -126,7 +141,7 @@ public class WorldGuardImplementation implements IWorldGuardImplementation {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Map<String, IWrappedRegion> getRegions(World world) {
|
public Map<String, IWrappedRegion> getRegions(World world) {
|
||||||
RegionManager regionManager = plugin.getRegionManager(world);
|
RegionManager regionManager = worldGuardPlugin.getRegionManager(world);
|
||||||
Map<String, ProtectedRegion> regions = regionManager.getRegions();
|
Map<String, ProtectedRegion> regions = regionManager.getRegions();
|
||||||
|
|
||||||
Map<String, IWrappedRegion> map = new HashMap<>();
|
Map<String, IWrappedRegion> map = new HashMap<>();
|
||||||
|
@ -187,4 +202,45 @@ public class WorldGuardImplementation implements IWorldGuardImplementation {
|
||||||
.collect(Collectors.toSet()));
|
.collect(Collectors.toSet()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Optional<ISelection> getPlayerSelection(@NonNull Player player) {
|
||||||
|
return Optional.ofNullable(worldEditPlugin.getSelection(player))
|
||||||
|
.map(selection -> {
|
||||||
|
if (selection instanceof CuboidSelection) {
|
||||||
|
return new ICuboidSelection() {
|
||||||
|
@Override
|
||||||
|
public Location getMinimumPoint() {
|
||||||
|
return selection.getMinimumPoint();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Location getMaximumPoint() {
|
||||||
|
return selection.getMaximumPoint();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
} else if (selection instanceof Polygonal2DSelection) {
|
||||||
|
return new IPolygonalSelection() {
|
||||||
|
@Override
|
||||||
|
public Set<Location> getPoints() {
|
||||||
|
return ((Polygonal2DSelection) selection).getNativePoints().stream()
|
||||||
|
.map(vector -> new BlockVector(vector.toVector()))
|
||||||
|
.map(vector -> WorldGuardVectorUtilities.fromBlockVector(selection.getWorld(), vector))
|
||||||
|
.collect(Collectors.toSet());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getMinimumY() {
|
||||||
|
return selection.getMinimumPoint().getBlockY();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getMaximumY() {
|
||||||
|
return selection.getMaximumPoint().getBlockY();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
throw new UnsupportedOperationException("Unsupported " + selection.getClass().getSimpleName() + " selection!");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,6 +2,7 @@ package org.codemc.worldguardwrapper.implementation.legacy.region;
|
||||||
|
|
||||||
import com.sk89q.worldedit.BlockVector;
|
import com.sk89q.worldedit.BlockVector;
|
||||||
import com.sk89q.worldguard.protection.flags.Flag;
|
import com.sk89q.worldguard.protection.flags.Flag;
|
||||||
|
import com.sk89q.worldguard.protection.regions.ProtectedCuboidRegion;
|
||||||
import com.sk89q.worldguard.protection.regions.ProtectedPolygonalRegion;
|
import com.sk89q.worldguard.protection.regions.ProtectedPolygonalRegion;
|
||||||
import com.sk89q.worldguard.protection.regions.ProtectedRegion;
|
import com.sk89q.worldguard.protection.regions.ProtectedRegion;
|
||||||
import lombok.AllArgsConstructor;
|
import lombok.AllArgsConstructor;
|
||||||
|
@ -34,7 +35,19 @@ public class WrappedRegion implements IWrappedRegion {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ISelection getSelection() {
|
public ISelection getSelection() {
|
||||||
if (handle instanceof ProtectedPolygonalRegion) {
|
if (handle instanceof ProtectedCuboidRegion) {
|
||||||
|
return new ICuboidSelection() {
|
||||||
|
@Override
|
||||||
|
public Location getMinimumPoint() {
|
||||||
|
return WorldGuardVectorUtilities.fromBlockVector(world, handle.getMinimumPoint());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Location getMaximumPoint() {
|
||||||
|
return WorldGuardVectorUtilities.fromBlockVector(world, handle.getMaximumPoint());
|
||||||
|
}
|
||||||
|
};
|
||||||
|
} else if (handle instanceof ProtectedPolygonalRegion) {
|
||||||
return new IPolygonalSelection() {
|
return new IPolygonalSelection() {
|
||||||
@Override
|
@Override
|
||||||
public Set<Location> getPoints() {
|
public Set<Location> getPoints() {
|
||||||
|
@ -54,19 +67,9 @@ public class WrappedRegion implements IWrappedRegion {
|
||||||
return handle.getMaximumPoint().getBlockY();
|
return handle.getMaximumPoint().getBlockY();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
} else {
|
||||||
|
throw new UnsupportedOperationException("Unsupported " + handle.getClass().getSimpleName() + " region!");
|
||||||
}
|
}
|
||||||
|
|
||||||
return new ICuboidSelection() {
|
|
||||||
@Override
|
|
||||||
public Location getMinimumPoint() {
|
|
||||||
return WorldGuardVectorUtilities.fromBlockVector(world, handle.getMinimumPoint());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Location getMaximumPoint() {
|
|
||||||
return WorldGuardVectorUtilities.fromBlockVector(world, handle.getMaximumPoint());
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.codemc.worldguardwrapper</groupId>
|
<groupId>org.codemc.worldguardwrapper</groupId>
|
||||||
<artifactId>worldguardwrapper-parent</artifactId>
|
<artifactId>worldguardwrapper-parent</artifactId>
|
||||||
<version>1.1.8-SNAPSHOT</version>
|
<version>1.1.9-SNAPSHOT</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>worldguardwrapper-implementation</artifactId>
|
<artifactId>worldguardwrapper-implementation</artifactId>
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.codemc.worldguardwrapper</groupId>
|
<groupId>org.codemc.worldguardwrapper</groupId>
|
||||||
<artifactId>worldguardwrapper-implementation</artifactId>
|
<artifactId>worldguardwrapper-implementation</artifactId>
|
||||||
<version>1.1.8-SNAPSHOT</version>
|
<version>1.1.9-SNAPSHOT</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>worldguardwrapper-implementation-v6</artifactId>
|
<artifactId>worldguardwrapper-implementation-v6</artifactId>
|
||||||
|
@ -28,7 +28,7 @@
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>${project.groupId}</groupId>
|
<groupId>${project.groupId}</groupId>
|
||||||
<artifactId>worldguardwrapper-api</artifactId>
|
<artifactId>worldguardwrapper-api</artifactId>
|
||||||
<version>1.1.8-SNAPSHOT</version>
|
<version>1.1.9-SNAPSHOT</version>
|
||||||
<scope>provided</scope>
|
<scope>provided</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
|
|
|
@ -1,6 +1,10 @@
|
||||||
package org.codemc.worldguardwrapper.implementation.v6;
|
package org.codemc.worldguardwrapper.implementation.v6;
|
||||||
|
|
||||||
import com.google.common.collect.Maps;
|
import com.sk89q.minecraft.util.commands.CommandException;
|
||||||
|
import com.sk89q.worldedit.BlockVector;
|
||||||
|
import com.sk89q.worldedit.bukkit.WorldEditPlugin;
|
||||||
|
import com.sk89q.worldedit.bukkit.selections.CuboidSelection;
|
||||||
|
import com.sk89q.worldedit.bukkit.selections.Polygonal2DSelection;
|
||||||
import com.sk89q.worldguard.LocalPlayer;
|
import com.sk89q.worldguard.LocalPlayer;
|
||||||
import com.sk89q.worldguard.bukkit.WorldGuardPlugin;
|
import com.sk89q.worldguard.bukkit.WorldGuardPlugin;
|
||||||
import com.sk89q.worldguard.protection.ApplicableRegionSet;
|
import com.sk89q.worldguard.protection.ApplicableRegionSet;
|
||||||
|
@ -11,7 +15,6 @@ import com.sk89q.worldguard.protection.managers.RegionManager;
|
||||||
import com.sk89q.worldguard.protection.regions.ProtectedCuboidRegion;
|
import com.sk89q.worldguard.protection.regions.ProtectedCuboidRegion;
|
||||||
import com.sk89q.worldguard.protection.regions.ProtectedPolygonalRegion;
|
import com.sk89q.worldguard.protection.regions.ProtectedPolygonalRegion;
|
||||||
import com.sk89q.worldguard.protection.regions.ProtectedRegion;
|
import com.sk89q.worldguard.protection.regions.ProtectedRegion;
|
||||||
import lombok.NoArgsConstructor;
|
|
||||||
import lombok.NonNull;
|
import lombok.NonNull;
|
||||||
import org.bukkit.Location;
|
import org.bukkit.Location;
|
||||||
import org.bukkit.World;
|
import org.bukkit.World;
|
||||||
|
@ -26,22 +29,35 @@ import org.codemc.worldguardwrapper.implementation.v6.region.WrappedRegion;
|
||||||
import org.codemc.worldguardwrapper.implementation.v6.utility.WorldGuardFlagUtilities;
|
import org.codemc.worldguardwrapper.implementation.v6.utility.WorldGuardFlagUtilities;
|
||||||
import org.codemc.worldguardwrapper.implementation.v6.utility.WorldGuardVectorUtilities;
|
import org.codemc.worldguardwrapper.implementation.v6.utility.WorldGuardVectorUtilities;
|
||||||
import org.codemc.worldguardwrapper.region.IWrappedRegion;
|
import org.codemc.worldguardwrapper.region.IWrappedRegion;
|
||||||
|
import org.codemc.worldguardwrapper.selection.ICuboidSelection;
|
||||||
|
import org.codemc.worldguardwrapper.selection.IPolygonalSelection;
|
||||||
|
import org.codemc.worldguardwrapper.selection.ISelection;
|
||||||
|
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
@NoArgsConstructor
|
|
||||||
public class WorldGuardImplementation implements IWorldGuardImplementation {
|
public class WorldGuardImplementation implements IWorldGuardImplementation {
|
||||||
|
|
||||||
private final WorldGuardPlugin plugin = WorldGuardPlugin.inst();
|
private final WorldGuardPlugin worldGuardPlugin;
|
||||||
private final FlagRegistry flagRegistry = plugin.getFlagRegistry();
|
private final WorldEditPlugin worldEditPlugin;
|
||||||
|
private final FlagRegistry flagRegistry;
|
||||||
|
|
||||||
|
public WorldGuardImplementation() {
|
||||||
|
worldGuardPlugin = WorldGuardPlugin.inst();
|
||||||
|
try {
|
||||||
|
worldEditPlugin = worldGuardPlugin.getWorldEdit();
|
||||||
|
} catch (CommandException e) {
|
||||||
|
throw new RuntimeException(e);
|
||||||
|
}
|
||||||
|
flagRegistry = worldGuardPlugin.getFlagRegistry();
|
||||||
|
}
|
||||||
|
|
||||||
private Optional<LocalPlayer> wrapPlayer(Player player) {
|
private Optional<LocalPlayer> wrapPlayer(Player player) {
|
||||||
return Optional.ofNullable(player).map(bukkitPlayer -> plugin.wrapPlayer(player));
|
return Optional.ofNullable(player).map(bukkitPlayer -> worldGuardPlugin.wrapPlayer(player));
|
||||||
}
|
}
|
||||||
|
|
||||||
private Optional<RegionManager> getWorldManager(@NonNull World world) {
|
private Optional<RegionManager> getWorldManager(@NonNull World world) {
|
||||||
return Optional.ofNullable(plugin.getRegionManager(world));
|
return Optional.ofNullable(worldGuardPlugin.getRegionManager(world));
|
||||||
}
|
}
|
||||||
|
|
||||||
private Optional<ApplicableRegionSet> getApplicableRegions(@NonNull Location location) {
|
private Optional<ApplicableRegionSet> getApplicableRegions(@NonNull Location location) {
|
||||||
|
@ -152,7 +168,7 @@ public class WorldGuardImplementation implements IWorldGuardImplementation {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Map<String, IWrappedRegion> getRegions(World world) {
|
public Map<String, IWrappedRegion> getRegions(World world) {
|
||||||
RegionManager regionManager = plugin.getRegionManager(world);
|
RegionManager regionManager = worldGuardPlugin.getRegionManager(world);
|
||||||
Map<String, ProtectedRegion> regions = regionManager.getRegions();
|
Map<String, ProtectedRegion> regions = regionManager.getRegions();
|
||||||
|
|
||||||
Map<String, IWrappedRegion> map = new HashMap<>();
|
Map<String, IWrappedRegion> map = new HashMap<>();
|
||||||
|
@ -213,4 +229,45 @@ public class WorldGuardImplementation implements IWorldGuardImplementation {
|
||||||
.collect(Collectors.toSet()));
|
.collect(Collectors.toSet()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Optional<ISelection> getPlayerSelection(@NonNull Player player) {
|
||||||
|
return Optional.ofNullable(worldEditPlugin.getSelection(player))
|
||||||
|
.map(selection -> {
|
||||||
|
if (selection instanceof CuboidSelection) {
|
||||||
|
return new ICuboidSelection() {
|
||||||
|
@Override
|
||||||
|
public Location getMinimumPoint() {
|
||||||
|
return selection.getMinimumPoint();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Location getMaximumPoint() {
|
||||||
|
return selection.getMaximumPoint();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
} else if (selection instanceof Polygonal2DSelection) {
|
||||||
|
return new IPolygonalSelection() {
|
||||||
|
@Override
|
||||||
|
public Set<Location> getPoints() {
|
||||||
|
return ((Polygonal2DSelection) selection).getNativePoints().stream()
|
||||||
|
.map(vector -> new BlockVector(vector.toVector()))
|
||||||
|
.map(vector -> WorldGuardVectorUtilities.fromBlockVector(selection.getWorld(), vector))
|
||||||
|
.collect(Collectors.toSet());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getMinimumY() {
|
||||||
|
return selection.getMinimumPoint().getBlockY();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getMaximumY() {
|
||||||
|
return selection.getMaximumPoint().getBlockY();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
throw new UnsupportedOperationException("Unsupported " + selection.getClass().getSimpleName() + " selection!");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,6 +2,7 @@ package org.codemc.worldguardwrapper.implementation.v6.region;
|
||||||
|
|
||||||
import com.sk89q.worldedit.BlockVector;
|
import com.sk89q.worldedit.BlockVector;
|
||||||
import com.sk89q.worldguard.protection.flags.Flag;
|
import com.sk89q.worldguard.protection.flags.Flag;
|
||||||
|
import com.sk89q.worldguard.protection.regions.ProtectedCuboidRegion;
|
||||||
import com.sk89q.worldguard.protection.regions.ProtectedPolygonalRegion;
|
import com.sk89q.worldguard.protection.regions.ProtectedPolygonalRegion;
|
||||||
import com.sk89q.worldguard.protection.regions.ProtectedRegion;
|
import com.sk89q.worldguard.protection.regions.ProtectedRegion;
|
||||||
import lombok.AllArgsConstructor;
|
import lombok.AllArgsConstructor;
|
||||||
|
@ -18,11 +19,7 @@ import org.codemc.worldguardwrapper.selection.ICuboidSelection;
|
||||||
import org.codemc.worldguardwrapper.selection.IPolygonalSelection;
|
import org.codemc.worldguardwrapper.selection.IPolygonalSelection;
|
||||||
import org.codemc.worldguardwrapper.selection.ISelection;
|
import org.codemc.worldguardwrapper.selection.ISelection;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.*;
|
||||||
import java.util.Map;
|
|
||||||
import java.util.Optional;
|
|
||||||
import java.util.Set;
|
|
||||||
import java.util.UUID;
|
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
|
@ -34,7 +31,19 @@ public class WrappedRegion implements IWrappedRegion {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ISelection getSelection() {
|
public ISelection getSelection() {
|
||||||
if (handle instanceof ProtectedPolygonalRegion) {
|
if (handle instanceof ProtectedCuboidRegion) {
|
||||||
|
return new ICuboidSelection() {
|
||||||
|
@Override
|
||||||
|
public Location getMinimumPoint() {
|
||||||
|
return WorldGuardVectorUtilities.fromBlockVector(world, handle.getMinimumPoint());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Location getMaximumPoint() {
|
||||||
|
return WorldGuardVectorUtilities.fromBlockVector(world, handle.getMaximumPoint());
|
||||||
|
}
|
||||||
|
};
|
||||||
|
} else if (handle instanceof ProtectedPolygonalRegion) {
|
||||||
return new IPolygonalSelection() {
|
return new IPolygonalSelection() {
|
||||||
@Override
|
@Override
|
||||||
public Set<Location> getPoints() {
|
public Set<Location> getPoints() {
|
||||||
|
@ -54,19 +63,9 @@ public class WrappedRegion implements IWrappedRegion {
|
||||||
return handle.getMaximumPoint().getBlockY();
|
return handle.getMaximumPoint().getBlockY();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
} else {
|
||||||
|
throw new UnsupportedOperationException("Unsupported " + handle.getClass().getSimpleName() + " region!");
|
||||||
}
|
}
|
||||||
|
|
||||||
return new ICuboidSelection() {
|
|
||||||
@Override
|
|
||||||
public Location getMinimumPoint() {
|
|
||||||
return WorldGuardVectorUtilities.fromBlockVector(world, handle.getMinimumPoint());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Location getMaximumPoint() {
|
|
||||||
return WorldGuardVectorUtilities.fromBlockVector(world, handle.getMaximumPoint());
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.codemc.worldguardwrapper</groupId>
|
<groupId>org.codemc.worldguardwrapper</groupId>
|
||||||
<artifactId>worldguardwrapper-implementation</artifactId>
|
<artifactId>worldguardwrapper-implementation</artifactId>
|
||||||
<version>1.1.8-SNAPSHOT</version>
|
<version>1.1.9-SNAPSHOT</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>worldguardwrapper-implementation-v7</artifactId>
|
<artifactId>worldguardwrapper-implementation-v7</artifactId>
|
||||||
|
@ -28,7 +28,7 @@
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>${project.groupId}</groupId>
|
<groupId>${project.groupId}</groupId>
|
||||||
<artifactId>worldguardwrapper-api</artifactId>
|
<artifactId>worldguardwrapper-api</artifactId>
|
||||||
<version>1.1.8-SNAPSHOT</version>
|
<version>1.1.9-SNAPSHOT</version>
|
||||||
<scope>provided</scope>
|
<scope>provided</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
|
|
|
@ -1,9 +1,14 @@
|
||||||
package org.codemc.worldguardwrapper.implementation.v7;
|
package org.codemc.worldguardwrapper.implementation.v7;
|
||||||
|
|
||||||
import com.google.common.collect.Maps;
|
import com.sk89q.minecraft.util.commands.CommandException;
|
||||||
|
import com.sk89q.worldedit.IncompleteRegionException;
|
||||||
import com.sk89q.worldedit.bukkit.BukkitAdapter;
|
import com.sk89q.worldedit.bukkit.BukkitAdapter;
|
||||||
import com.sk89q.worldedit.bukkit.BukkitWorld;
|
import com.sk89q.worldedit.bukkit.BukkitWorld;
|
||||||
|
import com.sk89q.worldedit.bukkit.WorldEditPlugin;
|
||||||
import com.sk89q.worldedit.math.BlockVector2;
|
import com.sk89q.worldedit.math.BlockVector2;
|
||||||
|
import com.sk89q.worldedit.regions.CuboidRegion;
|
||||||
|
import com.sk89q.worldedit.regions.Polygonal2DRegion;
|
||||||
|
import com.sk89q.worldedit.regions.Region;
|
||||||
import com.sk89q.worldguard.LocalPlayer;
|
import com.sk89q.worldguard.LocalPlayer;
|
||||||
import com.sk89q.worldguard.WorldGuard;
|
import com.sk89q.worldguard.WorldGuard;
|
||||||
import com.sk89q.worldguard.bukkit.WorldGuardPlugin;
|
import com.sk89q.worldguard.bukkit.WorldGuardPlugin;
|
||||||
|
@ -15,7 +20,6 @@ import com.sk89q.worldguard.protection.managers.RegionManager;
|
||||||
import com.sk89q.worldguard.protection.regions.ProtectedCuboidRegion;
|
import com.sk89q.worldguard.protection.regions.ProtectedCuboidRegion;
|
||||||
import com.sk89q.worldguard.protection.regions.ProtectedPolygonalRegion;
|
import com.sk89q.worldguard.protection.regions.ProtectedPolygonalRegion;
|
||||||
import com.sk89q.worldguard.protection.regions.ProtectedRegion;
|
import com.sk89q.worldguard.protection.regions.ProtectedRegion;
|
||||||
import lombok.NoArgsConstructor;
|
|
||||||
import lombok.NonNull;
|
import lombok.NonNull;
|
||||||
import org.bukkit.Location;
|
import org.bukkit.Location;
|
||||||
import org.bukkit.World;
|
import org.bukkit.World;
|
||||||
|
@ -29,19 +33,33 @@ import org.codemc.worldguardwrapper.implementation.v7.flag.AbstractWrappedFlag;
|
||||||
import org.codemc.worldguardwrapper.implementation.v7.region.WrappedRegion;
|
import org.codemc.worldguardwrapper.implementation.v7.region.WrappedRegion;
|
||||||
import org.codemc.worldguardwrapper.implementation.v7.utility.WorldGuardFlagUtilities;
|
import org.codemc.worldguardwrapper.implementation.v7.utility.WorldGuardFlagUtilities;
|
||||||
import org.codemc.worldguardwrapper.region.IWrappedRegion;
|
import org.codemc.worldguardwrapper.region.IWrappedRegion;
|
||||||
|
import org.codemc.worldguardwrapper.selection.ICuboidSelection;
|
||||||
|
import org.codemc.worldguardwrapper.selection.IPolygonalSelection;
|
||||||
|
import org.codemc.worldguardwrapper.selection.ISelection;
|
||||||
|
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
@NoArgsConstructor
|
|
||||||
public class WorldGuardImplementation implements IWorldGuardImplementation {
|
public class WorldGuardImplementation implements IWorldGuardImplementation {
|
||||||
|
|
||||||
private final WorldGuard core = WorldGuard.getInstance();
|
private final WorldGuard core;
|
||||||
private final FlagRegistry flagRegistry = core.getFlagRegistry();
|
private final FlagRegistry flagRegistry;
|
||||||
private final WorldGuardPlugin plugin = WorldGuardPlugin.inst();
|
private final WorldGuardPlugin worldGuardPlugin;
|
||||||
|
private final WorldEditPlugin worldEditPlugin;
|
||||||
|
|
||||||
|
public WorldGuardImplementation() {
|
||||||
|
core = WorldGuard.getInstance();
|
||||||
|
flagRegistry = core.getFlagRegistry();
|
||||||
|
worldGuardPlugin = WorldGuardPlugin.inst();
|
||||||
|
try {
|
||||||
|
worldEditPlugin = worldGuardPlugin.getWorldEdit();
|
||||||
|
} catch (CommandException e) {
|
||||||
|
throw new RuntimeException(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private Optional<LocalPlayer> wrapPlayer(Player player) {
|
private Optional<LocalPlayer> wrapPlayer(Player player) {
|
||||||
return Optional.ofNullable(player).map(bukkitPlayer -> plugin.wrapPlayer(player));
|
return Optional.ofNullable(player).map(bukkitPlayer -> worldGuardPlugin.wrapPlayer(player));
|
||||||
}
|
}
|
||||||
|
|
||||||
private Optional<RegionManager> getWorldManager(@NonNull World world) {
|
private Optional<RegionManager> getWorldManager(@NonNull World world) {
|
||||||
|
@ -221,4 +239,56 @@ public class WorldGuardImplementation implements IWorldGuardImplementation {
|
||||||
return set.map(protectedRegions -> protectedRegions.stream()
|
return set.map(protectedRegions -> protectedRegions.stream()
|
||||||
.map(region -> new WrappedRegion(world, region)).collect(Collectors.toSet()));
|
.map(region -> new WrappedRegion(world, region)).collect(Collectors.toSet()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Optional<ISelection> getPlayerSelection(@NonNull Player player) {
|
||||||
|
Region region;
|
||||||
|
try {
|
||||||
|
region = worldEditPlugin.getSession(player).getSelection(BukkitAdapter.adapt(player.getWorld()));
|
||||||
|
} catch (IncompleteRegionException e) {
|
||||||
|
region = null;
|
||||||
|
}
|
||||||
|
return Optional.ofNullable(region)
|
||||||
|
.map(selection -> {
|
||||||
|
World world = Optional.ofNullable(selection.getWorld()).map(BukkitAdapter::adapt).orElse(null);
|
||||||
|
if (world == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
if (selection instanceof CuboidRegion) {
|
||||||
|
return new ICuboidSelection() {
|
||||||
|
@Override
|
||||||
|
public Location getMinimumPoint() {
|
||||||
|
return BukkitAdapter.adapt(world, selection.getMinimumPoint());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Location getMaximumPoint() {
|
||||||
|
return BukkitAdapter.adapt(world, selection.getMaximumPoint());
|
||||||
|
}
|
||||||
|
};
|
||||||
|
} else if (selection instanceof Polygonal2DRegion) {
|
||||||
|
return new IPolygonalSelection() {
|
||||||
|
@Override
|
||||||
|
public Set<Location> getPoints() {
|
||||||
|
return ((Polygonal2DRegion) selection).getPoints().stream()
|
||||||
|
.map(BlockVector2::toBlockVector3)
|
||||||
|
.map(vector -> BukkitAdapter.adapt(world, vector))
|
||||||
|
.collect(Collectors.toSet());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getMinimumY() {
|
||||||
|
return selection.getMinimumPoint().getBlockY();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getMaximumY() {
|
||||||
|
return selection.getMaximumPoint().getBlockY();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
throw new UnsupportedOperationException("Unsupported " + selection.getClass().getSimpleName() + " selection!");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,6 +3,7 @@ package org.codemc.worldguardwrapper.implementation.v7.region;
|
||||||
import com.sk89q.worldedit.bukkit.BukkitAdapter;
|
import com.sk89q.worldedit.bukkit.BukkitAdapter;
|
||||||
import com.sk89q.worldedit.math.BlockVector2;
|
import com.sk89q.worldedit.math.BlockVector2;
|
||||||
import com.sk89q.worldguard.protection.flags.Flag;
|
import com.sk89q.worldguard.protection.flags.Flag;
|
||||||
|
import com.sk89q.worldguard.protection.regions.ProtectedCuboidRegion;
|
||||||
import com.sk89q.worldguard.protection.regions.ProtectedPolygonalRegion;
|
import com.sk89q.worldguard.protection.regions.ProtectedPolygonalRegion;
|
||||||
import com.sk89q.worldguard.protection.regions.ProtectedRegion;
|
import com.sk89q.worldguard.protection.regions.ProtectedRegion;
|
||||||
import lombok.AllArgsConstructor;
|
import lombok.AllArgsConstructor;
|
||||||
|
@ -18,11 +19,7 @@ import org.codemc.worldguardwrapper.selection.ICuboidSelection;
|
||||||
import org.codemc.worldguardwrapper.selection.IPolygonalSelection;
|
import org.codemc.worldguardwrapper.selection.IPolygonalSelection;
|
||||||
import org.codemc.worldguardwrapper.selection.ISelection;
|
import org.codemc.worldguardwrapper.selection.ISelection;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.*;
|
||||||
import java.util.Map;
|
|
||||||
import java.util.Optional;
|
|
||||||
import java.util.Set;
|
|
||||||
import java.util.UUID;
|
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
|
@ -34,7 +31,19 @@ public class WrappedRegion implements IWrappedRegion {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ISelection getSelection() {
|
public ISelection getSelection() {
|
||||||
if (handle instanceof ProtectedPolygonalRegion) {
|
if (handle instanceof ProtectedCuboidRegion) {
|
||||||
|
return new ICuboidSelection() {
|
||||||
|
@Override
|
||||||
|
public Location getMinimumPoint() {
|
||||||
|
return BukkitAdapter.adapt(world, handle.getMinimumPoint());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Location getMaximumPoint() {
|
||||||
|
return BukkitAdapter.adapt(world, handle.getMaximumPoint());
|
||||||
|
}
|
||||||
|
};
|
||||||
|
} else if (handle instanceof ProtectedPolygonalRegion) {
|
||||||
return new IPolygonalSelection() {
|
return new IPolygonalSelection() {
|
||||||
@Override
|
@Override
|
||||||
public Set<Location> getPoints() {
|
public Set<Location> getPoints() {
|
||||||
|
@ -54,19 +63,9 @@ public class WrappedRegion implements IWrappedRegion {
|
||||||
return handle.getMaximumPoint().getBlockY();
|
return handle.getMaximumPoint().getBlockY();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
} else {
|
||||||
|
throw new UnsupportedOperationException("Unsupported " + handle.getClass().getSimpleName() + " region!");
|
||||||
}
|
}
|
||||||
|
|
||||||
return new ICuboidSelection() {
|
|
||||||
@Override
|
|
||||||
public Location getMinimumPoint() {
|
|
||||||
return BukkitAdapter.adapt(world, handle.getMinimumPoint());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Location getMaximumPoint() {
|
|
||||||
return BukkitAdapter.adapt(world, handle.getMaximumPoint());
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.codemc.worldguardwrapper</groupId>
|
<groupId>org.codemc.worldguardwrapper</groupId>
|
||||||
<artifactId>worldguardwrapper-parent</artifactId>
|
<artifactId>worldguardwrapper-parent</artifactId>
|
||||||
<version>1.1.8-SNAPSHOT</version>
|
<version>1.1.9-SNAPSHOT</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>worldguardwrapper</artifactId>
|
<artifactId>worldguardwrapper</artifactId>
|
||||||
|
@ -18,22 +18,22 @@
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>${project.groupId}</groupId>
|
<groupId>${project.groupId}</groupId>
|
||||||
<artifactId>worldguardwrapper-api</artifactId>
|
<artifactId>worldguardwrapper-api</artifactId>
|
||||||
<version>1.1.8-SNAPSHOT</version>
|
<version>1.1.9-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>${project.groupId}</groupId>
|
<groupId>${project.groupId}</groupId>
|
||||||
<artifactId>worldguardwrapper-implementation-legacy</artifactId>
|
<artifactId>worldguardwrapper-implementation-legacy</artifactId>
|
||||||
<version>1.1.8-SNAPSHOT</version>
|
<version>1.1.9-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>${project.groupId}</groupId>
|
<groupId>${project.groupId}</groupId>
|
||||||
<artifactId>worldguardwrapper-implementation-v6</artifactId>
|
<artifactId>worldguardwrapper-implementation-v6</artifactId>
|
||||||
<version>1.1.8-SNAPSHOT</version>
|
<version>1.1.9-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>${project.groupId}</groupId>
|
<groupId>${project.groupId}</groupId>
|
||||||
<artifactId>worldguardwrapper-implementation-v7</artifactId>
|
<artifactId>worldguardwrapper-implementation-v7</artifactId>
|
||||||
<version>1.1.8-SNAPSHOT</version>
|
<version>1.1.9-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|
||||||
|
|
2
pom.xml
2
pom.xml
|
@ -6,7 +6,7 @@
|
||||||
|
|
||||||
<groupId>org.codemc.worldguardwrapper</groupId>
|
<groupId>org.codemc.worldguardwrapper</groupId>
|
||||||
<artifactId>worldguardwrapper-parent</artifactId>
|
<artifactId>worldguardwrapper-parent</artifactId>
|
||||||
<version>1.1.8-SNAPSHOT</version>
|
<version>1.1.9-SNAPSHOT</version>
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
|
||||||
<modules>
|
<modules>
|
||||||
|
|
Loading…
Reference in New Issue
Block a user