mirror of
https://github.com/NoCheatPlus/NoCheatPlus.git
synced 2024-12-26 18:37:59 +01:00
Adjust/fix moving debug output.
This commit is contained in:
parent
b73f68dd55
commit
d7110b3239
@ -19,7 +19,7 @@ import fr.neatmonster.nocheatplus.utilities.build.BuildParameters;
|
||||
public class DebugUtil {
|
||||
|
||||
/**
|
||||
* 3 decimal digits after comma (StringUtil.fdec3).
|
||||
* 3 decimal digits after comma (StringUtil.fdec3). No leading new line.
|
||||
* @param from
|
||||
* @param to
|
||||
* @param loc Reference location for from, usually Player.getLocation().
|
||||
@ -27,22 +27,21 @@ public class DebugUtil {
|
||||
* @return
|
||||
*/
|
||||
public static void addFormattedMove(final PlayerLocation from, final PlayerLocation to, final Location loc, final StringBuilder builder){
|
||||
builder.append(" " + from.getWorld().getName() + " " + StringUtil.fdec3.format(from.getX()) + (from.getX() == loc.getX() ? "" : ("(" + StringUtil.fdec3.format(loc.getX()) + ")")));
|
||||
builder.append(StringUtil.fdec3.format(from.getX()) + (from.getX() == loc.getX() ? "" : ("(" + StringUtil.fdec3.format(loc.getX()) + ")")));
|
||||
builder.append(", " + StringUtil.fdec3.format(from.getY()) + (from.getY() == loc.getY() ? "" : ("(" + StringUtil.fdec3.format(loc.getY()) + ")")));
|
||||
builder.append(", " + StringUtil.fdec3.format(from.getZ()) + (from.getZ() == loc.getZ() ? "" : ("(" + StringUtil.fdec3.format(loc.getZ()) + ")")));
|
||||
builder.append(" -> " + StringUtil.fdec3.format(to.getX()) + ", " + StringUtil.fdec3.format(to.getY()) + ", " + StringUtil.fdec3.format(to.getZ()));
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Add exact coordinates, multiple lines.
|
||||
* Add exact coordinates, multiple lines. No leading new line.
|
||||
* @param from
|
||||
* @param to
|
||||
* @param loc Reference location for from, usually Player.getLocation().
|
||||
* @param builder
|
||||
*/
|
||||
public static void addMove(final PlayerLocation from, final PlayerLocation to, final Location loc, final StringBuilder builder){
|
||||
builder.append(" " + from.getWorld().getName() + "moves:\nfrom: " + from.getX() + (from.getX() == loc.getX() ? "" : ("(" + loc.getX() + ")")));
|
||||
builder.append("from: " + from.getX() + (from.getX() == loc.getX() ? "" : ("(" + loc.getX() + ")")));
|
||||
builder.append(", " + from.getY() + (from.getY() == loc.getY() ? "" : ("(" + loc.getY() + ")")));
|
||||
builder.append(", " + from.getZ() + (from.getZ() == loc.getZ() ? "" : ("(" + loc.getZ() + ")")));
|
||||
builder.append("\nto: " + to.getX() + ", " + to.getY() + ", " + to.getZ());
|
||||
@ -55,15 +54,17 @@ public class DebugUtil {
|
||||
* @param to
|
||||
* @param mcAccess
|
||||
*/
|
||||
public static void outputMoveDebug(final Player player, final PlayerLocation from, final PlayerLocation to, final MCAccess mcAccess) {
|
||||
public static void outputMoveDebug(final Player player, final PlayerLocation from, final PlayerLocation to, final double maxYOnGround, final MCAccess mcAccess) {
|
||||
final StringBuilder builder = new StringBuilder(250);
|
||||
final Location loc = player.getLocation();
|
||||
// TODO: Differentiate debug levels (needs setting up some policy + document in BuildParamteres)?
|
||||
builder.append(player.getName());
|
||||
if (BuildParameters.debugLevel > 0) {
|
||||
builder.append("\n-------------- MOVE --------------\n");
|
||||
builder.append(player.getName() + " " + from.getWorld().getName() + ":\n");
|
||||
addMove(from, to, loc, builder);
|
||||
}
|
||||
else {
|
||||
builder.append(player.getName() + " " + from.getWorld().getName() + " ");
|
||||
addFormattedMove(from, to, loc, builder);
|
||||
}
|
||||
final double jump = mcAccess.getJumpAmplifier(player);
|
||||
@ -74,12 +75,12 @@ public class DebugUtil {
|
||||
|
||||
if (BuildParameters.debugLevel > 0){
|
||||
// Note: the block flags are for normal on-ground checking, not with yOnGrond set to 0.5.
|
||||
from.collectBlockFlags(from.getyOnGround());
|
||||
from.collectBlockFlags(maxYOnGround);
|
||||
if (from.getBlockFlags() != 0) builder.append("\nfrom flags: " + StringUtil.join(BlockProperties.getFlagNames(from.getBlockFlags()), "+"));
|
||||
if (from.getTypeId() != 0) addBlockInfo(builder, from, "\nfrom");
|
||||
if (from.getTypeIdBelow() != 0) addBlockBelowInfo(builder, from, "\nfrom");
|
||||
if (!from.isOnGround() && from.isOnGround(0.5)) builder.append(" (ground within 0.5)");
|
||||
to.collectBlockFlags(to.getyOnGround());
|
||||
to.collectBlockFlags(maxYOnGround);
|
||||
if (to.getBlockFlags() != 0) builder.append("\nto flags: " + StringUtil.join(BlockProperties.getFlagNames(to.getBlockFlags()), "+"));
|
||||
if (to.getTypeId() != 0) addBlockInfo(builder, to, "\nto");
|
||||
if (to.getTypeIdBelow() != 0) addBlockBelowInfo(builder, to, "\nto");
|
||||
|
@ -496,7 +496,7 @@ public class MovingListener extends CheckListener implements TickListener, IRemo
|
||||
data.resetTeleported();
|
||||
// Debug.
|
||||
if (cc.debug) {
|
||||
DebugUtil.outputMoveDebug(player, pFrom, pTo, mcAccess);
|
||||
DebugUtil.outputMoveDebug(player, pFrom, pTo, Math.max(cc.noFallyOnGround, cc.yOnGround), mcAccess);
|
||||
}
|
||||
|
||||
// Check for illegal move and bounding box etc.
|
||||
@ -506,8 +506,9 @@ public class MovingListener extends CheckListener implements TickListener, IRemo
|
||||
parkedInfo.add(moveInfo);
|
||||
return;
|
||||
}
|
||||
pFrom.collectBlockFlags(cc.noFallyOnGround);
|
||||
pTo.collectBlockFlags(cc.noFallyOnGround);
|
||||
final double maxYNoFall = Math.max(cc.noFallyOnGround, cc.yOnGround);
|
||||
pFrom.collectBlockFlags(maxYNoFall);
|
||||
pTo.collectBlockFlags(maxYNoFall);
|
||||
|
||||
// Potion effect "Jump".
|
||||
final double jumpAmplifier = MovingListener.getJumpAmplifier(player);
|
||||
|
Loading…
Reference in New Issue
Block a user