mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-03 23:17:48 +01:00
General cleanup
This commit is contained in:
parent
47677766ca
commit
3cb880cf80
@ -35,7 +35,7 @@ public class AdvancementTab implements Viewable {
|
|||||||
protected ByteBuf createBuffer;
|
protected ByteBuf createBuffer;
|
||||||
// the packet used to clear the tab (used to remove it and to update an advancement)
|
// the packet used to clear the tab (used to remove it and to update an advancement)
|
||||||
// will never change (since the root identifier is always the same)
|
// will never change (since the root identifier is always the same)
|
||||||
protected ByteBuf removeBuffer;
|
protected final ByteBuf removeBuffer;
|
||||||
|
|
||||||
protected AdvancementTab(String rootIdentifier, AdvancementRoot root) {
|
protected AdvancementTab(String rootIdentifier, AdvancementRoot root) {
|
||||||
this.root = root;
|
this.root = root;
|
||||||
|
@ -47,10 +47,8 @@ public class NotificationCenter {
|
|||||||
* @param players the collection of players to send the notification to
|
* @param players the collection of players to send the notification to
|
||||||
*/
|
*/
|
||||||
public static void send(Notification notification, Collection<Player> players) {
|
public static void send(Notification notification, Collection<Player> players) {
|
||||||
// Can't use PacketWriterUtils before we need the packets to come in the correct order
|
// Can't use PacketWriterUtils because we need the packets to come in the correct order
|
||||||
players.forEach(player -> {
|
players.forEach(player -> send(notification, player));
|
||||||
send(notification, player);
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -27,18 +27,18 @@ import static net.minestom.server.MinecraftServer.*;
|
|||||||
*/
|
*/
|
||||||
public final class BenchmarkManager {
|
public final class BenchmarkManager {
|
||||||
|
|
||||||
public static ThreadMXBean threadMXBean = ManagementFactory.getThreadMXBean();
|
public static final ThreadMXBean THREAD_MX_BEAN = ManagementFactory.getThreadMXBean();
|
||||||
private static List<String> threads = new ArrayList<>();
|
private static final List<String> THREADS = new ArrayList<>();
|
||||||
|
|
||||||
static {
|
static {
|
||||||
threadMXBean.setThreadContentionMonitoringEnabled(true);
|
THREAD_MX_BEAN.setThreadContentionMonitoringEnabled(true);
|
||||||
threadMXBean.setThreadCpuTimeEnabled(true);
|
THREAD_MX_BEAN.setThreadCpuTimeEnabled(true);
|
||||||
|
|
||||||
threads.add(THREAD_NAME_MAIN_UPDATE);
|
THREADS.add(THREAD_NAME_MAIN_UPDATE);
|
||||||
threads.add(THREAD_NAME_PACKET_WRITER);
|
THREADS.add(THREAD_NAME_PACKET_WRITER);
|
||||||
threads.add(THREAD_NAME_BLOCK_BATCH);
|
THREADS.add(THREAD_NAME_BLOCK_BATCH);
|
||||||
threads.add(THREAD_NAME_SCHEDULER);
|
THREADS.add(THREAD_NAME_SCHEDULER);
|
||||||
threads.add(THREAD_NAME_TICK);
|
THREADS.add(THREAD_NAME_TICK);
|
||||||
}
|
}
|
||||||
|
|
||||||
private final Long2LongMap lastCpuTimeMap = new Long2LongOpenHashMap();
|
private final Long2LongMap lastCpuTimeMap = new Long2LongOpenHashMap();
|
||||||
@ -85,7 +85,7 @@ public final class BenchmarkManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void addThreadMonitor(String threadName) {
|
public void addThreadMonitor(String threadName) {
|
||||||
threads.add(threadName);
|
THREADS.add(threadName);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -119,11 +119,11 @@ public final class BenchmarkManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void refreshData() {
|
private void refreshData() {
|
||||||
ThreadInfo[] threadInfo = threadMXBean.getThreadInfo(threadMXBean.getAllThreadIds());
|
ThreadInfo[] threadInfo = THREAD_MX_BEAN.getThreadInfo(THREAD_MX_BEAN.getAllThreadIds());
|
||||||
for (ThreadInfo threadInfo2 : threadInfo) {
|
for (ThreadInfo threadInfo2 : threadInfo) {
|
||||||
final String name = threadInfo2.getThreadName();
|
final String name = threadInfo2.getThreadName();
|
||||||
boolean shouldBenchmark = false;
|
boolean shouldBenchmark = false;
|
||||||
for (String thread : threads) {
|
for (String thread : THREADS) {
|
||||||
if (name.startsWith(thread)) {
|
if (name.startsWith(thread)) {
|
||||||
shouldBenchmark = true;
|
shouldBenchmark = true;
|
||||||
break;
|
break;
|
||||||
@ -141,8 +141,8 @@ public final class BenchmarkManager {
|
|||||||
|
|
||||||
final long blockedTime = threadInfo2.getBlockedTime();
|
final long blockedTime = threadInfo2.getBlockedTime();
|
||||||
final long waitedTime = threadInfo2.getWaitedTime();
|
final long waitedTime = threadInfo2.getWaitedTime();
|
||||||
final long cpuTime = threadMXBean.getThreadCpuTime(id);
|
final long cpuTime = THREAD_MX_BEAN.getThreadCpuTime(id);
|
||||||
final long userTime = threadMXBean.getThreadUserTime(id);
|
final long userTime = THREAD_MX_BEAN.getThreadUserTime(id);
|
||||||
|
|
||||||
lastCpuTimeMap.put(id, cpuTime);
|
lastCpuTimeMap.put(id, cpuTime);
|
||||||
lastUserTimeMap.put(id, userTime);
|
lastUserTimeMap.put(id, userTime);
|
||||||
|
@ -21,7 +21,7 @@ import java.util.List;
|
|||||||
*/
|
*/
|
||||||
public class RichMessage extends JsonMessage {
|
public class RichMessage extends JsonMessage {
|
||||||
|
|
||||||
private List<RichComponent> components = new ArrayList<>();
|
private final List<RichComponent> components = new ArrayList<>();
|
||||||
private RichComponent currentComponent;
|
private RichComponent currentComponent;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -214,8 +214,8 @@ public class RichMessage extends JsonMessage {
|
|||||||
*/
|
*/
|
||||||
private static class RichComponent {
|
private static class RichComponent {
|
||||||
|
|
||||||
private ColoredText text;
|
private final ColoredText text;
|
||||||
private FormatRetention formatRetention;
|
private final FormatRetention formatRetention;
|
||||||
private ChatClickEvent clickEvent;
|
private ChatClickEvent clickEvent;
|
||||||
private ChatHoverEvent hoverEvent;
|
private ChatHoverEvent hoverEvent;
|
||||||
private String insertion;
|
private String insertion;
|
||||||
|
@ -5,8 +5,8 @@ package net.minestom.server.chat;
|
|||||||
*/
|
*/
|
||||||
public class TranslatableText {
|
public class TranslatableText {
|
||||||
|
|
||||||
private String code;
|
private final String code;
|
||||||
private String[] arguments;
|
private final String[] arguments;
|
||||||
|
|
||||||
private TranslatableText(String code, String[] arguments) {
|
private TranslatableText(String code, String[] arguments) {
|
||||||
this.code = code;
|
this.code = code;
|
||||||
|
@ -11,7 +11,7 @@ import net.minestom.server.utils.Vector;
|
|||||||
public class BoundingBox {
|
public class BoundingBox {
|
||||||
|
|
||||||
private final Entity entity;
|
private final Entity entity;
|
||||||
private float x, y, z;
|
private final float x, y, z;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a {@link BoundingBox} linked to an {@link Entity} and with a specific size.
|
* Creates a {@link BoundingBox} linked to an {@link Entity} and with a specific size.
|
||||||
|
@ -37,10 +37,10 @@ public final class CommandManager {
|
|||||||
|
|
||||||
private boolean running;
|
private boolean running;
|
||||||
|
|
||||||
private ConsoleSender consoleSender = new ConsoleSender();
|
private final ConsoleSender consoleSender = new ConsoleSender();
|
||||||
|
|
||||||
private CommandDispatcher dispatcher = new CommandDispatcher();
|
private final CommandDispatcher dispatcher = new CommandDispatcher();
|
||||||
private Map<String, CommandProcessor> commandProcessorMap = new HashMap<>();
|
private final Map<String, CommandProcessor> commandProcessorMap = new HashMap<>();
|
||||||
|
|
||||||
public CommandManager() {
|
public CommandManager() {
|
||||||
running = true;
|
running = true;
|
||||||
|
@ -36,8 +36,8 @@ public abstract class EntityCreature extends LivingEntity {
|
|||||||
private IPath path;
|
private IPath path;
|
||||||
private Position pathPosition;
|
private Position pathPosition;
|
||||||
|
|
||||||
protected List<GoalSelector> goalSelectors = new ArrayList<>();
|
protected final List<GoalSelector> goalSelectors = new ArrayList<>();
|
||||||
protected List<TargetSelector> targetSelectors = new ArrayList<>();
|
protected final List<TargetSelector> targetSelectors = new ArrayList<>();
|
||||||
private GoalSelector currentGoalSelector;
|
private GoalSelector currentGoalSelector;
|
||||||
|
|
||||||
private Entity target;
|
private Entity target;
|
||||||
|
@ -74,7 +74,7 @@ public class Player extends LivingEntity implements CommandSender {
|
|||||||
private boolean answerKeepAlive;
|
private boolean answerKeepAlive;
|
||||||
|
|
||||||
private String username;
|
private String username;
|
||||||
protected PlayerConnection playerConnection;
|
protected final PlayerConnection playerConnection;
|
||||||
protected final Set<Entity> viewableEntities = new CopyOnWriteArraySet<>();
|
protected final Set<Entity> viewableEntities = new CopyOnWriteArraySet<>();
|
||||||
|
|
||||||
private int latency;
|
private int latency;
|
||||||
@ -490,7 +490,7 @@ public class Player extends LivingEntity implements CommandSender {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Respawns the player by sending a {@link RespawnPacket} to the player and teleporting him
|
* Respawns the player by sending a {@link RespawnPacket} to the player and teleporting him
|
||||||
* to {@link #getRespawnPoint()}. It also resetso fire and his health
|
* to {@link #getRespawnPoint()}. It also resets fire and his health
|
||||||
*/
|
*/
|
||||||
public void respawn() {
|
public void respawn() {
|
||||||
if (!isDead())
|
if (!isDead())
|
||||||
@ -694,7 +694,7 @@ public class Player extends LivingEntity implements CommandSender {
|
|||||||
* Sends a legacy message with the specified color char.
|
* Sends a legacy message with the specified color char.
|
||||||
*
|
*
|
||||||
* @param text the text with the legacy color formatting
|
* @param text the text with the legacy color formatting
|
||||||
* @param colorChar the color charactero
|
* @param colorChar the color character
|
||||||
*/
|
*/
|
||||||
public void sendLegacyMessage(String text, char colorChar) {
|
public void sendLegacyMessage(String text, char colorChar) {
|
||||||
ColoredText coloredText = ColoredText.ofLegacy(text, colorChar);
|
ColoredText coloredText = ColoredText.ofLegacy(text, colorChar);
|
||||||
|
@ -5,7 +5,7 @@ import net.minestom.server.entity.EntityCreature;
|
|||||||
|
|
||||||
public abstract class GoalSelector {
|
public abstract class GoalSelector {
|
||||||
|
|
||||||
protected EntityCreature entityCreature;
|
protected final EntityCreature entityCreature;
|
||||||
|
|
||||||
public GoalSelector(EntityCreature entityCreature) {
|
public GoalSelector(EntityCreature entityCreature) {
|
||||||
this.entityCreature = entityCreature;
|
this.entityCreature = entityCreature;
|
||||||
|
@ -10,8 +10,8 @@ public class DoNothingGoal extends GoalSelector {
|
|||||||
|
|
||||||
private static final Random RANDOM = new Random();
|
private static final Random RANDOM = new Random();
|
||||||
|
|
||||||
private long time;
|
private final long time;
|
||||||
private float chance;
|
private final float chance;
|
||||||
private long startTime;
|
private long startTime;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -9,14 +9,14 @@ import net.minestom.server.utils.time.CooldownUtils;
|
|||||||
import net.minestom.server.utils.time.TimeUnit;
|
import net.minestom.server.utils.time.TimeUnit;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Attack the entity's target ({@link EntityCreature#getTarget()}) OR the closest entity
|
* Attacks the entity's target ({@link EntityCreature#getTarget()}) OR the closest entity
|
||||||
* which can be targeted with the entity {@link TargetSelector}
|
* which can be targeted with the entity {@link TargetSelector}.
|
||||||
*/
|
*/
|
||||||
public class MeleeAttackGoal extends GoalSelector {
|
public class MeleeAttackGoal extends GoalSelector {
|
||||||
|
|
||||||
private long lastHit;
|
private long lastHit;
|
||||||
private int delay;
|
private final int delay;
|
||||||
private TimeUnit timeUnit;
|
private final TimeUnit timeUnit;
|
||||||
|
|
||||||
private boolean stop;
|
private boolean stop;
|
||||||
|
|
||||||
|
@ -12,8 +12,8 @@ public class RandomStrollGoal extends GoalSelector {
|
|||||||
|
|
||||||
private static final long DELAY = 2500;
|
private static final long DELAY = 2500;
|
||||||
|
|
||||||
private int radius;
|
private final int radius;
|
||||||
private List<Position> closePositions;
|
private final List<Position> closePositions;
|
||||||
|
|
||||||
private long lastStroll;
|
private long lastStroll;
|
||||||
|
|
||||||
|
@ -7,11 +7,11 @@ import net.minestom.server.entity.damage.DamageType;
|
|||||||
import net.minestom.server.entity.damage.EntityDamage;
|
import net.minestom.server.entity.damage.EntityDamage;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Target the last damager of this entity
|
* Targets the last damager of this entity.
|
||||||
*/
|
*/
|
||||||
public class LastEntityDamagerTarget extends TargetSelector {
|
public class LastEntityDamagerTarget extends TargetSelector {
|
||||||
|
|
||||||
private float range;
|
private final float range;
|
||||||
|
|
||||||
public LastEntityDamagerTarget(EntityCreature entityCreature, float range) {
|
public LastEntityDamagerTarget(EntityCreature entityCreature, float range) {
|
||||||
super(entityCreature);
|
super(entityCreature);
|
||||||
|
@ -12,8 +12,8 @@ import java.util.function.Consumer;
|
|||||||
|
|
||||||
public class FakePlayer extends Player {
|
public class FakePlayer extends Player {
|
||||||
|
|
||||||
private FakePlayerOption option;
|
private final FakePlayerOption option;
|
||||||
private FakePlayerController fakePlayerController;
|
private final FakePlayerController fakePlayerController;
|
||||||
|
|
||||||
private FakePlayer(UUID uuid, String username, FakePlayerOption option) {
|
private FakePlayer(UUID uuid, String username, FakePlayerOption option) {
|
||||||
super(uuid, username, new FakePlayerConnection());
|
super(uuid, username, new FakePlayerConnection());
|
||||||
@ -40,9 +40,7 @@ public class FakePlayer extends Player {
|
|||||||
public static void initPlayer(UUID uuid, String username, FakePlayerOption option, Consumer<FakePlayer> scheduledCallback) {
|
public static void initPlayer(UUID uuid, String username, FakePlayerOption option, Consumer<FakePlayer> scheduledCallback) {
|
||||||
final FakePlayer fakePlayer = new FakePlayer(uuid, username, option);
|
final FakePlayer fakePlayer = new FakePlayer(uuid, username, option);
|
||||||
|
|
||||||
fakePlayer.addEventCallback(PlayerLoginEvent.class, event -> {
|
fakePlayer.addEventCallback(PlayerLoginEvent.class, event -> MinecraftServer.getSchedulerManager().buildTask(() -> scheduledCallback.accept(fakePlayer)).delay(1, TimeUnit.TICK).schedule());
|
||||||
MinecraftServer.getSchedulerManager().buildTask(() -> scheduledCallback.accept(fakePlayer)).delay(1, TimeUnit.TICK).schedule();
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -16,11 +16,11 @@ import net.minestom.server.utils.BlockPosition;
|
|||||||
import net.minestom.server.utils.inventory.PlayerInventoryUtils;
|
import net.minestom.server.utils.inventory.PlayerInventoryUtils;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class act as a client controller for {@link FakePlayer}
|
* This class act as a client controller for {@link FakePlayer}.
|
||||||
*/
|
*/
|
||||||
public class FakePlayerController {
|
public class FakePlayerController {
|
||||||
|
|
||||||
private FakePlayer fakePlayer;
|
private final FakePlayer fakePlayer;
|
||||||
|
|
||||||
public FakePlayerController(FakePlayer fakePlayer) {
|
public FakePlayerController(FakePlayer fakePlayer) {
|
||||||
this.fakePlayer = fakePlayer;
|
this.fakePlayer = fakePlayer;
|
||||||
|
@ -9,8 +9,8 @@ import net.minestom.server.instance.Chunk;
|
|||||||
public class PFColumnarSpace implements IColumnarSpace {
|
public class PFColumnarSpace implements IColumnarSpace {
|
||||||
|
|
||||||
private final ColumnarOcclusionFieldList occlusionFieldList = new ColumnarOcclusionFieldList(this);
|
private final ColumnarOcclusionFieldList occlusionFieldList = new ColumnarOcclusionFieldList(this);
|
||||||
private PFInstanceSpace instanceSpace;
|
private final PFInstanceSpace instanceSpace;
|
||||||
private Chunk chunk;
|
private final Chunk chunk;
|
||||||
|
|
||||||
|
|
||||||
public PFColumnarSpace(PFInstanceSpace instanceSpace, Chunk chunk) {
|
public PFColumnarSpace(PFInstanceSpace instanceSpace, Chunk chunk) {
|
||||||
|
@ -11,8 +11,8 @@ import java.util.concurrent.ConcurrentHashMap;
|
|||||||
|
|
||||||
public class PFInstanceSpace implements IInstanceSpace {
|
public class PFInstanceSpace implements IInstanceSpace {
|
||||||
|
|
||||||
private Instance instance;
|
private final Instance instance;
|
||||||
private Map<Chunk, PFColumnarSpace> chunkSpaceMap = new ConcurrentHashMap<>();
|
private final Map<Chunk, PFColumnarSpace> chunkSpaceMap = new ConcurrentHashMap<>();
|
||||||
|
|
||||||
public PFInstanceSpace(Instance instance) {
|
public PFInstanceSpace(Instance instance) {
|
||||||
this.instance = instance;
|
this.instance = instance;
|
||||||
|
@ -10,7 +10,7 @@ import net.minestom.server.utils.Position;
|
|||||||
|
|
||||||
public class PFPathingEntity implements IPathingEntity {
|
public class PFPathingEntity implements IPathingEntity {
|
||||||
|
|
||||||
private EntityCreature entity;
|
private final EntityCreature entity;
|
||||||
|
|
||||||
private float searchRange;
|
private float searchRange;
|
||||||
private Position targetPosition;
|
private Position targetPosition;
|
||||||
|
@ -14,7 +14,7 @@ import java.util.function.Consumer;
|
|||||||
// "You have to set both Orientation and Yaw/Pitch accordingly, otherwise it will not work."
|
// "You have to set both Orientation and Yaw/Pitch accordingly, otherwise it will not work."
|
||||||
public class EntityItemFrame extends ObjectEntity {
|
public class EntityItemFrame extends ObjectEntity {
|
||||||
|
|
||||||
private ItemFrameOrientation orientation;
|
private final ItemFrameOrientation orientation;
|
||||||
private ItemStack itemStack;
|
private ItemStack itemStack;
|
||||||
private Rotation rotation;
|
private Rotation rotation;
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@ import net.minestom.server.event.Event;
|
|||||||
|
|
||||||
public class EntityDeathEvent extends Event {
|
public class EntityDeathEvent extends Event {
|
||||||
|
|
||||||
private Entity entity;
|
private final Entity entity;
|
||||||
// TODO cause
|
// TODO cause
|
||||||
|
|
||||||
public EntityDeathEvent(Entity entity) {
|
public EntityDeathEvent(Entity entity) {
|
||||||
@ -13,6 +13,8 @@ public class EntityDeathEvent extends Event {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* Get the killed entity,
|
||||||
|
*
|
||||||
* @return the entity that died
|
* @return the entity that died
|
||||||
*/
|
*/
|
||||||
public Entity getEntity() {
|
public Entity getEntity() {
|
||||||
|
@ -9,8 +9,8 @@ import net.minestom.server.item.ItemStack;
|
|||||||
*/
|
*/
|
||||||
public class EntityItemMergeEvent extends CancellableEvent {
|
public class EntityItemMergeEvent extends CancellableEvent {
|
||||||
|
|
||||||
private ItemEntity source;
|
private final ItemEntity source;
|
||||||
private ItemEntity merged;
|
private final ItemEntity merged;
|
||||||
|
|
||||||
private ItemStack result;
|
private ItemStack result;
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@ import net.minestom.server.utils.Vector;
|
|||||||
|
|
||||||
public class EntityVelocityEvent extends CancellableEvent {
|
public class EntityVelocityEvent extends CancellableEvent {
|
||||||
|
|
||||||
private Entity entity;
|
private final Entity entity;
|
||||||
private Vector velocity;
|
private Vector velocity;
|
||||||
|
|
||||||
public EntityVelocityEvent(Entity entity, Vector velocity) {
|
public EntityVelocityEvent(Entity entity, Vector velocity) {
|
||||||
|
@ -7,9 +7,9 @@ import net.minestom.server.utils.item.ItemStackUtils;
|
|||||||
|
|
||||||
public class ArmorEquipEvent extends Event {
|
public class ArmorEquipEvent extends Event {
|
||||||
|
|
||||||
private Entity entity;
|
private final Entity entity;
|
||||||
private ItemStack armorItem;
|
private ItemStack armorItem;
|
||||||
private ArmorSlot armorSlot;
|
private final ArmorSlot armorSlot;
|
||||||
|
|
||||||
public ArmorEquipEvent(Entity entity, ItemStack armorItem, ArmorSlot armorSlot) {
|
public ArmorEquipEvent(Entity entity, ItemStack armorItem, ArmorSlot armorSlot) {
|
||||||
this.entity = entity;
|
this.entity = entity;
|
||||||
|
@ -5,7 +5,7 @@ import net.minestom.server.item.ItemStack;
|
|||||||
|
|
||||||
public class ItemDropEvent extends CancellableEvent {
|
public class ItemDropEvent extends CancellableEvent {
|
||||||
|
|
||||||
private ItemStack itemStack;
|
private final ItemStack itemStack;
|
||||||
|
|
||||||
public ItemDropEvent(ItemStack itemStack) {
|
public ItemDropEvent(ItemStack itemStack) {
|
||||||
this.itemStack = itemStack;
|
this.itemStack = itemStack;
|
||||||
|
@ -6,7 +6,7 @@ import net.minestom.server.item.ItemStack;
|
|||||||
|
|
||||||
public class ItemUpdateStateEvent extends Event {
|
public class ItemUpdateStateEvent extends Event {
|
||||||
|
|
||||||
private Player player;
|
private final Player player;
|
||||||
private final Player.Hand hand;
|
private final Player.Hand hand;
|
||||||
private final ItemStack itemStack;
|
private final ItemStack itemStack;
|
||||||
private boolean handAnimation;
|
private boolean handAnimation;
|
||||||
|
@ -5,7 +5,7 @@ import net.minestom.server.event.CancellableEvent;
|
|||||||
|
|
||||||
public class PickupExperienceEvent extends CancellableEvent {
|
public class PickupExperienceEvent extends CancellableEvent {
|
||||||
|
|
||||||
private ExperienceOrb experienceOrb;
|
private final ExperienceOrb experienceOrb;
|
||||||
private short experienceCount;
|
private short experienceCount;
|
||||||
|
|
||||||
public PickupExperienceEvent(ExperienceOrb experienceOrb) {
|
public PickupExperienceEvent(ExperienceOrb experienceOrb) {
|
||||||
|
@ -5,7 +5,7 @@ import net.minestom.server.item.ItemStack;
|
|||||||
|
|
||||||
public class PickupItemEvent extends CancellableEvent {
|
public class PickupItemEvent extends CancellableEvent {
|
||||||
|
|
||||||
private ItemStack itemStack;
|
private final ItemStack itemStack;
|
||||||
|
|
||||||
public PickupItemEvent(ItemStack itemStack) {
|
public PickupItemEvent(ItemStack itemStack) {
|
||||||
this.itemStack = itemStack;
|
this.itemStack = itemStack;
|
||||||
|
@ -9,10 +9,10 @@ public class PlayerBlockBreakEvent extends CancellableEvent {
|
|||||||
|
|
||||||
private final Player player;
|
private final Player player;
|
||||||
|
|
||||||
private BlockPosition blockPosition;
|
private final BlockPosition blockPosition;
|
||||||
|
|
||||||
private short blockStateId;
|
private final short blockStateId;
|
||||||
private CustomBlock customBlock;
|
private final CustomBlock customBlock;
|
||||||
|
|
||||||
private short resultBlockStateId;
|
private short resultBlockStateId;
|
||||||
private short resultCustomBlockId;
|
private short resultCustomBlockId;
|
||||||
|
@ -12,8 +12,8 @@ import net.minestom.server.utils.BlockPosition;
|
|||||||
public class PlayerBlockInteractEvent extends CancellableEvent {
|
public class PlayerBlockInteractEvent extends CancellableEvent {
|
||||||
|
|
||||||
private final Player player;
|
private final Player player;
|
||||||
private BlockPosition blockPosition;
|
private final BlockPosition blockPosition;
|
||||||
private Player.Hand hand;
|
private final Player.Hand hand;
|
||||||
private final BlockFace blockFace;
|
private final BlockFace blockFace;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -17,8 +17,8 @@ public class PlayerBlockPlaceEvent extends CancellableEvent {
|
|||||||
private final Player player;
|
private final Player player;
|
||||||
private short blockStateId;
|
private short blockStateId;
|
||||||
private short customBlockId;
|
private short customBlockId;
|
||||||
private BlockPosition blockPosition;
|
private final BlockPosition blockPosition;
|
||||||
private Player.Hand hand;
|
private final Player.Hand hand;
|
||||||
|
|
||||||
private boolean consumeBlock;
|
private boolean consumeBlock;
|
||||||
|
|
||||||
|
@ -15,7 +15,7 @@ import java.util.function.Function;
|
|||||||
public class PlayerChatEvent extends CancellableEvent {
|
public class PlayerChatEvent extends CancellableEvent {
|
||||||
|
|
||||||
private final Player sender;
|
private final Player sender;
|
||||||
private Collection<Player> recipients;
|
private final Collection<Player> recipients;
|
||||||
private String message;
|
private String message;
|
||||||
private Function<PlayerChatEvent, RichMessage> chatFormat;
|
private Function<PlayerChatEvent, RichMessage> chatFormat;
|
||||||
|
|
||||||
|
@ -135,7 +135,7 @@ public class MinestomOverwriteClassLoader extends URLClassLoader {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
private Class<?> define(String name, byte[] bytes, boolean resolve) throws ClassNotFoundException {
|
private Class<?> define(String name, byte[] bytes, boolean resolve) {
|
||||||
Class<?> defined = defineClass(name, bytes, 0, bytes.length);
|
Class<?> defined = defineClass(name, bytes, 0, bytes.length);
|
||||||
log.trace("Loaded with code modifiers: " + name);
|
log.trace("Loaded with code modifiers: " + name);
|
||||||
if (resolve) {
|
if (resolve) {
|
||||||
|
@ -46,7 +46,7 @@ public class GlobalPropertyServiceMinestom implements IGlobalPropertyService {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public IPropertyKey resolveKey(String name) {
|
public IPropertyKey resolveKey(String name) {
|
||||||
return keys.computeIfAbsent(name, k -> new BasicProperty(k));
|
return keys.computeIfAbsent(name, BasicProperty::new);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -28,14 +28,14 @@ public class MinestomBytecodeProvider implements IClassBytecodeProvider {
|
|||||||
try {
|
try {
|
||||||
reader = new ClassReader(classLoader.loadBytes(name, transform));
|
reader = new ClassReader(classLoader.loadBytes(name, transform));
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
throw new ClassNotFoundException("Could not load ClassNode with name "+name, e);
|
throw new ClassNotFoundException("Could not load ClassNode with name " + name, e);
|
||||||
}
|
}
|
||||||
reader.accept(node, 0);
|
reader.accept(node, 0);
|
||||||
return node;
|
return node;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ClassNode getClassNode(String name, boolean runTransformers) throws ClassNotFoundException, IOException {
|
public ClassNode getClassNode(String name, boolean runTransformers) throws ClassNotFoundException {
|
||||||
return loadNode(name, runTransformers);
|
return loadNode(name, runTransformers);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -59,7 +59,7 @@ class LootTableContainer {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private class Entry {
|
private static class Entry {
|
||||||
private ConditionContainer[] conditions;
|
private ConditionContainer[] conditions;
|
||||||
private String type;
|
private String type;
|
||||||
private String name;
|
private String name;
|
||||||
|
@ -5,7 +5,6 @@ import net.minestom.server.gamedata.loottables.LootTable;
|
|||||||
import net.minestom.server.gamedata.loottables.LootTableEntryType;
|
import net.minestom.server.gamedata.loottables.LootTableEntryType;
|
||||||
import net.minestom.server.gamedata.loottables.LootTableFunction;
|
import net.minestom.server.gamedata.loottables.LootTableFunction;
|
||||||
import net.minestom.server.gamedata.loottables.LootTableManager;
|
import net.minestom.server.gamedata.loottables.LootTableManager;
|
||||||
import net.minestom.server.item.Material;
|
|
||||||
import net.minestom.server.registry.Registries;
|
import net.minestom.server.registry.Registries;
|
||||||
import net.minestom.server.utils.NamespaceID;
|
import net.minestom.server.utils.NamespaceID;
|
||||||
|
|
||||||
|
@ -18,14 +18,14 @@ import java.util.Map;
|
|||||||
import java.util.concurrent.ConcurrentHashMap;
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handles loading and caching of tags
|
* Handles loading and caching of tags.
|
||||||
*/
|
*/
|
||||||
public class TagManager {
|
public class TagManager {
|
||||||
|
|
||||||
private static final Logger LOGGER = LoggerFactory.getLogger(TagManager.class);
|
private static final Logger LOGGER = LoggerFactory.getLogger(TagManager.class);
|
||||||
private final Gson gson;
|
private final Gson gson;
|
||||||
private Map<NamespaceID, Tag> cache = new ConcurrentHashMap<>();
|
private final Map<NamespaceID, Tag> cache = new ConcurrentHashMap<>();
|
||||||
private List<RequiredTag> requiredTags = new LinkedList<>();
|
private final List<RequiredTag> requiredTags = new LinkedList<>();
|
||||||
|
|
||||||
public TagManager() {
|
public TagManager() {
|
||||||
gson = new GsonBuilder()
|
gson = new GsonBuilder()
|
||||||
|
@ -58,8 +58,8 @@ public abstract class Chunk implements Viewable, DataContainer {
|
|||||||
public static final int BIOME_COUNT = 1024; // 4x4x4 blocks group
|
public static final int BIOME_COUNT = 1024; // 4x4x4 blocks group
|
||||||
|
|
||||||
protected final Instance instance;
|
protected final Instance instance;
|
||||||
protected Biome[] biomes;
|
protected final Biome[] biomes;
|
||||||
protected int chunkX, chunkZ;
|
protected final int chunkX, chunkZ;
|
||||||
|
|
||||||
// Options
|
// Options
|
||||||
private final boolean shouldGenerate;
|
private final boolean shouldGenerate;
|
||||||
@ -70,7 +70,7 @@ public abstract class Chunk implements Viewable, DataContainer {
|
|||||||
private ByteBuf fullDataPacket;
|
private ByteBuf fullDataPacket;
|
||||||
|
|
||||||
protected volatile boolean loaded = true;
|
protected volatile boolean loaded = true;
|
||||||
protected Set<Player> viewers = new CopyOnWriteArraySet<>();
|
protected final Set<Player> viewers = new CopyOnWriteArraySet<>();
|
||||||
|
|
||||||
// Path finding
|
// Path finding
|
||||||
protected PFColumnarSpace columnarSpace;
|
protected PFColumnarSpace columnarSpace;
|
||||||
|
@ -45,15 +45,15 @@ public class DynamicChunk extends Chunk {
|
|||||||
|
|
||||||
// Used to get all blocks with data (no null)
|
// Used to get all blocks with data (no null)
|
||||||
// Key is still chunk coordinates (see #getBlockIndex)
|
// Key is still chunk coordinates (see #getBlockIndex)
|
||||||
protected Int2ObjectMap<Data> blocksData = new Int2ObjectOpenHashMap<>();
|
protected final Int2ObjectMap<Data> blocksData = new Int2ObjectOpenHashMap<>();
|
||||||
|
|
||||||
// Contains CustomBlocks' block index which are updatable
|
// Contains CustomBlocks' block index which are updatable
|
||||||
protected IntSet updatableBlocks = new IntOpenHashSet();
|
protected final IntSet updatableBlocks = new IntOpenHashSet();
|
||||||
// (block index)/(last update in ms)
|
// (block index)/(last update in ms)
|
||||||
protected Int2LongMap updatableBlocksLastUpdate = new Int2LongOpenHashMap();
|
protected final Int2LongMap updatableBlocksLastUpdate = new Int2LongOpenHashMap();
|
||||||
|
|
||||||
// Block entities
|
// Block entities
|
||||||
protected Set<Integer> blockEntities = new CopyOnWriteArraySet<>();
|
protected final Set<Integer> blockEntities = new CopyOnWriteArraySet<>();
|
||||||
|
|
||||||
public DynamicChunk(Instance instance, Biome[] biomes, int chunkX, int chunkZ) {
|
public DynamicChunk(Instance instance, Biome[] biomes, int chunkX, int chunkZ) {
|
||||||
super(instance, biomes, chunkX, chunkZ, true);
|
super(instance, biomes, chunkX, chunkZ, true);
|
||||||
|
@ -22,7 +22,7 @@ import java.util.concurrent.atomic.AtomicInteger;
|
|||||||
*/
|
*/
|
||||||
public class BlockBatch implements InstanceBatch {
|
public class BlockBatch implements InstanceBatch {
|
||||||
|
|
||||||
private InstanceContainer instance;
|
private final InstanceContainer instance;
|
||||||
|
|
||||||
private final Map<Chunk, List<BlockData>> data = new HashMap<>();
|
private final Map<Chunk, List<BlockData>> data = new HashMap<>();
|
||||||
|
|
||||||
@ -90,9 +90,7 @@ public class BlockBatch implements InstanceBatch {
|
|||||||
// Execute the callback if this was the last chunk to process
|
// Execute the callback if this was the last chunk to process
|
||||||
if (isLast) {
|
if (isLast) {
|
||||||
if (callback != null) {
|
if (callback != null) {
|
||||||
instance.scheduleNextTick(inst -> {
|
instance.scheduleNextTick(inst -> callback.run());
|
||||||
callback.run();
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9,12 +9,12 @@ import java.util.Map;
|
|||||||
public class BlockManager {
|
public class BlockManager {
|
||||||
|
|
||||||
// custom block id -> custom block
|
// custom block id -> custom block
|
||||||
private CustomBlock[] customBlocksInternalId = new CustomBlock[Short.MAX_VALUE];
|
private final CustomBlock[] customBlocksInternalId = new CustomBlock[Short.MAX_VALUE];
|
||||||
// custom block identifier -> custom block
|
// custom block identifier -> custom block
|
||||||
private Map<String, CustomBlock> customBlocksId = new HashMap<>();
|
private final Map<String, CustomBlock> customBlocksId = new HashMap<>();
|
||||||
|
|
||||||
// block id -> block placement rule
|
// block id -> block placement rule
|
||||||
private BlockPlacementRule[] placementRules = new BlockPlacementRule[Short.MAX_VALUE];
|
private final BlockPlacementRule[] placementRules = new BlockPlacementRule[Short.MAX_VALUE];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Registers a {@link CustomBlock}.
|
* Registers a {@link CustomBlock}.
|
||||||
|
@ -8,7 +8,7 @@ import net.minestom.server.utils.BlockPosition;
|
|||||||
|
|
||||||
public abstract class BlockPlacementRule {
|
public abstract class BlockPlacementRule {
|
||||||
|
|
||||||
private short blockId;
|
private final short blockId;
|
||||||
|
|
||||||
public BlockPlacementRule(short blockId) {
|
public BlockPlacementRule(short blockId) {
|
||||||
this.blockId = blockId;
|
this.blockId = blockId;
|
||||||
|
@ -9,32 +9,32 @@ import net.minestom.server.utils.BlockPosition;
|
|||||||
|
|
||||||
public class AxisPlacementRule extends BlockPlacementRule {
|
public class AxisPlacementRule extends BlockPlacementRule {
|
||||||
|
|
||||||
Block block;
|
protected final Block block;
|
||||||
|
|
||||||
public AxisPlacementRule(Block block) {
|
public AxisPlacementRule(Block block) {
|
||||||
super(block);
|
super(block);
|
||||||
this.block = block;
|
this.block = block;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean canPlace(Instance instance, BlockPosition blockPosition) {
|
public boolean canPlace(Instance instance, BlockPosition blockPosition) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public short blockRefresh(Instance instance, BlockPosition blockPosition, short currentId) {
|
public short blockRefresh(Instance instance, BlockPosition blockPosition, short currentId) {
|
||||||
return currentId;
|
return currentId;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public short blockPlace(Instance instance, Block block, BlockFace blockFace, Player pl) {
|
public short blockPlace(Instance instance, Block block, BlockFace blockFace, Player pl) {
|
||||||
String axis = "y";
|
String axis = "y";
|
||||||
if (blockFace == BlockFace.WEST || blockFace == BlockFace.EAST) {
|
if (blockFace == BlockFace.WEST || blockFace == BlockFace.EAST) {
|
||||||
axis = "x";
|
axis = "x";
|
||||||
} else if (blockFace == BlockFace.SOUTH || blockFace == BlockFace.NORTH) {
|
} else if (blockFace == BlockFace.SOUTH || blockFace == BlockFace.NORTH) {
|
||||||
axis = "z";
|
axis = "z";
|
||||||
}
|
}
|
||||||
return block.withProperties("axis="+axis);
|
return block.withProperties("axis=" + axis);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -7,10 +7,10 @@ import net.minestom.server.item.Enchantment;
|
|||||||
|
|
||||||
public class EnchantmentTableInventory extends Inventory {
|
public class EnchantmentTableInventory extends Inventory {
|
||||||
|
|
||||||
private short[] levelRequirements = new short[EnchantmentSlot.values().length];
|
private final short[] levelRequirements = new short[EnchantmentSlot.values().length];
|
||||||
private short seed;
|
private short seed;
|
||||||
private short[] enchantmentShown = new short[EnchantmentSlot.values().length];
|
private final short[] enchantmentShown = new short[EnchantmentSlot.values().length];
|
||||||
private short[] enchantmentLevel = new short[EnchantmentSlot.values().length];
|
private final short[] enchantmentLevel = new short[EnchantmentSlot.values().length];
|
||||||
|
|
||||||
public EnchantmentTableInventory(String title) {
|
public EnchantmentTableInventory(String title) {
|
||||||
super(InventoryType.ENCHANTMENT, title);
|
super(InventoryType.ENCHANTMENT, title);
|
||||||
|
@ -10,7 +10,7 @@ import java.util.Map;
|
|||||||
|
|
||||||
public class EnchantedBookMeta implements ItemMeta {
|
public class EnchantedBookMeta implements ItemMeta {
|
||||||
|
|
||||||
private Map<Enchantment, Short> storedEnchantmentMap = new HashMap<>();
|
private final Map<Enchantment, Short> storedEnchantmentMap = new HashMap<>();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the stored enchantment map.
|
* Gets the stored enchantment map.
|
||||||
|
@ -202,10 +202,10 @@ public class MapMeta implements ItemMeta {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static class MapDecoration {
|
public static class MapDecoration {
|
||||||
private String id;
|
private final String id;
|
||||||
private byte type;
|
private final byte type;
|
||||||
private byte x, z;
|
private final byte x, z;
|
||||||
private double rotation;
|
private final double rotation;
|
||||||
|
|
||||||
public MapDecoration(String id, byte type, byte x, byte z, double rotation) {
|
public MapDecoration(String id, byte type, byte x, byte z, double rotation) {
|
||||||
this.id = id;
|
this.id = id;
|
||||||
|
@ -21,7 +21,7 @@ import java.util.concurrent.CopyOnWriteArrayList;
|
|||||||
public class PotionMeta implements ItemMeta {
|
public class PotionMeta implements ItemMeta {
|
||||||
|
|
||||||
private PotionType potionType;
|
private PotionType potionType;
|
||||||
private List<CustomPotionEffect> customPotionEffects = new CopyOnWriteArrayList<>();
|
private final List<CustomPotionEffect> customPotionEffects = new CopyOnWriteArrayList<>();
|
||||||
|
|
||||||
private boolean hasColor;
|
private boolean hasColor;
|
||||||
private byte red, green, blue;
|
private byte red, green, blue;
|
||||||
|
@ -83,9 +83,7 @@ public class UseItemListener {
|
|||||||
|
|
||||||
// Eating code, contains the eating time customisation
|
// Eating code, contains the eating time customisation
|
||||||
PlayerPreEatEvent playerPreEatEvent = new PlayerPreEatEvent(player, itemStack, player.getDefaultEatingTime());
|
PlayerPreEatEvent playerPreEatEvent = new PlayerPreEatEvent(player, itemStack, player.getDefaultEatingTime());
|
||||||
player.callCancellableEvent(PlayerPreEatEvent.class, playerPreEatEvent, () -> {
|
player.callCancellableEvent(PlayerPreEatEvent.class, playerPreEatEvent, () -> player.refreshEating(true, playerPreEatEvent.getEatingTime()));
|
||||||
player.refreshEating(true, playerPreEatEvent.getEatingTime());
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (itemAnimationType != null) {
|
if (itemAnimationType != null) {
|
||||||
|
@ -14,7 +14,7 @@ public class PacketListenerManager {
|
|||||||
|
|
||||||
private static final ConnectionManager CONNECTION_MANAGER = MinecraftServer.getConnectionManager();
|
private static final ConnectionManager CONNECTION_MANAGER = MinecraftServer.getConnectionManager();
|
||||||
|
|
||||||
private Map<Class<? extends ClientPlayPacket>, PacketListenerConsumer> listeners = new ConcurrentHashMap<>();
|
private final Map<Class<? extends ClientPlayPacket>, PacketListenerConsumer> listeners = new ConcurrentHashMap<>();
|
||||||
|
|
||||||
public PacketListenerManager() {
|
public PacketListenerManager() {
|
||||||
setListener(ClientKeepAlivePacket.class, KeepAliveListener::listener);
|
setListener(ClientKeepAlivePacket.class, KeepAliveListener::listener);
|
||||||
|
@ -19,17 +19,17 @@ import java.util.function.Function;
|
|||||||
*/
|
*/
|
||||||
public final class ConnectionManager {
|
public final class ConnectionManager {
|
||||||
|
|
||||||
private Set<Player> players = new CopyOnWriteArraySet<>();
|
private final Set<Player> players = new CopyOnWriteArraySet<>();
|
||||||
private Map<PlayerConnection, Player> connectionPlayerMap = Collections.synchronizedMap(new HashMap<>());
|
private final Map<PlayerConnection, Player> connectionPlayerMap = Collections.synchronizedMap(new HashMap<>());
|
||||||
|
|
||||||
// All the consumers to call once a packet is received
|
// All the consumers to call once a packet is received
|
||||||
private List<PacketConsumer> receivePacketConsumers = new CopyOnWriteArrayList<>();
|
private final List<PacketConsumer> receivePacketConsumers = new CopyOnWriteArrayList<>();
|
||||||
// The uuid provider once a player login
|
// The uuid provider once a player login
|
||||||
private UuidProvider uuidProvider;
|
private UuidProvider uuidProvider;
|
||||||
// The player provider to have your own Player implementation
|
// The player provider to have your own Player implementation
|
||||||
private PlayerProvider playerProvider;
|
private PlayerProvider playerProvider;
|
||||||
// The consumers to call once a player connect, mostly used to init events
|
// The consumers to call once a player connect, mostly used to init events
|
||||||
private List<Consumer<Player>> playerInitializations = new CopyOnWriteArrayList<>();
|
private final List<Consumer<Player>> playerInitializations = new CopyOnWriteArrayList<>();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the {@link Player} linked to a {@link PlayerConnection}.
|
* Gets the {@link Player} linked to a {@link PlayerConnection}.
|
||||||
|
@ -15,7 +15,7 @@ public class LegacyPingHandler extends ChannelInboundHandlerAdapter {
|
|||||||
private ByteBuf buf;
|
private ByteBuf buf;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void channelRead(ChannelHandlerContext ctx, Object object) throws Exception {
|
public void channelRead(ChannelHandlerContext ctx, Object object) {
|
||||||
ByteBuf buf = (ByteBuf) object;
|
ByteBuf buf = (ByteBuf) object;
|
||||||
|
|
||||||
if (this.buf != null) {
|
if (this.buf != null) {
|
||||||
|
@ -11,7 +11,7 @@ import java.util.List;
|
|||||||
public class PacketDecoder extends ByteToMessageDecoder {
|
public class PacketDecoder extends ByteToMessageDecoder {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void decode(ChannelHandlerContext ctx, ByteBuf buf, List<Object> list) throws Exception {
|
protected void decode(ChannelHandlerContext ctx, ByteBuf buf, List<Object> list) {
|
||||||
if (buf.readableBytes() > 0) {
|
if (buf.readableBytes() > 0) {
|
||||||
list.add(new InboundPacket(Utils.readVarInt(buf), buf));
|
list.add(new InboundPacket(Utils.readVarInt(buf), buf));
|
||||||
}
|
}
|
||||||
|
@ -9,7 +9,7 @@ import net.minestom.server.utils.PacketUtils;
|
|||||||
public class PacketEncoder extends MessageToByteEncoder<ServerPacket> {
|
public class PacketEncoder extends MessageToByteEncoder<ServerPacket> {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void encode(ChannelHandlerContext ctx, ServerPacket packet, ByteBuf buf) throws Exception {
|
protected void encode(ChannelHandlerContext ctx, ServerPacket packet, ByteBuf buf) {
|
||||||
PacketUtils.writePacket(buf, packet);
|
PacketUtils.writePacket(buf, packet);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -8,9 +8,9 @@ import java.util.UUID;
|
|||||||
|
|
||||||
public class ChatMessagePacket implements ServerPacket {
|
public class ChatMessagePacket implements ServerPacket {
|
||||||
|
|
||||||
private String jsonMessage;
|
public String jsonMessage;
|
||||||
private Position position;
|
public Position position;
|
||||||
private UUID uuid;
|
public UUID uuid;
|
||||||
|
|
||||||
public ChatMessagePacket(String jsonMessage, Position position, UUID uuid) {
|
public ChatMessagePacket(String jsonMessage, Position position, UUID uuid) {
|
||||||
this.jsonMessage = jsonMessage;
|
this.jsonMessage = jsonMessage;
|
||||||
|
@ -20,8 +20,7 @@ public class WindowItemsPacket implements ServerPacket {
|
|||||||
}
|
}
|
||||||
|
|
||||||
writer.writeShort((short) items.length);
|
writer.writeShort((short) items.length);
|
||||||
for (int i = 0; i < items.length; i++) {
|
for (ItemStack item : items) {
|
||||||
ItemStack item = items[i];
|
|
||||||
writer.writeItemStack(item);
|
writer.writeItemStack(item);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -35,7 +35,7 @@ public class WorldBorderPacket implements ServerPacket {
|
|||||||
|
|
||||||
public static class WBSetSize extends WBAction {
|
public static class WBSetSize extends WBAction {
|
||||||
|
|
||||||
public double diameter;
|
public final double diameter;
|
||||||
|
|
||||||
public WBSetSize(double diameter) {
|
public WBSetSize(double diameter) {
|
||||||
this.diameter = diameter;
|
this.diameter = diameter;
|
||||||
@ -49,9 +49,9 @@ public class WorldBorderPacket implements ServerPacket {
|
|||||||
|
|
||||||
public static class WBLerpSize extends WBAction {
|
public static class WBLerpSize extends WBAction {
|
||||||
|
|
||||||
public double oldDiameter;
|
public final double oldDiameter;
|
||||||
public double newDiameter;
|
public final double newDiameter;
|
||||||
public long speed;
|
public final long speed;
|
||||||
|
|
||||||
public WBLerpSize(double oldDiameter, double newDiameter, long speed) {
|
public WBLerpSize(double oldDiameter, double newDiameter, long speed) {
|
||||||
this.oldDiameter = oldDiameter;
|
this.oldDiameter = oldDiameter;
|
||||||
@ -69,7 +69,7 @@ public class WorldBorderPacket implements ServerPacket {
|
|||||||
|
|
||||||
public static class WBSetCenter extends WBAction {
|
public static class WBSetCenter extends WBAction {
|
||||||
|
|
||||||
public double x, z;
|
public final double x, z;
|
||||||
|
|
||||||
public WBSetCenter(double x, double z) {
|
public WBSetCenter(double x, double z) {
|
||||||
this.x = x;
|
this.x = x;
|
||||||
@ -85,13 +85,13 @@ public class WorldBorderPacket implements ServerPacket {
|
|||||||
|
|
||||||
public static class WBInitialize extends WBAction {
|
public static class WBInitialize extends WBAction {
|
||||||
|
|
||||||
public double x, z;
|
public final double x, z;
|
||||||
public double oldDiameter;
|
public final double oldDiameter;
|
||||||
public double newDiameter;
|
public final double newDiameter;
|
||||||
public long speed;
|
public final long speed;
|
||||||
public int portalTeleportBoundary;
|
public final int portalTeleportBoundary;
|
||||||
public int warningTime;
|
public final int warningTime;
|
||||||
public int warningBlocks;
|
public final int warningBlocks;
|
||||||
|
|
||||||
public WBInitialize(double x, double z, double oldDiameter, double newDiameter, long speed,
|
public WBInitialize(double x, double z, double oldDiameter, double newDiameter, long speed,
|
||||||
int portalTeleportBoundary, int warningTime, int warningBlocks) {
|
int portalTeleportBoundary, int warningTime, int warningBlocks) {
|
||||||
@ -120,7 +120,7 @@ public class WorldBorderPacket implements ServerPacket {
|
|||||||
|
|
||||||
public static class WBSetWarningTime extends WBAction {
|
public static class WBSetWarningTime extends WBAction {
|
||||||
|
|
||||||
public int warningTime;
|
public final int warningTime;
|
||||||
|
|
||||||
public WBSetWarningTime(int warningTime) {
|
public WBSetWarningTime(int warningTime) {
|
||||||
this.warningTime = warningTime;
|
this.warningTime = warningTime;
|
||||||
@ -134,7 +134,7 @@ public class WorldBorderPacket implements ServerPacket {
|
|||||||
|
|
||||||
public static class WBSetWarningBlocks extends WBAction {
|
public static class WBSetWarningBlocks extends WBAction {
|
||||||
|
|
||||||
public int warningBlocks;
|
public final int warningBlocks;
|
||||||
|
|
||||||
public WBSetWarningBlocks(int warningBlocks) {
|
public WBSetWarningBlocks(int warningBlocks) {
|
||||||
this.warningBlocks = warningBlocks;
|
this.warningBlocks = warningBlocks;
|
||||||
|
@ -7,10 +7,7 @@ import it.unimi.dsi.fastutil.longs.LongSet;
|
|||||||
import net.minestom.server.instance.Instance;
|
import net.minestom.server.instance.Instance;
|
||||||
import net.minestom.server.utils.chunk.ChunkUtils;
|
import net.minestom.server.utils.chunk.ChunkUtils;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.*;
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.concurrent.ConcurrentHashMap;
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
import java.util.concurrent.CountDownLatch;
|
import java.util.concurrent.CountDownLatch;
|
||||||
import java.util.concurrent.Future;
|
import java.util.concurrent.Future;
|
||||||
@ -78,7 +75,7 @@ public class PerGroupChunkProvider extends ThreadProvider {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// The size of the final list, used as the initial capacity
|
// The size of the final list, used as the initial capacity
|
||||||
final int size = neighboursGroups.stream().mapToInt(value -> value.size()).sum() + 1;
|
final int size = neighboursGroups.stream().mapToInt(Set::size).sum() + 1;
|
||||||
|
|
||||||
// Represent the merged group of all the neighbours
|
// Represent the merged group of all the neighbours
|
||||||
LongSet finalGroup = new LongArraySet(size);
|
LongSet finalGroup = new LongArraySet(size);
|
||||||
@ -135,21 +132,18 @@ public class PerGroupChunkProvider extends ThreadProvider {
|
|||||||
}));
|
}));
|
||||||
|
|
||||||
// Update all the chunks
|
// Update all the chunks
|
||||||
instanceMap.keySet().forEach(chunksIndexes -> {
|
instanceMap.keySet().forEach(chunksIndexes -> futures.add(pool.submit(() -> {
|
||||||
|
// Wait for the instance to be updated
|
||||||
|
// Needed because the instance tick is used to unload waiting chunks
|
||||||
|
try {
|
||||||
|
countDownLatch.await();
|
||||||
|
} catch (InterruptedException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
futures.add(pool.submit(() -> {
|
// Tick all this chunk group
|
||||||
// Wait for the instance to be updated
|
chunksIndexes.forEach((long chunkIndex) -> processChunkTick(instance, chunkIndex, time));
|
||||||
// Needed because the instance tick is used to unload waiting chunks
|
})));
|
||||||
try {
|
|
||||||
countDownLatch.await();
|
|
||||||
} catch (InterruptedException e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tick all this chunk group
|
|
||||||
chunksIndexes.forEach((long chunkIndex) -> processChunkTick(instance, chunkIndex, time));
|
|
||||||
}));
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
return futures;
|
return futures;
|
||||||
}
|
}
|
||||||
|
@ -12,11 +12,11 @@ import java.util.Map;
|
|||||||
import java.util.concurrent.Future;
|
import java.util.concurrent.Future;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Separate work between instance (1 instance = 1 thread execution)
|
* Separates work between instance (1 instance = 1 thread execution).
|
||||||
*/
|
*/
|
||||||
public class PerInstanceThreadProvider extends ThreadProvider {
|
public class PerInstanceThreadProvider extends ThreadProvider {
|
||||||
|
|
||||||
private Map<Instance, LongSet> instanceChunkMap = new HashMap<>();
|
private final Map<Instance, LongSet> instanceChunkMap = new HashMap<>();
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onInstanceCreate(Instance instance) {
|
public void onInstanceCreate(Instance instance) {
|
||||||
@ -49,15 +49,12 @@ public class PerInstanceThreadProvider extends ThreadProvider {
|
|||||||
public List<Future<?>> update(long time) {
|
public List<Future<?>> update(long time) {
|
||||||
List<Future<?>> futures = new ArrayList<>();
|
List<Future<?>> futures = new ArrayList<>();
|
||||||
|
|
||||||
instanceChunkMap.forEach((instance, chunkIndexes) -> {
|
instanceChunkMap.forEach((instance, chunkIndexes) -> futures.add(pool.submit(() -> {
|
||||||
|
// Tick instance
|
||||||
futures.add(pool.submit(() -> {
|
updateInstance(instance, time);
|
||||||
// Tick instance
|
// Tick chunks
|
||||||
updateInstance(instance, time);
|
chunkIndexes.forEach((long chunkIndex) -> processChunkTick(instance, chunkIndex, time));
|
||||||
// Tick chunks
|
})));
|
||||||
chunkIndexes.forEach((long chunkIndex) -> processChunkTick(instance, chunkIndex, time));
|
|
||||||
}));
|
|
||||||
});
|
|
||||||
return futures;
|
return futures;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -43,8 +43,7 @@ public final class ArrayUtils {
|
|||||||
for (int i = 0; i < a.length; i++) {
|
for (int i = 0; i < a.length; i++) {
|
||||||
final long aValue = a[i];
|
final long aValue = a[i];
|
||||||
boolean contains = false;
|
boolean contains = false;
|
||||||
for (int n = 0; n < b.length; n++) {
|
for (final long bValue : b) {
|
||||||
final long bValue = b[n];
|
|
||||||
if (bValue == aValue) {
|
if (bValue == aValue) {
|
||||||
contains = true;
|
contains = true;
|
||||||
break;
|
break;
|
||||||
|
@ -4,7 +4,6 @@ import it.unimi.dsi.fastutil.ints.Int2ObjectOpenHashMap;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.regex.Pattern;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Represents a namespaced ID
|
* Represents a namespaced ID
|
||||||
@ -29,7 +28,7 @@ public class NamespaceID implements CharSequence {
|
|||||||
final int index = namespaceID.indexOf(':');
|
final int index = namespaceID.indexOf(':');
|
||||||
if (index < 0)
|
if (index < 0)
|
||||||
return "minecraft";
|
return "minecraft";
|
||||||
assert namespaceID.indexOf(':', index+1) == -1: "Namespace ID can only have at most one colon ':' ("+namespaceID+")";
|
assert namespaceID.indexOf(':', index + 1) == -1 : "Namespace ID can only have at most one colon ':' (" + namespaceID + ")";
|
||||||
return namespaceID.substring(0, index);
|
return namespaceID.substring(0, index);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -44,7 +43,7 @@ public class NamespaceID implements CharSequence {
|
|||||||
final int index = namespaceID.indexOf(':');
|
final int index = namespaceID.indexOf(':');
|
||||||
if (index < 0)
|
if (index < 0)
|
||||||
return namespaceID;
|
return namespaceID;
|
||||||
assert namespaceID.indexOf(':', index+1) == -1: "Namespace ID can only have at most one colon ':' ("+namespaceID+")";
|
assert namespaceID.indexOf(':', index + 1) == -1 : "Namespace ID can only have at most one colon ':' (" + namespaceID + ")";
|
||||||
return namespaceID.substring(index + 1);
|
return namespaceID.substring(index + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -82,9 +81,9 @@ public class NamespaceID implements CharSequence {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void validate() {
|
private void validate() {
|
||||||
assert !domain.contains(".") && !domain.contains("/") : "Domain cannot contain a dot nor a slash character (" + full+ ")";
|
assert !domain.contains(".") && !domain.contains("/") : "Domain cannot contain a dot nor a slash character (" + full + ")";
|
||||||
assert domain.matches(legalLetters) : "Illegal character in domain ("+full+"). Must match "+legalLetters;
|
assert domain.matches(legalLetters) : "Illegal character in domain (" + full + "). Must match " + legalLetters;
|
||||||
assert path.matches(legalLetters) : "Illegal character in path ("+full+"). Must match "+legalLetters;
|
assert path.matches(legalLetters) : "Illegal character in path (" + full + "). Must match " + legalLetters;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getDomain() {
|
public String getDomain() {
|
||||||
|
@ -135,8 +135,8 @@ public final class Utils {
|
|||||||
}
|
}
|
||||||
final long[] data = encodeBlocks(blocksData, bitsPerEntry);
|
final long[] data = encodeBlocks(blocksData, bitsPerEntry);
|
||||||
writeVarIntBuf(buffer, data.length);
|
writeVarIntBuf(buffer, data.length);
|
||||||
for (int i = 0; i < data.length; i++) {
|
for (long datum : data) {
|
||||||
buffer.writeLong(data[i]);
|
buffer.writeLong(datum);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user