forked from SteamWar/SteamWar
Implement Linkage for TowerRun
This commit is contained in:
@@ -27,6 +27,7 @@ import lombok.experimental.StandardException;
|
|||||||
import java.io.BufferedReader;
|
import java.io.BufferedReader;
|
||||||
import java.io.InputStreamReader;
|
import java.io.InputStreamReader;
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
|
import java.lang.reflect.Modifier;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
@@ -100,9 +101,12 @@ public abstract class AbstractLinker<T> {
|
|||||||
instances.forEach((clazz, o) -> {
|
instances.forEach((clazz, o) -> {
|
||||||
for (Field field : clazz.getFields()) {
|
for (Field field : clazz.getFields()) {
|
||||||
if (field.getAnnotation(LinkedInstance.class) != null) {
|
if (field.getAnnotation(LinkedInstance.class) != null) {
|
||||||
System.out.println("Setting " + field.getName() + " to " + instances.get(field.getType()));
|
|
||||||
try {
|
try {
|
||||||
field.set(o, instances.get(field.getType()));
|
if (Modifier.isStatic(field.getModifiers())) {
|
||||||
|
field.set(null, instances.get(field.getType()));
|
||||||
|
} else {
|
||||||
|
field.set(o, instances.get(field.getType()));
|
||||||
|
}
|
||||||
} catch (IllegalAccessException e) {
|
} catch (IllegalAccessException e) {
|
||||||
throw new SecurityException(e.getMessage(), e);
|
throw new SecurityException(e.getMessage(), e);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -29,6 +29,8 @@ java {
|
|||||||
dependencies {
|
dependencies {
|
||||||
annotationProcessor(libs.spigotannotations)
|
annotationProcessor(libs.spigotannotations)
|
||||||
compileOnly(libs.spigotannotations)
|
compileOnly(libs.spigotannotations)
|
||||||
|
compileOnly(libs.classindex)
|
||||||
|
annotationProcessor(libs.classindex)
|
||||||
|
|
||||||
compileOnly(project(":SpigotCore", "default"))
|
compileOnly(project(":SpigotCore", "default"))
|
||||||
|
|
||||||
|
|||||||
@@ -19,18 +19,14 @@
|
|||||||
|
|
||||||
package de.steamwar.towerrun;
|
package de.steamwar.towerrun;
|
||||||
|
|
||||||
|
import de.steamwar.command.SWCommand;
|
||||||
|
import de.steamwar.linkage.AbstractLinker;
|
||||||
|
import de.steamwar.linkage.LinkedInstance;
|
||||||
|
import de.steamwar.linkage.SpigotLinker;
|
||||||
import de.steamwar.message.Message;
|
import de.steamwar.message.Message;
|
||||||
import de.steamwar.towerrun.commands.StartCommand;
|
|
||||||
import de.steamwar.towerrun.config.WorldConfig;
|
import de.steamwar.towerrun.config.WorldConfig;
|
||||||
import de.steamwar.towerrun.countdowns.EndCountdown;
|
|
||||||
import de.steamwar.towerrun.countdowns.GameCountdown;
|
import de.steamwar.towerrun.countdowns.GameCountdown;
|
||||||
import de.steamwar.towerrun.countdowns.LobbyCountdown;
|
|
||||||
import de.steamwar.towerrun.game.TowerRunGame;
|
|
||||||
import de.steamwar.towerrun.generator.TowerGenerator;
|
import de.steamwar.towerrun.generator.TowerGenerator;
|
||||||
import de.steamwar.towerrun.listener.GlobalListener;
|
|
||||||
import de.steamwar.towerrun.listener.IngameListener;
|
|
||||||
import de.steamwar.towerrun.listener.LobbyListener;
|
|
||||||
import de.steamwar.towerrun.listener.NotLobbyListener;
|
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.plugin.java.JavaPlugin;
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
@@ -58,6 +54,7 @@ public class TowerRun extends JavaPlugin {
|
|||||||
private static TowerGenerator towerGenerator = null;
|
private static TowerGenerator towerGenerator = null;
|
||||||
|
|
||||||
@Getter
|
@Getter
|
||||||
|
@LinkedInstance
|
||||||
private static GameCountdown gameCountdown;
|
private static GameCountdown gameCountdown;
|
||||||
|
|
||||||
|
|
||||||
@@ -70,14 +67,21 @@ public class TowerRun extends JavaPlugin {
|
|||||||
towerGenerator = new TowerGenerator(WorldConfig.TOWER_GENERATOR_CONFIG);
|
towerGenerator = new TowerGenerator(WorldConfig.TOWER_GENERATOR_CONFIG);
|
||||||
}
|
}
|
||||||
|
|
||||||
new LobbyListener();
|
SpigotLinker spigotLinker = new SpigotLinker(this, message) {
|
||||||
new IngameListener();
|
@Override
|
||||||
new GlobalListener();
|
protected void linkObject(Object any) {
|
||||||
new NotLobbyListener();
|
if (any instanceof SWCommand) {
|
||||||
final LobbyCountdown lobbyCountdown = new LobbyCountdown();
|
((SWCommand) any).setMessage(message);
|
||||||
new EndCountdown(lobbyCountdown);
|
}
|
||||||
new StartCommand(lobbyCountdown);
|
}
|
||||||
gameCountdown = new GameCountdown();
|
};
|
||||||
|
try {
|
||||||
|
spigotLinker.link();
|
||||||
|
} catch (AbstractLinker.LinkException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
Bukkit.shutdown();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
Bukkit.getScheduler().runTaskTimer(this, new FightInfoPacketSender(), 20, 20);
|
Bukkit.getScheduler().runTaskTimer(this, new FightInfoPacketSender(), 20, 20);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -21,18 +21,19 @@ package de.steamwar.towerrun.commands;
|
|||||||
|
|
||||||
import de.steamwar.command.SWCommand;
|
import de.steamwar.command.SWCommand;
|
||||||
import de.steamwar.command.TypeValidator;
|
import de.steamwar.command.TypeValidator;
|
||||||
|
import de.steamwar.linkage.Linked;
|
||||||
import de.steamwar.sql.SteamwarUser;
|
import de.steamwar.sql.SteamwarUser;
|
||||||
import de.steamwar.sql.UserPerm;
|
import de.steamwar.sql.UserPerm;
|
||||||
import de.steamwar.towerrun.TowerRun;
|
import de.steamwar.towerrun.TowerRun;
|
||||||
import de.steamwar.towerrun.countdowns.LobbyCountdown;
|
import de.steamwar.towerrun.countdowns.LobbyCountdown;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
@Linked
|
||||||
public class StartCommand extends SWCommand {
|
public class StartCommand extends SWCommand {
|
||||||
private final LobbyCountdown countdown;
|
private LobbyCountdown countdown;
|
||||||
|
|
||||||
public StartCommand(LobbyCountdown countdown) {
|
public StartCommand() {
|
||||||
super("start", "skip");
|
super("start", "skip");
|
||||||
this.countdown = countdown;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Register
|
@Register
|
||||||
|
|||||||
@@ -19,6 +19,8 @@
|
|||||||
|
|
||||||
package de.steamwar.towerrun.countdowns;
|
package de.steamwar.towerrun.countdowns;
|
||||||
|
|
||||||
|
import de.steamwar.linkage.Linked;
|
||||||
|
import de.steamwar.linkage.LinkedInstance;
|
||||||
import de.steamwar.towerrun.TowerRun;
|
import de.steamwar.towerrun.TowerRun;
|
||||||
import de.steamwar.towerrun.config.Config;
|
import de.steamwar.towerrun.config.Config;
|
||||||
import de.steamwar.towerrun.game.TowerRunGame;
|
import de.steamwar.towerrun.game.TowerRunGame;
|
||||||
@@ -29,15 +31,16 @@ import org.bukkit.Sound;
|
|||||||
import java.util.EnumSet;
|
import java.util.EnumSet;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
|
@Linked
|
||||||
public class EndCountdown extends Countdown {
|
public class EndCountdown extends Countdown {
|
||||||
|
|
||||||
private final LobbyCountdown lobbyCountdown;
|
@LinkedInstance
|
||||||
|
private LobbyCountdown lobbyCountdown;
|
||||||
|
|
||||||
private static final boolean RESETS = Objects.requireNonNull(Bukkit.getWorlds().get(0).getWorldFolder().list((dir, name) -> name.equals("backup"))).length > 0;
|
private static final boolean RESETS = Objects.requireNonNull(Bukkit.getWorlds().get(0).getWorldFolder().list((dir, name) -> name.equals("backup"))).length > 0;
|
||||||
|
|
||||||
public EndCountdown(LobbyCountdown lobbyCountdown) {
|
public EndCountdown() {
|
||||||
super(EnumSet.of(GameStates.END));
|
super(EnumSet.of(GameStates.END));
|
||||||
this.lobbyCountdown = lobbyCountdown;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -19,6 +19,7 @@
|
|||||||
|
|
||||||
package de.steamwar.towerrun.countdowns;
|
package de.steamwar.towerrun.countdowns;
|
||||||
|
|
||||||
|
import de.steamwar.linkage.Linked;
|
||||||
import de.steamwar.towerrun.TowerRun;
|
import de.steamwar.towerrun.TowerRun;
|
||||||
import de.steamwar.towerrun.config.Config;
|
import de.steamwar.towerrun.config.Config;
|
||||||
import de.steamwar.towerrun.game.TowerRunGame;
|
import de.steamwar.towerrun.game.TowerRunGame;
|
||||||
@@ -26,6 +27,7 @@ import de.steamwar.towerrun.state.GameStates;
|
|||||||
|
|
||||||
import java.util.EnumSet;
|
import java.util.EnumSet;
|
||||||
|
|
||||||
|
@Linked
|
||||||
public class GameCountdown extends Countdown {
|
public class GameCountdown extends Countdown {
|
||||||
|
|
||||||
private long startTime = 0;
|
private long startTime = 0;
|
||||||
|
|||||||
@@ -19,6 +19,7 @@
|
|||||||
|
|
||||||
package de.steamwar.towerrun.countdowns;
|
package de.steamwar.towerrun.countdowns;
|
||||||
|
|
||||||
|
import de.steamwar.linkage.Linked;
|
||||||
import de.steamwar.towerrun.TowerRun;
|
import de.steamwar.towerrun.TowerRun;
|
||||||
import de.steamwar.towerrun.config.Config;
|
import de.steamwar.towerrun.config.Config;
|
||||||
import de.steamwar.towerrun.game.TowerRunGame;
|
import de.steamwar.towerrun.game.TowerRunGame;
|
||||||
@@ -31,6 +32,7 @@ import org.bukkit.Sound;
|
|||||||
import java.util.EnumSet;
|
import java.util.EnumSet;
|
||||||
|
|
||||||
@Getter
|
@Getter
|
||||||
|
@Linked
|
||||||
public class LobbyCountdown extends Countdown {
|
public class LobbyCountdown extends Countdown {
|
||||||
|
|
||||||
@Setter
|
@Setter
|
||||||
|
|||||||
@@ -19,6 +19,7 @@
|
|||||||
|
|
||||||
package de.steamwar.towerrun.listener;
|
package de.steamwar.towerrun.listener;
|
||||||
|
|
||||||
|
import de.steamwar.linkage.Linked;
|
||||||
import de.steamwar.towerrun.TowerRun;
|
import de.steamwar.towerrun.TowerRun;
|
||||||
import de.steamwar.towerrun.config.WorldConfig;
|
import de.steamwar.towerrun.config.WorldConfig;
|
||||||
import de.steamwar.towerrun.game.TowerRunGame;
|
import de.steamwar.towerrun.game.TowerRunGame;
|
||||||
@@ -36,6 +37,7 @@ import org.bukkit.event.player.*;
|
|||||||
|
|
||||||
import java.util.EnumSet;
|
import java.util.EnumSet;
|
||||||
|
|
||||||
|
@Linked
|
||||||
public class GlobalListener extends GameStateBukkitListener implements Listener {
|
public class GlobalListener extends GameStateBukkitListener implements Listener {
|
||||||
public GlobalListener() {
|
public GlobalListener() {
|
||||||
super(EnumSet.allOf(GameStates.class));
|
super(EnumSet.allOf(GameStates.class));
|
||||||
|
|||||||
@@ -20,6 +20,7 @@
|
|||||||
package de.steamwar.towerrun.listener;
|
package de.steamwar.towerrun.listener;
|
||||||
|
|
||||||
import de.steamwar.inventory.SWItem;
|
import de.steamwar.inventory.SWItem;
|
||||||
|
import de.steamwar.linkage.Linked;
|
||||||
import de.steamwar.towerrun.TowerRun;
|
import de.steamwar.towerrun.TowerRun;
|
||||||
import de.steamwar.towerrun.config.Config;
|
import de.steamwar.towerrun.config.Config;
|
||||||
import de.steamwar.towerrun.config.WorldConfig;
|
import de.steamwar.towerrun.config.WorldConfig;
|
||||||
@@ -47,6 +48,7 @@ import java.util.*;
|
|||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
import java.util.stream.Stream;
|
import java.util.stream.Stream;
|
||||||
|
|
||||||
|
@Linked
|
||||||
public class IngameListener extends GameStateBukkitListener {
|
public class IngameListener extends GameStateBukkitListener {
|
||||||
|
|
||||||
private int time = 0;
|
private int time = 0;
|
||||||
|
|||||||
@@ -19,6 +19,7 @@
|
|||||||
|
|
||||||
package de.steamwar.towerrun.listener;
|
package de.steamwar.towerrun.listener;
|
||||||
|
|
||||||
|
import de.steamwar.linkage.Linked;
|
||||||
import de.steamwar.sql.SteamwarUser;
|
import de.steamwar.sql.SteamwarUser;
|
||||||
import de.steamwar.towerrun.TowerRun;
|
import de.steamwar.towerrun.TowerRun;
|
||||||
import de.steamwar.towerrun.config.Config;
|
import de.steamwar.towerrun.config.Config;
|
||||||
@@ -40,6 +41,7 @@ import org.bukkit.event.player.PlayerMoveEvent;
|
|||||||
import java.util.EnumSet;
|
import java.util.EnumSet;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
|
||||||
|
@Linked
|
||||||
public class LobbyListener extends GameStateBukkitListener {
|
public class LobbyListener extends GameStateBukkitListener {
|
||||||
public LobbyListener() {
|
public LobbyListener() {
|
||||||
super(EnumSet.of(GameStates.WAITING));
|
super(EnumSet.of(GameStates.WAITING));
|
||||||
|
|||||||
@@ -19,6 +19,7 @@
|
|||||||
|
|
||||||
package de.steamwar.towerrun.listener;
|
package de.steamwar.towerrun.listener;
|
||||||
|
|
||||||
|
import de.steamwar.linkage.Linked;
|
||||||
import de.steamwar.towerrun.TowerRun;
|
import de.steamwar.towerrun.TowerRun;
|
||||||
import de.steamwar.towerrun.config.WorldConfig;
|
import de.steamwar.towerrun.config.WorldConfig;
|
||||||
import de.steamwar.towerrun.state.GameStateBukkitListener;
|
import de.steamwar.towerrun.state.GameStateBukkitListener;
|
||||||
@@ -29,6 +30,7 @@ import org.bukkit.event.player.PlayerJoinEvent;
|
|||||||
|
|
||||||
import java.util.EnumSet;
|
import java.util.EnumSet;
|
||||||
|
|
||||||
|
@Linked
|
||||||
public class NotLobbyListener extends GameStateBukkitListener {
|
public class NotLobbyListener extends GameStateBukkitListener {
|
||||||
public NotLobbyListener() {
|
public NotLobbyListener() {
|
||||||
super(EnumSet.complementOf(EnumSet.of(GameStates.WAITING)));
|
super(EnumSet.complementOf(EnumSet.of(GameStates.WAITING)));
|
||||||
|
|||||||
Reference in New Issue
Block a user