This commit is contained in:
Trixkz 2021-11-22 07:34:13 -05:00
commit 0ff26a8724
8 changed files with 403 additions and 0 deletions

View File

@ -33,5 +33,13 @@
<orderEntry type="library" name="Maven: com.google.code.gson:gson:2.8.8" level="project" />
<orderEntry type="library" name="Maven: org.mongodb:mongo-java-driver:3.12.10" level="project" />
<orderEntry type="library" scope="PROVIDED" name="Maven: org.projectlombok:lombok:1.18.20" level="project" />
<orderEntry type="library" scope="PROVIDED" name="Maven: com.sk89q:worldedit:6.0.0-SNAPSHOT" level="project" />
<orderEntry type="library" scope="PROVIDED" name="Maven: de.schlichtherle:truezip:6.8.3" level="project" />
<orderEntry type="library" scope="PROVIDED" name="Maven: rhino:js:1.7R2" level="project" />
<orderEntry type="library" scope="PROVIDED" name="Maven: com.google.guava:guava:10.0.1" level="project" />
<orderEntry type="library" scope="PROVIDED" name="Maven: com.google.code.findbugs:jsr305:1.3.9" level="project" />
<orderEntry type="library" scope="PROVIDED" name="Maven: com.boydti:fawe-api:latest" level="project" />
<orderEntry type="library" scope="PROVIDED" name="Maven: me.clip:placeholderapi:2.10.9" level="project" />
<orderEntry type="library" scope="PROVIDED" name="Maven: org.jetbrains:annotations:19.0.0" level="project" />
</component>
</module>

32
pom.xml
View File

@ -61,6 +61,14 @@
<id>sonatype</id>
<url>https://oss.sonatype.org/content/groups/public/</url>
</repository>
<repository>
<id>fawe-repo</id>
<url>https://ci.athion.net/job/FastAsyncWorldEdit/ws/mvn/</url>
</repository>
<repository>
<id>placeholderapi</id>
<url>https://repo.extendedclip.com/content/repositories/placeholderapi/</url>
</repository>
</repositories>
<dependencies>
@ -98,5 +106,29 @@
<scope>provided</scope>
</dependency>
<!-- WorldEdit -->
<dependency>
<groupId>com.sk89q</groupId>
<artifactId>worldedit</artifactId>
<version>6.0.0-SNAPSHOT</version>
<scope>provided</scope>
</dependency>
<!-- FastAsyncWorldEdit -->
<dependency>
<groupId>com.boydti</groupId>
<artifactId>fawe-api</artifactId>
<version>latest</version>
<scope>provided</scope>
</dependency>
<!-- PlaceholderAPI -->
<dependency>
<groupId>me.clip</groupId>
<artifactId>placeholderapi</artifactId>
<version>2.10.9</version>
<scope>provided</scope>
</dependency>
</dependencies>
</project>

View File

@ -0,0 +1,49 @@
package rip.tilly.bedwars.commands.arena;
import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player;
import rip.tilly.bedwars.BedWars;
import rip.tilly.bedwars.utils.CC;
public class ArenaCommand implements CommandExecutor {
private BedWars plugin = BedWars.getInstance();
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
Player player = (Player) sender;
if (!player.hasPermission("bedwars.admin")) {
player.sendMessage(CC.translate("&cNo permission"));
return true;
}
if (args.length == 0) {
player.sendMessage(CC.translate("&cUsage:"));
player.sendMessage(CC.translate(" &c/arena"));
player.sendMessage(CC.translate(" &c/arena manage (Opens arena manage menu)"));
player.sendMessage(CC.translate(" &c/arena create <arena>"));
player.sendMessage(CC.translate(" &c/arena icon <arena>"));
player.sendMessage(CC.translate(" &c/arena enable <arena>"));
player.sendMessage(CC.translate(" &c/arena disable <arena>"));
player.sendMessage(CC.translate(" &c/arena a <arena>"));
player.sendMessage(CC.translate(" &c/arena b <arena>"));
player.sendMessage(CC.translate(" &c/arena min <arena>"));
player.sendMessage(CC.translate(" &c/arena max <arena>"));
player.sendMessage(CC.translate(" &c/arena teamAmin <arena>"));
player.sendMessage(CC.translate(" &c/arena teamAmax <arena>"));
player.sendMessage(CC.translate(" &c/arena teamBmin <arena>"));
player.sendMessage(CC.translate(" &c/arena teamBmax <arena>"));
player.sendMessage(CC.translate(" &c/arena deadzone <arena>"));
player.sendMessage(CC.translate(" &c/arena buildmax <arena>"));
} else {
switch (args[0].toLowerCase()) {
}
}
return true;
}
}

View File

