Add BauSystem module

Fix ci java version
Fix LinkageProcessor
This commit is contained in:
2024-08-05 13:28:50 +02:00
parent 41d31e6c9c
commit 3366a30b0c
526 changed files with 43550 additions and 149479 deletions
@@ -0,0 +1,272 @@
/*
* This file is a part of the SteamWar software.
*
* Copyright (C) 2021 SteamWar.de-Serverteam
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
package de.steamwar.bausystem.features.observer;
import com.comphenix.tinyprotocol.Reflection;
import de.steamwar.bausystem.region.Point;
import org.bukkit.Location;
import org.bukkit.Material;
import org.bukkit.Particle;
import org.bukkit.block.Block;
import org.bukkit.block.BlockFace;
import org.bukkit.block.data.Bisected;
import org.bukkit.block.data.BlockData;
import org.bukkit.block.data.type.Observer;
import org.bukkit.block.data.type.*;
import org.bukkit.entity.Player;
import java.util.*;
public class ObserverTracer {
private static final Set<BlockFace> ALLOWED = EnumSet.of(BlockFace.NORTH, BlockFace.SOUTH, BlockFace.EAST, BlockFace.WEST, BlockFace.UP, BlockFace.DOWN);
private Player player;
private Block block;
Set<Point> seen = new HashSet<>();
private List<Block> blockList = new ArrayList<>();
public ObserverTracer(Player player, Block block) {
this.player = player;
this.block = block;
}
public void show() {
if (!ObserverTracerListener.enabled.contains(player)) {
return;
}
for (Point p : seen) {
Location location = p.toLocation(player);
spawnParticle(player, location, location.getBlock());
}
}
public boolean trace() {
int size = seen.size();
seen.clear();
blockList.clear();
if (block.getType() != Material.OBSERVER) {
return seen.size() != size;
}
blockList.add(block);
while (!blockList.isEmpty()) {
Block b = blockList.remove(0);
Point point = Point.fromLocation(b.getLocation());
if (seen.contains(point)) {
continue;
}
seen.add(point);
spawnParticle(player, b.getLocation(), b);
if (b.getType() == Material.OBSERVER) {
calculateObserver(b);
continue;
}
BlockData blockData = b.getBlockData();
if (blockData instanceof Fence) {
calculateSimple(b);
continue;
}
if (blockData instanceof Door) {
if (((Door) blockData).getHalf() == Bisected.Half.BOTTOM) {
blockList.add(b.getLocation().add(0, 1, 0).getBlock());
} else {
blockList.add(b.getLocation().add(0, -1, 0).getBlock());
}
}
if (checkAllowed(b, blockData)) {
calculateSpecial(b);
continue;
}
if (b.getType().isBlock() && b.getType().isSolid() && b.getType().isOccluding()) {
calculateSolidBlock(b);
}
}
return seen.size() != size;
}
private void spawnParticle(Player player, Location location, Block block) {
player.spawnParticle(Particle.FLAME, location.clone().add(0.5, 0.5, 0.5), 1, 0, 0, 0, 0);
if (block.getType() == Material.OBSERVER) {
BlockFace blockFace = ((Observer) block.getBlockData()).getFacing();
blockFace = blockFace.getOppositeFace();
player.spawnParticle(Particle.FLAME, location.clone().add(0.5 + blockFace.getModX() / 5.0, 0.5 + blockFace.getModY() / 5.0, 0.5 + blockFace.getModZ() / 5.0), 1, 0, 0, 0, 0);
}
}
private void calculateObserver(Block block) {
// TODO: Implement single Repeater, single Redstone, DetectorRail, PoweredRail, Diagonal Piston
Observer observer = (Observer) block.getBlockData();
for (BlockFace blockFace : ALLOWED) {
Location location = block.getLocation().add(blockFace.getModX(), blockFace.getModY(), blockFace.getModZ());
Block b = location.getBlock();
if (blockFace == observer.getFacing().getOppositeFace() && !b.getType().isAir() && b.getType() != Material.OBSERVER) {
blockList.add(b);
if (checkMaterial(b)) {
calculateSolidBlock(b);
}
continue;
}
if (b.getType() != Material.OBSERVER) {
continue;
}
if (((Observer) b.getBlockData()).getFacing() == blockFace.getOppositeFace()) {
blockList.add(b);
}
}
if (observer.getFacing() == BlockFace.UP) {
Location location = block.getLocation();
location.add(0, -2, 0);
if (location.getY() >= 0) {
Block b = location.getBlock();
if (b.getType() == Material.DROPPER || b.getType() == Material.DISPENSER) {
blockList.add(b);
}
}
}
if (observer.getFacing() != BlockFace.UP && observer.getFacing() != BlockFace.DOWN) {
Location location = block.getLocation();
BlockFace blockFace = observer.getFacing().getOppositeFace();
location.add(blockFace.getModX(), -1, blockFace.getModZ());
if (location.getY() >= 0) {
Block b = location.getBlock();
if (b.getType() == Material.DROPPER || b.getType() == Material.DISPENSER) {
blockList.add(b);
}
}
}
}
private void calculateSolidBlock(Block block) {
for (BlockFace blockFace : ALLOWED) {
Location location = block.getLocation().add(blockFace.getModX(), blockFace.getModY(), blockFace.getModZ());
Block b = location.getBlock();
if (checkAllowed(b, b.getBlockData())) {
blockList.add(b);
}
}
}
private static final Class<?> craftPoweredRail = Reflection.getClass("{obc}.block.impl.CraftPoweredRail");
private boolean checkAllowed(Block block, BlockData blockData) {
if (checkMaterial(block)) return true;
if (block.getType() == Material.BELL) {
return true;
}
return blockData instanceof Door
|| blockData instanceof Gate
|| craftPoweredRail.isInstance(blockData)
|| blockData instanceof TrapDoor
|| blockData instanceof GlassPane;
}
private boolean checkMaterial(Block block) {
if (block.getType() == Material.DROPPER) {
return true;
}
if (block.getType() == Material.HOPPER) {
return true;
}
if (block.getType() == Material.DISPENSER) {
return true;
}
if (block.getType() == Material.REDSTONE_LAMP) {
return true;
}
if (block.getType() == Material.NOTE_BLOCK) {
return true;
}
return false;
}
private void calculateSpecial(Block block) {
BlockData blockData = block.getBlockData();
Location blockLocation = block.getLocation();
if (blockData instanceof TrapDoor) {
TrapDoor trapDoor = (TrapDoor) blockData;
fence(trapDoor.getFacing().getOppositeFace(), blockLocation);
}
if (blockData instanceof Door) {
Door door = (Door) blockData;
fence(door.getFacing().getOppositeFace(), blockLocation);
fence(doorHinge(door.getFacing(), door.getHinge()), blockLocation);
}
calculateSimple(block);
}
private void fence(BlockFace current, Location location) {
Block b = location.clone().add(current.getModX(), current.getModY(), current.getModZ()).getBlock();
if (b.getBlockData() instanceof Fence || b.getBlockData() instanceof GlassPane) {
blockList.add(b);
}
}
private BlockFace doorHinge(BlockFace blockFace, Door.Hinge hinge) {
switch (blockFace) {
case WEST:
if (hinge == Door.Hinge.RIGHT) {
return BlockFace.NORTH;
} else {
return BlockFace.SOUTH;
}
case SOUTH:
if (hinge == Door.Hinge.RIGHT) {
return BlockFace.WEST;
} else {
return BlockFace.EAST;
}
case EAST:
if (hinge == Door.Hinge.RIGHT) {
return BlockFace.SOUTH;
} else {
return BlockFace.NORTH;
}
case NORTH:
if (hinge == Door.Hinge.RIGHT) {
return BlockFace.EAST;
} else {
return BlockFace.WEST;
}
default:
throw new SecurityException();
}
}
private void calculateSimple(Block block) {
Location blockLocation = block.getLocation();
for (BlockFace blockFace : ALLOWED) {
Location location = blockLocation.clone().add(blockFace.getModX(), blockFace.getModY(), blockFace.getModZ());
Block b = location.getBlock();
if (b.getType() == Material.OBSERVER) {
Observer current = (Observer) b.getBlockData();
if (current.getFacing() == blockFace.getOppositeFace()) {
blockList.add(b);
}
}
}
}
}
@@ -0,0 +1,64 @@
/*
* This file is a part of the SteamWar software.
*
* Copyright (C) 2021 SteamWar.de-Serverteam
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
package de.steamwar.bausystem.features.observer;
import de.steamwar.bausystem.BauSystem;
import de.steamwar.bausystem.Permission;
import de.steamwar.command.SWCommand;
import de.steamwar.linkage.Linked;
import org.bukkit.entity.Player;
@Linked
public class ObserverTracerCommand extends SWCommand {
public ObserverTracerCommand() {
super("observertracer", "observer");
addDefaultHelpMessage("OBSERVER_HELP");
}
@Register(value = "enable", description = "OBSERVER_HELP_ENABLE")
public void enable(Player p) {
ObserverTracerListener.enabled.add(p);
BauSystem.MESSAGE.send("OBSERVER_ENABLE", p);
}
@Register(value = "disable", description = "OBSERVER_HELP_DISABLE")
public void disable(Player p) {
ObserverTracerListener.enabled.remove(p);
ObserverTracerListener.observerTracerMap.remove(p);
BauSystem.MESSAGE.send("OBSERVER_DISABLE", p);
}
@Register(value = "delete", description = "OBSERVER_HELP_DELETE")
public void delete(@Validator Player p) {
ObserverTracerListener.observerTracerMap.remove(p);
BauSystem.MESSAGE.send("OBSERVER_DELETE", p);
}
@Register(value = "retrace", description = "OBSERVER_HELP_RETRACE")
public void retrace(@Validator Player p) {
if (ObserverTracerListener.observerTracerMap.containsKey(p)) {
BauSystem.MESSAGE.send("OBSERVER_RETRACE_NO_TRACE", p);
return;
}
ObserverTracerListener.observerTracerMap.get(p).trace();
BauSystem.MESSAGE.send("OBSERVER_RETRACE_DONE", p);
}
}
@@ -0,0 +1,108 @@
/*
* This file is a part of the SteamWar software.
*
* Copyright (C) 2021 SteamWar.de-Serverteam
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
package de.steamwar.bausystem.features.observer;
import de.steamwar.bausystem.BauSystem;
import de.steamwar.bausystem.Permission;
import de.steamwar.bausystem.utils.BauMemberUpdateEvent;
import de.steamwar.linkage.Linked;
import org.bukkit.Bukkit;
import org.bukkit.GameMode;
import org.bukkit.Material;
import org.bukkit.entity.Player;
import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener;
import org.bukkit.event.block.Action;
import org.bukkit.event.player.PlayerInteractEvent;
import org.bukkit.event.player.PlayerJoinEvent;
import org.bukkit.event.player.PlayerQuitEvent;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
@Linked
public class ObserverTracerListener implements Listener {
static Set<Player> enabled = new HashSet<>();
static Map<Player, ObserverTracer> observerTracerMap = new HashMap<>();
public ObserverTracerListener() {
Bukkit.getScheduler().runTaskTimer(BauSystem.getInstance(), () -> {
observerTracerMap.forEach((player, observerTracer) -> {
if (player.getGameMode() == GameMode.SPECTATOR) {
observerTracer.show();
}
});
}, 15L, 15L);
}
@EventHandler
public void onPlayerInteract(PlayerInteractEvent event) {
if(!Permission.BUILD.hasPermission(event.getPlayer())) return;
if (!enabled.contains(event.getPlayer())) {
return;
}
if (event.getClickedBlock() == null) {
return;
}
if (observerTracerMap.containsKey(event.getPlayer())) {
ObserverTracer observerTracer = observerTracerMap.get(event.getPlayer());
Bukkit.getScheduler().runTaskLater(BauSystem.getInstance(), () -> {
if (!observerTracer.trace()) {
createNew(event);
}
observerTracerMap.forEach((player, o) -> {
o.trace();
});
}, 1L);
} else {
createNew(event);
}
}
private void createNew(PlayerInteractEvent event) {
if (event.getAction() != Action.RIGHT_CLICK_BLOCK) {
return;
}
if (event.getClickedBlock().getType() == Material.OBSERVER) {
ObserverTracer observerTracer = new ObserverTracer(event.getPlayer(), event.getClickedBlock());
observerTracer.trace();
observerTracerMap.put(event.getPlayer(), observerTracer);
}
}
@EventHandler
public void onBauMemberUpdate(BauMemberUpdateEvent event) {
event.getNewSpectator().forEach(observerTracerMap::remove);
}
@EventHandler
public void onPlayerJoin(PlayerJoinEvent event) {
enabled.add(event.getPlayer());
}
@EventHandler
public void onPlayerQuit(PlayerQuitEvent event) {
enabled.remove(event.getPlayer());
observerTracerMap.remove(event.getPlayer());
}
}