mirror of
https://github.com/NoCheatPlus/NoCheatPlus.git
synced 2025-01-04 23:07:44 +01:00
Bleeding: Add interfaces IFirst and ILast for hooks ordering.
This commit is contained in:
parent
a3eb7f576d
commit
5f589e78e9
10
src/fr/neatmonster/nocheatplus/hooks/IFirst.java
Normal file
10
src/fr/neatmonster/nocheatplus/hooks/IFirst.java
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
package fr.neatmonster.nocheatplus.hooks;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicate that an object is intended to be sorted in first.
|
||||||
|
* @author mc_dev
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public interface IFirst {
|
||||||
|
|
||||||
|
}
|
10
src/fr/neatmonster/nocheatplus/hooks/ILast.java
Normal file
10
src/fr/neatmonster/nocheatplus/hooks/ILast.java
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
package fr.neatmonster.nocheatplus.hooks;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicate that an object is intended to be sorted in last.
|
||||||
|
* @author mc_dev
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public interface ILast {
|
||||||
|
|
||||||
|
}
|
@ -2,7 +2,8 @@ package fr.neatmonster.nocheatplus.hooks;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Interface to indicate an object is just used to collect stats,
|
* Interface to indicate an object is just used to collect stats,
|
||||||
* it will get the violations first and can not cancel vl-processing.
|
* it can not cancel vl-processing. If ILast is implemented as well,
|
||||||
|
* this will be sorted after hooks that can cancel, otherwise before those.
|
||||||
* @author mc_dev
|
* @author mc_dev
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
@ -3,6 +3,7 @@ package fr.neatmonster.nocheatplus.hooks;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
|
import java.util.Comparator;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.LinkedHashSet;
|
import java.util.LinkedHashSet;
|
||||||
import java.util.LinkedList;
|
import java.util.LinkedList;
|
||||||
@ -50,6 +51,25 @@ public final class NCPHookManager {
|
|||||||
/** Mapping the check types to the hooks. */
|
/** Mapping the check types to the hooks. */
|
||||||
private static final Map<CheckType, List<NCPHook>> hooksByChecks = new HashMap<CheckType, List<NCPHook>>();
|
private static final Map<CheckType, List<NCPHook>> hooksByChecks = new HashMap<CheckType, List<NCPHook>>();
|
||||||
|
|
||||||
|
private static Comparator<NCPHook> HookComparator = new Comparator<NCPHook>() {
|
||||||
|
@Override
|
||||||
|
public int compare(final NCPHook o1, final NCPHook o2) {
|
||||||
|
final boolean s1 = o1 instanceof IStats;
|
||||||
|
final boolean f1 = o1 instanceof IFirst;
|
||||||
|
final boolean l1 = o1 instanceof ILast;
|
||||||
|
final boolean s2 = o2 instanceof IStats;
|
||||||
|
final boolean f2 = o2 instanceof IFirst;
|
||||||
|
final boolean l2 = o2 instanceof ILast;
|
||||||
|
if (s1 && !s2) return l1 ? 1 : -1;
|
||||||
|
else if (!s1 && s2) return l2 ? -1 : 1;
|
||||||
|
else if (l2) return -1;
|
||||||
|
else if (l1) return 1;
|
||||||
|
else if (f1) return -1;
|
||||||
|
else if (f2) return 1;
|
||||||
|
else return 0;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
static{
|
static{
|
||||||
// Fill the map to be sure that thread safety can be guaranteed.
|
// Fill the map to be sure that thread safety can be guaranteed.
|
||||||
for (final CheckType type : CheckType.values()){
|
for (final CheckType type : CheckType.values()){
|
||||||
@ -105,8 +125,9 @@ public final class NCPHookManager {
|
|||||||
private static void addToMapping(final CheckType checkType, final NCPHook hook) {
|
private static void addToMapping(final CheckType checkType, final NCPHook hook) {
|
||||||
final List<NCPHook> hooks = hooksByChecks.get(checkType);
|
final List<NCPHook> hooks = hooksByChecks.get(checkType);
|
||||||
if (!hooks.contains(hook)){
|
if (!hooks.contains(hook)){
|
||||||
if (hook instanceof IStats) hooks.add(0, hook);
|
if (!(hook instanceof ILast) && (hook instanceof IStats || hook instanceof IFirst)) hooks.add(0, hook);
|
||||||
else hooks.add(hook);
|
else hooks.add(hook);
|
||||||
|
Collections.sort(hooks, HookComparator);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user