SPIGOT-7540, #1312: Add ServerTickManager API
By: Miles Holder <mwholder2005@gmail.com>
This commit is contained in:
@@ -133,6 +133,7 @@ import org.bukkit.NamespacedKey;
|
||||
import org.bukkit.OfflinePlayer;
|
||||
import org.bukkit.Registry;
|
||||
import org.bukkit.Server;
|
||||
import org.bukkit.ServerTickManager;
|
||||
import org.bukkit.StructureType;
|
||||
import org.bukkit.UnsafeValues;
|
||||
import org.bukkit.Warning.WarningState;
|
||||
@@ -298,6 +299,7 @@ public final class CraftServer implements Server {
|
||||
public String minimumAPI;
|
||||
public CraftScoreboardManager scoreboardManager;
|
||||
public CraftDataPackManager dataPackManager;
|
||||
private CraftServerTickManager serverTickManager;
|
||||
public boolean playerCommandState;
|
||||
private boolean printSaveWarning;
|
||||
private CraftIconCache icon;
|
||||
@@ -324,6 +326,7 @@ public final class CraftServer implements Server {
|
||||
this.serverVersion = CraftServer.class.getPackage().getImplementationVersion();
|
||||
this.structureManager = new CraftStructureManager(console.getStructureManager());
|
||||
this.dataPackManager = new CraftDataPackManager(this.getServer().getPackRepository());
|
||||
this.serverTickManager = new CraftServerTickManager(console.tickRateManager());
|
||||
|
||||
Bukkit.setServer(this);
|
||||
|
||||
@@ -714,6 +717,11 @@ public final class CraftServer implements Server {
|
||||
return this.dataPackManager;
|
||||
}
|
||||
|
||||
@Override
|
||||
public ServerTickManager getServerTickManager() {
|
||||
return this.serverTickManager;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getResourcePack() {
|
||||
return this.getServer().getServerResourcePack().map(MinecraftServer.ServerResourcePackInfo::url).orElse("");
|
||||
|
||||
@@ -0,0 +1,93 @@
|
||||
package org.bukkit.craftbukkit;
|
||||
|
||||
import com.google.common.base.Preconditions;
|
||||
import net.minecraft.server.ServerTickRateManager;
|
||||
import org.bukkit.ServerTickManager;
|
||||
import org.bukkit.craftbukkit.entity.CraftEntity;
|
||||
import org.bukkit.entity.Entity;
|
||||
|
||||
final class CraftServerTickManager implements ServerTickManager {
|
||||
|
||||
private final ServerTickRateManager manager;
|
||||
|
||||
CraftServerTickManager(ServerTickRateManager manager) {
|
||||
this.manager = manager;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isRunningNormally() {
|
||||
return manager.runsNormally();
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isStepping() {
|
||||
return manager.isSteppingForward();
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isSprinting() {
|
||||
return manager.isSprinting();
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isFrozen() {
|
||||
return manager.isFrozen();
|
||||
}
|
||||
|
||||
@Override
|
||||
public float getTickRate() {
|
||||
return manager.tickrate();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setTickRate(final float tickRate) {
|
||||
Preconditions.checkArgument(tickRate > 1 && tickRate < 10_000, "The given tick rate must not be less than one");
|
||||
manager.setTickRate(tickRate);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setFrozen(final boolean frozen) {
|
||||
if (frozen) {
|
||||
if (manager.isSprinting()) {
|
||||
manager.stopSprinting();
|
||||
}
|
||||
|
||||
if (manager.isSteppingForward()) {
|
||||
manager.stopStepping();
|
||||
}
|
||||
}
|
||||
|
||||
manager.setFrozen(frozen);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean stepGameIfFrozen(final int ticks) {
|
||||
return manager.stepGameIfPaused(ticks);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean stopStepping() {
|
||||
return manager.stopStepping();
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean requestGameToSprint(final int ticks) {
|
||||
return manager.requestGameToSprint(ticks);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean stopSprinting() {
|
||||
return manager.stopSprinting();
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isFrozen(final Entity entity) {
|
||||
Preconditions.checkArgument(entity != null, "The given entity must not be null");
|
||||
return manager.isEntityFrozen(((CraftEntity) entity).getHandle());
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getFrozenTicksToRun() {
|
||||
return manager.frozenTicksToRun();
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user