mirror of
https://github.com/NoCheatPlus/NoCheatPlus.git
synced 2025-01-04 23:07:44 +01:00
Remove workarounds listener (split to moving + combined).
This commit is contained in:
parent
298336bf6b
commit
f30bccd7d3
@ -21,7 +21,6 @@ import org.bukkit.plugin.PluginDescriptionFile;
|
|||||||
import org.bukkit.plugin.java.JavaPlugin;
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
|
||||||
import fr.neatmonster.nocheatplus.checks.CheckType;
|
import fr.neatmonster.nocheatplus.checks.CheckType;
|
||||||
import fr.neatmonster.nocheatplus.checks.Workarounds;
|
|
||||||
import fr.neatmonster.nocheatplus.checks.blockbreak.BlockBreakListener;
|
import fr.neatmonster.nocheatplus.checks.blockbreak.BlockBreakListener;
|
||||||
import fr.neatmonster.nocheatplus.checks.blockinteract.BlockInteractListener;
|
import fr.neatmonster.nocheatplus.checks.blockinteract.BlockInteractListener;
|
||||||
import fr.neatmonster.nocheatplus.checks.blockplace.BlockPlaceListener;
|
import fr.neatmonster.nocheatplus.checks.blockplace.BlockPlaceListener;
|
||||||
@ -247,7 +246,6 @@ public class NoCheatPlus extends JavaPlugin implements Listener {
|
|||||||
new FightListener(),
|
new FightListener(),
|
||||||
new InventoryListener(),
|
new InventoryListener(),
|
||||||
new MovingListener(),
|
new MovingListener(),
|
||||||
new Workarounds(),
|
|
||||||
new INotifyReload() {
|
new INotifyReload() {
|
||||||
@Override
|
@Override
|
||||||
public void onReload() {
|
public void onReload() {
|
||||||
|
@ -1,76 +0,0 @@
|
|||||||
package fr.neatmonster.nocheatplus.checks;
|
|
||||||
|
|
||||||
import org.bukkit.event.EventHandler;
|
|
||||||
import org.bukkit.event.EventPriority;
|
|
||||||
import org.bukkit.event.Listener;
|
|
||||||
import org.bukkit.event.player.PlayerMoveEvent;
|
|
||||||
import org.bukkit.event.player.PlayerToggleSprintEvent;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* M""MMM""MMM""M dP dP
|
|
||||||
* M MMM MMM M 88 88
|
|
||||||
* M MMP MMP M .d8888b. 88d888b. 88 .dP .d8888b. 88d888b. .d8888b. dP dP 88d888b. .d888b88 .d8888b.
|
|
||||||
* M MM' MM' .M 88' `88 88' `88 88888" 88' `88 88' `88 88' `88 88 88 88' `88 88' `88 Y8ooooo.
|
|
||||||
* M `' . '' .MM 88. .88 88 88 `8b. 88. .88 88 88. .88 88. .88 88 88 88. .88 88
|
|
||||||
* M .d .dMMM `88888P' dP dP `YP `88888P8 dP `88888P' `88888P' dP dP `88888P8 `88888P'
|
|
||||||
* MMMMMMMMMMMMMM
|
|
||||||
*/
|
|
||||||
/**
|
|
||||||
* Only place that listens to player-teleport related events and dispatches them to relevant checks.
|
|
||||||
*/
|
|
||||||
public class Workarounds implements Listener {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A listener listening to PlayerMoveEvents.
|
|
||||||
*
|
|
||||||
* @param event
|
|
||||||
* the event
|
|
||||||
*/
|
|
||||||
@EventHandler(
|
|
||||||
priority = EventPriority.HIGHEST)
|
|
||||||
public void onPlayerMove(final PlayerMoveEvent event) {
|
|
||||||
/*
|
|
||||||
* _____ _ __ __
|
|
||||||
* | __ \| | | \/ |
|
|
||||||
* | |__) | | __ _ _ _ ___ _ __ | \ / | _____ _____
|
|
||||||
* | ___/| |/ _` | | | |/ _ \ '__| | |\/| |/ _ \ \ / / _ \
|
|
||||||
* | | | | (_| | |_| | __/ | | | | | (_) \ V / __/
|
|
||||||
* |_| |_|\__,_|\__, |\___|_| |_| |_|\___/ \_/ \___|
|
|
||||||
* __/ |
|
|
||||||
* |___/
|
|
||||||
*/
|
|
||||||
// No typo here. I really only handle cancelled events and ignore others.
|
|
||||||
if (!event.isCancelled())
|
|
||||||
return;
|
|
||||||
|
|
||||||
// Fix a common mistake that other developers make (cancelling move events is crazy, rather set the target
|
|
||||||
// location to the from location).
|
|
||||||
event.setCancelled(false);
|
|
||||||
event.setTo(event.getFrom().clone());
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A listener listening to PlayerToggleSprintEvents.
|
|
||||||
*
|
|
||||||
* @param event
|
|
||||||
* the event
|
|
||||||
*/
|
|
||||||
@EventHandler(
|
|
||||||
priority = EventPriority.HIGHEST)
|
|
||||||
public void onPlayerToggleSprint(final PlayerToggleSprintEvent event) {
|
|
||||||
/*
|
|
||||||
* _____ _ _______ _ _____ _ _
|
|
||||||
* | __ \| | |__ __| | | / ____| (_) | |
|
|
||||||
* | |__) | | __ _ _ _ ___ _ __ | | ___ __ _ __ _| | ___ | (___ _ __ _ __ _ _ __ | |_
|
|
||||||
* | ___/| |/ _` | | | |/ _ \ '__| | |/ _ \ / _` |/ _` | |/ _ \ \___ \| '_ \| '__| | '_ \| __|
|
|
||||||
* | | | | (_| | |_| | __/ | | | (_) | (_| | (_| | | __/ ____) | |_) | | | | | | | |_
|
|
||||||
* |_| |_|\__,_|\__, |\___|_| |_|\___/ \__, |\__, |_|\___| |_____/| .__/|_| |_|_| |_|\__|
|
|
||||||
* __/ | __/ | __/ | | |
|
|
||||||
* |___/ |___/ |___/ |_|
|
|
||||||
*/
|
|
||||||
// Some plugins cancel "sprinting", which makes no sense at all because it doesn't stop people from sprinting
|
|
||||||
// and rewards them by reducing their hunger bar as if they were walking instead of sprinting.
|
|
||||||
if (event.isCancelled() && event.isSprinting())
|
|
||||||
event.setCancelled(false);
|
|
||||||
}
|
|
||||||
}
|
|
@ -100,4 +100,29 @@ public class CombinedListener implements Listener {
|
|||||||
event.setCancelled(true);
|
event.setCancelled(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A workaround for cancelled PlayerToggleSprintEvents.
|
||||||
|
*
|
||||||
|
* @param event
|
||||||
|
* the event
|
||||||
|
*/
|
||||||
|
@EventHandler(
|
||||||
|
priority = EventPriority.HIGHEST)
|
||||||
|
public void onPlayerToggleSprintHighest(final PlayerToggleSprintEvent event) {
|
||||||
|
/*
|
||||||
|
* _____ _ _______ _ _____ _ _
|
||||||
|
* | __ \| | |__ __| | | / ____| (_) | |
|
||||||
|
* | |__) | | __ _ _ _ ___ _ __ | | ___ __ _ __ _| | ___ | (___ _ __ _ __ _ _ __ | |_
|
||||||
|
* | ___/| |/ _` | | | |/ _ \ '__| | |/ _ \ / _` |/ _` | |/ _ \ \___ \| '_ \| '__| | '_ \| __|
|
||||||
|
* | | | | (_| | |_| | __/ | | | (_) | (_| | (_| | | __/ ____) | |_) | | | | | | | |_
|
||||||
|
* |_| |_|\__,_|\__, |\___|_| |_|\___/ \__, |\__, |_|\___| |_____/| .__/|_| |_|_| |_|\__|
|
||||||
|
* __/ | __/ | __/ | | |
|
||||||
|
* |___/ |___/ |___/ |_|
|
||||||
|
*/
|
||||||
|
// Some plugins cancel "sprinting", which makes no sense at all because it doesn't stop people from sprinting
|
||||||
|
// and rewards them by reducing their hunger bar as if they were walking instead of sprinting.
|
||||||
|
if (event.isCancelled() && event.isSprinting())
|
||||||
|
event.setCancelled(false);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -418,6 +418,35 @@ public class MovingListener implements Listener {
|
|||||||
parkedInfo.add(moveInfo);
|
parkedInfo.add(moveInfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A workaround for cancelled PlayerMoveEvents.
|
||||||
|
*
|
||||||
|
* @param event
|
||||||
|
* the event
|
||||||
|
*/
|
||||||
|
@EventHandler(
|
||||||
|
priority = EventPriority.HIGHEST)
|
||||||
|
public void onPlayerMoveHighest(final PlayerMoveEvent event) {
|
||||||
|
/*
|
||||||
|
* _____ _ __ __
|
||||||
|
* | __ \| | | \/ |
|
||||||
|
* | |__) | | __ _ _ _ ___ _ __ | \ / | _____ _____
|
||||||
|
* | ___/| |/ _` | | | |/ _ \ '__| | |\/| |/ _ \ \ / / _ \
|
||||||
|
* | | | | (_| | |_| | __/ | | | | | (_) \ V / __/
|
||||||
|
* |_| |_|\__,_|\__, |\___|_| |_| |_|\___/ \_/ \___|
|
||||||
|
* __/ |
|
||||||
|
* |___/
|
||||||
|
*/
|
||||||
|
// No typo here. I really only handle cancelled events and ignore others.
|
||||||
|
if (!event.isCancelled())
|
||||||
|
return;
|
||||||
|
|
||||||
|
// Fix a common mistake that other developers make (cancelling move events is crazy, rather set the target
|
||||||
|
// location to the from location).
|
||||||
|
event.setCancelled(false);
|
||||||
|
event.setTo(event.getFrom().clone());
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* When a player uses a portal, all information related to the moving checks becomes invalid.
|
* When a player uses a portal, all information related to the moving checks becomes invalid.
|
||||||
*
|
*
|
||||||
|
Loading…
Reference in New Issue
Block a user