@ -1,6 +1,7 @@
package rip.tilly.bedwars.managers;
import rip.tilly.bedwars.BedWars;
import rip.tilly.bedwars.commands.arena.ArenaCommand;
import rip.tilly.bedwars.commands.level.LevelCommand;
import rip.tilly.bedwars.commands.party.PartyCommand;
import rip.tilly.bedwars.commands.setspawn.SetSpawnCommand;
@ -19,5 +20,6 @@ public class CommandManager {
this.main.getCommand("level").setExecutor(new LevelCommand());
this.main.getCommand("xp").setExecutor(new XpCommand());
this.main.getCommand("party").setExecutor(new PartyCommand());
this.main.getCommand("arena").setExecutor(new ArenaCommand());
}
}

View File

@ -0,0 +1,89 @@
package rip.tilly.bedwars.runnables;
import lombok.AllArgsConstructor;
import lombok.Getter;
import org.bukkit.Bukkit;
import org.bukkit.ChatColor;
import org.bukkit.entity.Player;
import rip.tilly.bedwars.BedWars;
import rip.tilly.bedwars.game.arena.Arena;
import rip.tilly.bedwars.game.arena.CopiedArena;
import rip.tilly.bedwars.utils.CustomLocation;
@Getter
@AllArgsConstructor
public class ArenaCommandRunnable implements Runnable {
private final BedWars plugin;
private final Arena copiedArena;
private int times;
@Override
public void run() {
this.duplicateArena(this.copiedArena, 10000, 10000);
}
private void duplicateArena(Arena arena, int offsetX, int offsetZ) {
new DuplicateArenaRunnable(this.plugin, arena, offsetX, offsetZ, 500, 500) {
@Override
public void onComplete() {
double minX = arena.getMin().getX() + this.getOffsetX();
double minZ = arena.getMin().getZ() + this.getOffsetZ();
double maxX = arena.getMax().getX() + this.getOffsetX();
double maxZ = arena.getMax().getZ() + this.getOffsetZ();
double aX = arena.getA().getX() + this.getOffsetX();
double aZ = arena.getA().getZ() + this.getOffsetZ();
double bX = arena.getB().getX() + this.getOffsetX();
double bZ = arena.getB().getZ() + this.getOffsetZ();
CustomLocation min = new CustomLocation(minX, arena.getMin().getY(), minZ, arena.getMin().getYaw(), arena.getMin().getPitch());
CustomLocation max = new CustomLocation(maxX, arena.getMax().getY(), maxZ, arena.getMax().getYaw(), arena.getMax().getPitch());
CustomLocation a = new CustomLocation(aX, arena.getA().getY(), aZ, arena.getA().getYaw(), arena.getA().getPitch());
CustomLocation b = new CustomLocation(bX, arena.getB().getY(), bZ, arena.getB().getYaw(), arena.getB().getPitch());
double aMinX = arena.getTeamAmin().getX() + this.getOffsetX();
double aMinZ = arena.getTeamAmin().getZ() + this.getOffsetZ();
double aMaxX = arena.getTeamAmax().getX() + this.getOffsetX();
double aMaxZ = arena.getTeamAmax().getZ() + this.getOffsetZ();
double bMinX = arena.getTeamBmin().getX() + this.getOffsetX();
double bMinZ = arena.getTeamBmin().getZ() + this.getOffsetZ();
double bMaxX = arena.getTeamBmax().getX() + this.getOffsetX();
double bMaxZ = arena.getTeamBmax().getZ() + this.getOffsetZ();
CustomLocation teamAmin = new CustomLocation(aMinX, arena.getTeamAmin().getY(), aMinZ, arena.getTeamAmin().getYaw(), arena.getTeamAmin().getPitch());
CustomLocation teamAmax = new CustomLocation(aMaxX, arena.getTeamAmax().getY(), aMaxZ, arena.getTeamAmax().getYaw(), arena.getTeamAmax().getPitch());
CustomLocation teamBmin = new CustomLocation(bMinX, arena.getTeamBmin().getY(), bMinZ, arena.getTeamBmin().getYaw(), arena.getTeamBmin().getPitch());
CustomLocation teamBmax = new CustomLocation(bMaxX, arena.getTeamBmax().getY(), bMaxZ, arena.getTeamBmax().getYaw(), arena.getTeamBmax().getPitch());
CopiedArena copiedArena = new CopiedArena(a, b, min, max, teamAmin, teamAmax, teamBmin, teamBmax);
arena.addCopiedArena(copiedArena);
arena.addAvailableArena(copiedArena);
String arenaPasteMessage = "[Copied Arena] - " + arena.getName() + " placed at " + (int) minX + ", " + (int) minZ + ". " + ArenaCommandRunnable.this.times + " copies remaining.";
if (--ArenaCommandRunnable.this.times > 0) {
ArenaCommandRunnable.this.plugin.getServer().getLogger().info(arenaPasteMessage);
for (Player player : Bukkit.getOnlinePlayers()) {
if (player.isOp()) {
player.sendMessage(ChatColor.GREEN + arenaPasteMessage);
}
}
ArenaCommandRunnable.this.duplicateArena(arena, (int) Math.round(maxX), (int) Math.round(maxZ));
} else {
for (Player player : Bukkit.getOnlinePlayers()) {
if (player.isOp()) {
player.sendMessage(ChatColor.GREEN + "All the copies for " + ArenaCommandRunnable.this.copiedArena.getName() + " have been pasted successfully!");
}
}
ArenaCommandRunnable.this.plugin.getServer().getLogger().info("All the copies for " + ArenaCommandRunnable.this.copiedArena.getName() + " have been pasted successfully!");
ArenaCommandRunnable.this.plugin.getArenaManager().setGeneratingArenaRunnable(ArenaCommandRunnable.this.plugin.getArenaManager().getGeneratingArenaRunnable() - 1);
this.getPlugin().getArenaManager().reloadArenas();
}
}
}.run();
}
}

