Signed-off-by: yoyosource <yoyosource@nidido.de>
Dieser Commit ist enthalten in:
Ursprung
c7b21bfc74
Commit
eb352a36dd
@ -25,7 +25,6 @@ import de.steamwar.bausystem.configplayer.ConfigConverter;
|
|||||||
import de.steamwar.bausystem.features.gui.BauGUI;
|
import de.steamwar.bausystem.features.gui.BauGUI;
|
||||||
import de.steamwar.bausystem.features.script.ScriptExecutor;
|
import de.steamwar.bausystem.features.script.ScriptExecutor;
|
||||||
import de.steamwar.bausystem.features.script.SpecialCommand;
|
import de.steamwar.bausystem.features.script.SpecialCommand;
|
||||||
import de.steamwar.bausystem.features.slaves.panzern.Panzern;
|
|
||||||
import de.steamwar.bausystem.features.slaves.panzern.PanzernAlgorithm;
|
import de.steamwar.bausystem.features.slaves.panzern.PanzernAlgorithm;
|
||||||
import de.steamwar.bausystem.features.slaves.panzern.PanzernAlgorithmLazyInit;
|
import de.steamwar.bausystem.features.slaves.panzern.PanzernAlgorithmLazyInit;
|
||||||
import de.steamwar.bausystem.features.smartplace.SmartPlaceBehaviour;
|
import de.steamwar.bausystem.features.smartplace.SmartPlaceBehaviour;
|
||||||
@ -44,15 +43,13 @@ import java.util.function.Consumer;
|
|||||||
import java.util.function.Predicate;
|
import java.util.function.Predicate;
|
||||||
|
|
||||||
@RequiredArgsConstructor
|
@RequiredArgsConstructor
|
||||||
@AllArgsConstructor
|
|
||||||
@Getter
|
|
||||||
public enum LinkageType {
|
public enum LinkageType {
|
||||||
|
|
||||||
// NORMAL
|
// NORMAL
|
||||||
COMMAND(false, SWCommand.class::isAssignableFrom, o -> ((SWCommand) o).setMessage(BauSystem.MESSAGE)),
|
COMMAND(false, SWCommand.class::isAssignableFrom, o -> ((SWCommand) o).setMessage(BauSystem.MESSAGE)),
|
||||||
ENABLE_LINK(false, Enable.class::isAssignableFrom, o -> ((Enable) o).enable()),
|
ENABLE_LINK(false, Enable.class::isAssignableFrom, o -> ((Enable) o).enable()),
|
||||||
DISABLE_LINK(true, Disable.class::isAssignableFrom, o -> ((Disable) o).disable()),
|
DISABLE_LINK(true, Disable.class::isAssignableFrom, o -> ((Disable) o).disable()),
|
||||||
PLAIN(false, clazz -> true),
|
PLAIN(false, clazz -> true, o -> {}),
|
||||||
LISTENER(false, Listener.class::isAssignableFrom, o -> Bukkit.getPluginManager().registerEvents((Listener) o, BauSystem.getInstance())),
|
LISTENER(false, Listener.class::isAssignableFrom, o -> Bukkit.getPluginManager().registerEvents((Listener) o, BauSystem.getInstance())),
|
||||||
UNLINK_LISTENER(true, Listener.class::isAssignableFrom, o -> HandlerList.unregisterAll((Listener) o)),
|
UNLINK_LISTENER(true, Listener.class::isAssignableFrom, o -> HandlerList.unregisterAll((Listener) o)),
|
||||||
|
|
||||||
@ -64,11 +61,9 @@ public enum LinkageType {
|
|||||||
PANZERN(false, PanzernAlgorithm.class::isAssignableFrom, o -> PanzernAlgorithmLazyInit.add((PanzernAlgorithm) o)),
|
PANZERN(false, PanzernAlgorithm.class::isAssignableFrom, o -> PanzernAlgorithmLazyInit.add((PanzernAlgorithm) o)),
|
||||||
SMART_PLACE(false, SmartPlaceBehaviour.class::isAssignableFrom, o -> SmartPlaceListener.add((SmartPlaceBehaviour) o));
|
SMART_PLACE(false, SmartPlaceBehaviour.class::isAssignableFrom, o -> SmartPlaceListener.add((SmartPlaceBehaviour) o));
|
||||||
|
|
||||||
private final boolean unlink;
|
final boolean unlink;
|
||||||
|
|
||||||
private final Predicate<Class<?>> linkagePredicate;
|
final Predicate<Class<?>> linkagePredicate;
|
||||||
|
|
||||||
@SuppressWarnings("FieldMayBeFinal")
|
final Consumer<Object> linkageConsumer;
|
||||||
private Consumer<Object> linkageConsumer = o -> {
|
|
||||||
};
|
|
||||||
}
|
}
|
@ -101,7 +101,7 @@ public class LinkageUtils {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
List<LinkageType> linkageTypeList = Arrays.stream(linkages).map(Linked::value).filter(linkageType -> linkageType.isUnlink() == unlink).filter(linkageType -> linkageType.getLinkagePredicate().test(clazz)).collect(Collectors.toList());
|
List<LinkageType> linkageTypeList = Arrays.stream(linkages).map(Linked::value).filter(linkageType -> linkageType.unlink == unlink).filter(linkageType -> linkageType.linkagePredicate.test(clazz)).collect(Collectors.toList());
|
||||||
if (linkageTypeList.isEmpty()) {
|
if (linkageTypeList.isEmpty()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -111,10 +111,10 @@ public class LinkageUtils {
|
|||||||
if (object == null) {
|
if (object == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
linkageTypeList.forEach(linkageType -> linkageType.getLinkageConsumer().accept(object));
|
linkageTypeList.forEach(linkageType -> linkageType.linkageConsumer.accept(object));
|
||||||
} else {
|
} else {
|
||||||
Object object = objectMap.computeIfAbsent(clazz, LinkageUtils::constructInstance);
|
Object object = objectMap.computeIfAbsent(clazz, LinkageUtils::constructInstance);
|
||||||
linkageTypeList.forEach(linkageType -> linkageType.getLinkageConsumer().accept(object));
|
linkageTypeList.forEach(linkageType -> linkageType.linkageConsumer.accept(object));
|
||||||
|
|
||||||
for (Field field : clazz.getDeclaredFields()) {
|
for (Field field : clazz.getDeclaredFields()) {
|
||||||
LinkedInstance linkedInstance = field.getDeclaredAnnotation(LinkedInstance.class);
|
LinkedInstance linkedInstance = field.getDeclaredAnnotation(LinkedInstance.class);
|
||||||
|
In neuem Issue referenzieren
Einen Benutzer sperren