Fix issue with replacing broken blocks.

This commit is contained in:
asofold 2012-09-12 20:28:36 +02:00
parent c1195c630a
commit 19ca256c30
7 changed files with 33 additions and 29 deletions

View File

@ -75,34 +75,48 @@ public class BlockBreakListener implements Listener {
// Do the actual checks, if still needed. It's a good idea to make computationally cheap checks first, because // Do the actual checks, if still needed. It's a good idea to make computationally cheap checks first, because
// it may save us from doing the computationally expensive checks. // it may save us from doing the computationally expensive checks.
final BlockBreakConfig cc = BlockBreakConfig.getConfig(player);
final BlockBreakData data = BlockBreakData.getData(player);
final long now = System.currentTimeMillis();
// Has the player broken a block that was not damaged before? // Has the player broken a block that was not damaged before?
if (wrongBlock.isEnabled(player) && wrongBlock.check(player, block)) if (wrongBlock.isEnabled(player) && wrongBlock.check(player, block, cc, data))
cancelled = true; cancelled = true;
// Has the player broken more blocks per second than allowed? // Has the player broken more blocks per second than allowed?
if (!cancelled && frequency.isEnabled(player) && frequency.check(player)) if (!cancelled && frequency.isEnabled(player) && frequency.check(player, cc, data))
cancelled = true; cancelled = true;
// Has the player broken blocks faster than possible? // Has the player broken blocks faster than possible?
if (!cancelled && fastBreak.isEnabled(player) && fastBreak.check(player, block)) if (!cancelled && fastBreak.isEnabled(player) && fastBreak.check(player, block, cc, data))
cancelled = true; cancelled = true;
// Did the arm of the player move before breaking this block? // Did the arm of the player move before breaking this block?
if (!cancelled && noSwing.isEnabled(player) && noSwing.check(player)) if (!cancelled && noSwing.isEnabled(player) && noSwing.check(player, data))
cancelled = true; cancelled = true;
// Is the block really in reach distance? // Is the block really in reach distance?
if (!cancelled && reach.isEnabled(player) && reach.check(player, block.getLocation())) if (!cancelled && reach.isEnabled(player) && reach.check(player, block.getLocation(), data))
cancelled = true; cancelled = true;
// Did the player look at the block at all? // Did the player look at the block at all?
if (!cancelled && direction.isEnabled(player) && direction.check(player, block.getLocation())) if (!cancelled && direction.isEnabled(player) && direction.check(player, block.getLocation(), data))
cancelled = true; cancelled = true;
// At least one check failed and demanded to cancel the event. // At least one check failed and demanded to cancel the event.
if (cancelled) if (cancelled){
event.setCancelled(cancelled); event.setCancelled(cancelled);
// Reset damage position:
data.fastBreakDamageTime = now;
data.clickedX = block.getX();
data.clickedY = block.getY();
data.clickedZ = block.getZ();
}
else{
// Invalidate last damage position:
data.clickedX = Integer.MAX_VALUE;
}
} }

View File

@ -38,8 +38,7 @@ public class Direction extends Check {
* the location * the location
* @return true, if successful * @return true, if successful
*/ */
public boolean check(final Player player, final Location location) { public boolean check(final Player player, final Location location, final BlockBreakData data) {
final BlockBreakData data = BlockBreakData.getData(player);
boolean cancel = false; boolean cancel = false;

View File

@ -38,13 +38,13 @@ public class FastBreak extends Check {
* the player * the player
* @param block * @param block
* the block * the block
* @param data
* @param cc
* @param elaspedTime * @param elaspedTime
* @return true, if successful * @return true, if successful
*/ */
public boolean check(final Player player, final Block block) { public boolean check(final Player player, final Block block, final BlockBreakConfig cc, final BlockBreakData data) {
final long now = System.currentTimeMillis(); final long now = System.currentTimeMillis();
final BlockBreakConfig cc = BlockBreakConfig.getConfig(player);
final BlockBreakData data = BlockBreakData.getData(player);
boolean cancel = false; boolean cancel = false;

View File

@ -17,9 +17,7 @@ public class Frequency extends Check {
super(CheckType.BLOCKBREAK_FREQUENCY); super(CheckType.BLOCKBREAK_FREQUENCY);
} }
public boolean check(final Player player){ public boolean check(final Player player, final BlockBreakConfig cc, final BlockBreakData data){
final BlockBreakConfig cc = BlockBreakConfig.getConfig(player);
final BlockBreakData data = BlockBreakData.getData(player);
final float interval = (float) ((player.getGameMode() == GameMode.CREATIVE)?(cc.frequencyIntervalCreative):(cc.frequencyIntervalSurvival)); final float interval = (float) ((player.getGameMode() == GameMode.CREATIVE)?(cc.frequencyIntervalCreative):(cc.frequencyIntervalSurvival));
data.frequencyBuckets.add(System.currentTimeMillis(), interval); data.frequencyBuckets.add(System.currentTimeMillis(), interval);

View File

@ -34,8 +34,7 @@ public class NoSwing extends Check {
* the player * the player
* @return true, if successful * @return true, if successful
*/ */
public boolean check(final Player player) { public boolean check(final Player player, final BlockBreakData data) {
final BlockBreakData data = BlockBreakData.getData(player);
boolean cancel = false; boolean cancel = false;

View File

@ -47,8 +47,7 @@ public class Reach extends Check {
* the location * the location
* @return true, if successful * @return true, if successful
*/ */
public boolean check(final Player player, final Location location) { public boolean check(final Player player, final Location location, final BlockBreakData data) {
final BlockBreakData data = BlockBreakData.getData(player);
boolean cancel = false; boolean cancel = false;

View File

@ -19,11 +19,11 @@ public class WrongBlock extends Check {
* probably due to packet delaying issues for insta breaking. very effective against some nuker techniques. * probably due to packet delaying issues for insta breaking. very effective against some nuker techniques.
* @param player * @param player
* @param block * @param block
* @param data
* @param cc
* @return * @return
*/ */
public boolean check(final Player player, final Block block){ public boolean check(final Player player, final Block block, final BlockBreakConfig cc, final BlockBreakData data){
final BlockBreakConfig cc = BlockBreakConfig.getConfig(player);
final BlockBreakData data = BlockBreakData.getData(player);
boolean cancel = false; boolean cancel = false;
if (data.clickedX != block.getX() || data.clickedZ != block.getZ() || data.clickedY != block.getY()){ if (data.clickedX != block.getX() || data.clickedZ != block.getZ() || data.clickedY != block.getY()){
@ -33,11 +33,6 @@ public class WrongBlock extends Check {
cancel = true; cancel = true;
if (Improbable.check(player, 5.0f, now)) if (Improbable.check(player, 5.0f, now))
cancel = true; cancel = true;
// Reset, to prevent endless violation level farming.
data.fastBreakDamageTime = now;
data.clickedX = block.getX();
data.clickedY = block.getY();
data.clickedZ = block.getZ();
} }
return cancel; return cancel;