View File

@ -0,0 +1,54 @@
package rip.tilly.bedwars.runnables;
import com.boydti.fawe.util.EditSessionBuilder;
import com.boydti.fawe.util.TaskManager;
import com.sk89q.worldedit.EditSession;
import com.sk89q.worldedit.MaxChangedBlocksException;
import com.sk89q.worldedit.Vector;
import com.sk89q.worldedit.blocks.BaseBlock;
import com.sk89q.worldedit.blocks.BlockID;
import com.sk89q.worldedit.regions.CuboidRegion;
import org.bukkit.scheduler.BukkitRunnable;
import rip.tilly.bedwars.BedWars;
import rip.tilly.bedwars.game.arena.Arena;
import rip.tilly.bedwars.game.arena.CopiedArena;
public class ArenaCopyRemovalRunnable extends BukkitRunnable {
private final int number;
private final Arena arena;
private final CopiedArena arenaCopy;
private final BedWars plugin = BedWars.getInstance();
public ArenaCopyRemovalRunnable(int number, Arena arena, CopiedArena arenaCopy) {
this.number = number;
this.arena = arena;
this.arenaCopy = arenaCopy;
}
@Override
public void run() {
TaskManager.IMP.async(() -> {
EditSession editSession = new EditSessionBuilder(arenaCopy.getA().getWorld()).fastmode(true).allowedRegionsEverywhere().autoQueue(false).limitUnlimited().build();
CuboidRegion copyRegion = new CuboidRegion(
new Vector(arenaCopy.getMax().getX(), arenaCopy.getMax().getY(), arenaCopy.getMax().getZ()),
new Vector(arenaCopy.getMin().getX(), arenaCopy.getMin().getY(), arenaCopy.getMin().getZ())
);
try {
editSession.setBlocks(copyRegion, new BaseBlock(BlockID.AIR));
} catch (MaxChangedBlocksException e) {
e.getStackTrace();
}
editSession.flushQueue();
});
this.plugin.getArenasConfig().getConfig().getConfigurationSection("arenas." + arena.getName() + ".copiedArenas").set(String.valueOf(number), null);
this.plugin.getArenasConfig().save();
this.plugin.getArenaManager().getArena(arena.getName()).getCopiedArenas().remove(arenaCopy);
this.plugin.getArenaManager().getArena(arena.getName()).getAvailableArenas().remove(number);
}
}

View File

@ -0,0 +1,62 @@
package rip.tilly.bedwars.runnables;
import com.boydti.fawe.util.EditSessionBuilder;
import com.boydti.fawe.util.TaskManager;
import com.sk89q.worldedit.EditSession;
import com.sk89q.worldedit.Vector;
import com.sk89q.worldedit.blocks.BaseBlock;
import lombok.Getter;
import org.bukkit.Location;
import org.bukkit.World;
import org.bukkit.block.Block;
import org.bukkit.scheduler.BukkitRunnable;
import java.util.Iterator;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ConcurrentMap;
@Getter
public abstract class BlockPlaceRunnable extends BukkitRunnable {
private final ConcurrentMap<Location, Block> blocks;
private final int totalBlocks;
private final Iterator<Location> iterator;
private World world;
private int blockIndex = 0;
private int blocksPlaced = 0;
private boolean completed = false;
public BlockPlaceRunnable(World world, Map<Location, Block> blocks) {
this.world = world;
this.blocks = new ConcurrentHashMap<>();
this.blocks.putAll(blocks);
this.totalBlocks = blocks.keySet().size();
this.iterator = blocks.keySet().iterator();
}
@Override
public void run() {
if (blocks.isEmpty() || !iterator.hasNext()) {
finish();
completed = true;
cancel();
return;
}
TaskManager.IMP.async(() -> {
EditSession editSession = new EditSessionBuilder(this.world.getName()).fastmode(true).allowedRegionsEverywhere().autoQueue(false).limitUnlimited().build();
for (Map.Entry<Location, Block> entry : this.blocks.entrySet()) {
try {
editSession.setBlock(new Vector(entry.getKey().getBlockX(), entry.getKey().getBlockY(), entry.getKey().getZ()), new BaseBlock(entry.getValue().getTypeId(), entry.getValue().getData()));
} catch (Exception ex) {
ex.printStackTrace();
}
}
editSession.flushQueue();
TaskManager.IMP.task(this.blocks::clear);
});
}
public abstract void finish();
}

View File

@ -0,0 +1,107 @@
package rip.tilly.bedwars.runnables;
import lombok.Getter;
import org.bukkit.Location;
import org.bukkit.Material;
import org.bukkit.block.Block;
import org.bukkit.scheduler.BukkitRunnable;
import rip.tilly.bedwars.BedWars;
import rip.tilly.bedwars.game.arena.Arena;
import java.util.HashMap;
import java.util.Map;
@Getter
public abstract class DuplicateArenaRunnable extends BukkitRunnable {
private final BedWars plugin;
private Arena copiedArena;
private int offsetX;
private int offsetZ;
private int incrementX;
private int incrementZ;
private Map<Location, Block> paste;
public DuplicateArenaRunnable(BedWars plugin, Arena copiedArena, int offsetX, int offsetZ, int incrementX, int incrementZ) {
this.plugin = plugin;
this.copiedArena = copiedArena;
this.offsetX = offsetX;
this.offsetZ = offsetZ;
this.incrementX = incrementX;
this.incrementZ = incrementZ;
}
@Override
public void run() {
if (this.paste == null) {
Map<Location, Block> copy = this.blocksFromTwoPoints(this.copiedArena.getMin().toBukkitLocation(), this.copiedArena.getMax().toBukkitLocation());
this.paste = new HashMap<>();
for (Location loc : copy.keySet()) {
if (copy.get(loc).getType() != Material.AIR) {
this.paste.put(loc.clone().add(this.offsetX, 0, this.offsetZ), copy.get(loc));
}
}
copy.clear();
} else {
Map<Location, Block> newPaste = new HashMap<>();
for (Location loc : this.paste.keySet()) {
if (this.paste.get(loc).getType() != Material.AIR) {
newPaste.put(loc.clone().add(this.incrementX, 0, this.incrementZ), this.paste.get(loc));
}
}
this.paste.clear();
this.paste.putAll(newPaste);
}
boolean safe = true;
for (Location loc : this.paste.keySet()) {
Block block = loc.getBlock();
if (block.getType() != Material.AIR) {
safe = false;
break;
}
}
if (!safe) {
this.offsetX += this.incrementX;
this.offsetZ += this.incrementZ;
this.run();
return;
}
new BlockPlaceRunnable(this.copiedArena.getA().toBukkitLocation().getWorld(), this.paste) {
@Override
public void finish() {
DuplicateArenaRunnable.this.onComplete();
}
}.runTaskTimer(this.plugin, 0L, 5L);
}
public Map<Location, Block> blocksFromTwoPoints(Location loc1, Location loc2) {
Map<Location, Block> blocks = new HashMap<>();
int topBlockX = (loc1.getBlockX() < loc2.getBlockX() ? loc2.getBlockX() : loc1.getBlockX());
int bottomBlockX = (loc1.getBlockX() > loc2.getBlockX() ? loc2.getBlockX() : loc1.getBlockX());
int topBlockY = (loc1.getBlockY() < loc2.getBlockY() ? loc2.getBlockY() : loc1.getBlockY());
int bottomBlockY = (loc1.getBlockY() > loc2.getBlockY() ? loc2.getBlockY() : loc1.getBlockY());
int topBlockZ = (loc1.getBlockZ() < loc2.getBlockZ() ? loc2.getBlockZ() : loc1.getBlockZ());
int bottomBlockZ = (loc1.getBlockZ() > loc2.getBlockZ() ? loc2.getBlockZ() : loc1.getBlockZ());
for (int x = bottomBlockX; x <= topBlockX; x++) {
for (int z = bottomBlockZ; z <= topBlockZ; z++) {
for (int y = bottomBlockY; y <= topBlockY; y++) {
Block block = loc1.getWorld().getBlockAt(x, y, z);
if (block.getType() != Material.AIR) {
blocks.put(new Location(loc1.getWorld(), x, y, z), block);
}
}
}
}
return blocks;
}
public abstract void onComplete();
}