use of com.gmail.stefvanschiedev.buildinggame.utils.TopStatHologram in project buildinggame by stefvanschie.
the class Main method loadPlugin.
/**
* Loads the entire plugin
*
* @since 2.1.0
*/
public void loadPlugin(boolean reload) {
long start = System.currentTimeMillis();
// this has to be done quite early
if (!reload) {
Gui.registerProperty("particle-type", Particle::valueOf);
Gui.registerProperty("biome", Biome::valueOf);
Gui.registerProperty("dye-color", DyeColor::valueOf);
Gui.registerProperty("material", Material::valueOf);
}
getLogger().info("Loading files");
SettingsManager.getInstance().setup(this, false);
getLogger().info("Loading arenas");
ArenaManager.getInstance().setup();
ArenaModeManager.getInstance().setup();
BuildTimerManager.getInstance().setup();
LobbyManager.getInstance().setup();
LobbyTimerManager.getInstance().setup();
MinPlayersManager.getInstance().setup();
MatchesManager.getInstance().setup();
VoteTimerManager.getInstance().setup();
WinTimerManager.getInstance().setup();
getLogger().info("Loading plots");
PlotManager.getInstance().setup();
// has to be down here for some config stuff
MaxPlayersManager.getInstance().setup();
LocationManager.getInstance().setup();
BoundaryManager.getInstance().setup();
FloorManager.getInstance().setup();
getLogger().info("Loading main spawn");
MainSpawnManager.getInstance().setup();
PluginManager pm = Bukkit.getPluginManager();
getLogger().info("Loading soft dependencies");
if (pm.isPluginEnabled("Vault"))
SDVault.getInstance().setup();
if (pm.isPluginEnabled("PlaceholderAPI")) {
try {
String version = pm.getPlugin("PlaceholderAPI").getDescription().getVersion();
var number = Integer.parseInt(version.replace(".", ""));
// This ensures the versions don't get mixed up (e.g. 2.7.5 being bigger than 2.9).
for (var i = version.split("\\.").length; i < 3; i++) number *= 10;
// 290 is the first version with offline player support
if (number >= 290) {
if (!new PlaceholderAPIPlaceholders().register())
getLogger().warning("Unable to register placeholders for PlaceholderAPI");
} else
getLogger().warning("PlaceholderAPI is outdated, update to a later version to keep BuildingGame compatible with PlaceholderAPI.");
} catch (NumberFormatException e) {
getLogger().warning("Unable to get PlaceholderAPI version, contact the plugin author about this.");
e.printStackTrace();
}
}
if (pm.isPluginEnabled("MVdWPlaceholderAPI")) {
PlaceholderSupplier.getPlaceholderReplacements().forEach((placeholder, biFunction) -> PlaceholderAPI.registerPlaceholder(this, placeholder, event -> biFunction.apply(event.getOfflinePlayer(), event.getPlaceholder())));
}
getLogger().info("Loading commands");
if (!reload) {
var manager = new BukkitCommandManager(this);
// noinspection deprecation
manager.enableUnstableAPI("help");
// register contexts
manager.getCommandContexts().registerContext(Arena.class, context -> {
var arena = ArenaManager.getInstance().getArena(context.popFirstArg());
if (arena == null)
throw new InvalidCommandArgument("This arena doesn't exist");
return arena;
});
manager.getCommandContexts().registerContext(ArenaMode.class, context -> {
var mode = ArenaMode.valueOf(context.popFirstArg().toUpperCase(Locale.getDefault()));
if (mode == null)
throw new InvalidCommandArgument("This game mode doesn't exist");
return mode;
});
manager.getCommandContexts().registerContext(StatType.class, context -> {
var type = StatType.valueOf(context.popFirstArg().toUpperCase(Locale.getDefault()));
if (type == null)
throw new InvalidCommandArgument("This statistic type doesn't exist");
return type;
});
// register completions
manager.getCommandCompletions().registerCompletion("arenas", context -> ArenaManager.getInstance().getArenas().stream().map(Arena::getName).collect(Collectors.toList()));
manager.getCommandCompletions().registerCompletion("arenamodes", context -> Stream.of(ArenaMode.values()).map(mode -> mode.toString().toUpperCase(Locale.getDefault())).collect(Collectors.toList()));
manager.getCommandCompletions().registerCompletion("stattypes", context -> Stream.of(StatType.values()).map(Enum::toString).collect(Collectors.toList()));
manager.getCommandCompletions().registerCompletion("holograms", context -> TopStatHologram.getHolograms().stream().map(TopStatHologram::getName).collect(Collectors.toList()));
// register conditions
manager.getCommandConditions().addCondition(String.class, "arenanotexist", (context, executionContext, string) -> {
if (ArenaManager.getInstance().getArena(string) != null || string.equals("main-spawn"))
throw new ConditionFailedException("Arena already exists");
});
// hd stands for Holographic Displays, but it's shorten to hd since the full name is a bit long
manager.getCommandConditions().addCondition("hdenabled", context -> pm.isPluginEnabled("HolographicDisplays"));
manager.registerCommand(new CommandManager());
}
getLogger().info("Loading stats");
StatManager.getInstance().setup();
// loading achievements should happen after the statistics have been loaded
Achievement.loadAchievements();
getLogger().info("Loading listeners");
if (!reload) {
pm.registerEvents(new BlockDispenseItem(), this);
pm.registerEvents(new BlockEdit(), this);
pm.registerEvents(new JoinSignCreate(), this);
pm.registerEvents(new LeaveSignCreate(), this);
pm.registerEvents(new StatSignCreate(), this);
pm.registerEvents(new UpdateLoadedSigns(), this);
pm.registerEvents(new SpectateSignCreate(), this);
pm.registerEvents(new SignBreak(), this);
pm.registerEvents(new LiquidFlow(), this);
pm.registerEvents(new PistonBlockMove(), this);
// starts the connection to bungeecord
if (SettingsManager.getInstance().getConfig().getBoolean("bungeecord.enable"))
BungeeCordHandler.getInstance();
// per world inventory compatibility fix
if (pm.isPluginEnabled("PerWorldInventory")) {
try {
String version = pm.getPlugin("PerWorldInventory").getDescription().getVersion();
var number = Integer.parseInt(version.replace(".", ""));
// This ensures the versions don't get mixed up (e.g. 1.7.5 being bigger than 1.11).
for (var i = version.split("\\.").length; i < 3; i++) number *= 10;
// 200 is the first version with the new package name
if (number >= 200)
pm.registerEvents(new PerWorldInventoryCancel(), this);
else
getLogger().warning("PerWorldInventory is outdated, update to a later version to keep BuildingGame compatible with PerWorldInventory.");
} catch (NumberFormatException e) {
getLogger().warning("Unable to get PerWorldInventory version, contact the plugin author about this.");
e.printStackTrace();
}
}
if (pm.isPluginEnabled("WorldEdit"))
WorldEdit.getInstance().getEventBus().register(new WorldEditBoundaryAssertion());
if (pm.isPluginEnabled("Citizens")) {
pm.registerEvents(new NPCCreate(), this);
TraitInfo traitInfo = TraitInfo.create(NPCFloorChangeTrait.class).withName("buildinggame:floorchange");
CitizensAPI.getTraitFactory().registerTrait(traitInfo);
}
pm.registerEvents(new ClickJoinSign(), this);
pm.registerEvents(new ClickLeaveSign(), this);
pm.registerEvents(new ClickSpectateSign(), this);
pm.registerEvents(new Drop(), this);
pm.registerEvents(new Interact(), this);
pm.registerEvents(new Leave(), this);
pm.registerEvents(new Move(), this);
pm.registerEvents(new PlaceBucket(), this);
pm.registerEvents(new PlaceIgnoreSpectators(), this);
if (SettingsManager.getInstance().getConfig().getBoolean("chat.adjust"))
pm.registerEvents(new Chat(), this);
pm.registerEvents(new CommandBlocker(), this);
pm.registerEvents(new EntityDamage(), this);
pm.registerEvents(new TakeDamage(), this);
pm.registerEvents(new LoseFood(), this);
// entity events
pm.registerEvents(new ChickenSpawnByEgg(), this);
pm.registerEvents(new EntityExplode(), this);
pm.registerEvents(new EntityOptionsMenu(), this);
pm.registerEvents(new EntitySpawn(), this);
// scoreboards
pm.registerEvents(new MainScoreboardJoinShow(), this);
pm.registerEvents(new MainScoreboardWorldChange(), this);
// stats
// saved
pm.registerEvents(new BreakStat(), this);
pm.registerEvents(new FirstStat(), this);
pm.registerEvents(new PlaceStat(), this);
pm.registerEvents(new PlaysStat(), this);
pm.registerEvents(new SecondStat(), this);
pm.registerEvents(new ThirdStat(), this);
// unsaved
pm.registerEvents(new UnsavedStatsPlace(), this);
// structure
pm.registerEvents(new TreeGrow(), this);
if (StatManager.getInstance().getMySQLDatabase() != null) {
pm.registerEvents(new JoinPlayerStats(), this);
pm.registerEvents(new QuitPlayerStats(), this);
}
}
getLogger().info("Loading signs");
SignManager.getInstance().setup();
getLogger().info("Loading timer");
new ParticleRender().runTaskTimer(this, 0L, 10L);
new ScoreboardUpdater().runTaskTimer(this, 0L, SettingsManager.getInstance().getConfig().getLong("scoreboard-update-delay"));
new StatSaveTimer().runTaskTimerAsynchronously(this, 0L, SettingsManager.getInstance().getConfig().getLong("stats.save-delay"));
new EntityTimer().runTaskTimer(this, 0L, 20L);
new StatSignUpdater().runTaskTimerAsynchronously(this, 0L, 1L);
long end = System.currentTimeMillis();
long duration = end - start;
String time;
if (duration < 1000) {
time = duration + " milliseconds";
} else if (duration < 60000) {
time = duration / 1000.0 + " seconds";
} else {
time = (duration / 60000) + ":" + (duration % 60000) / 1000.0 + " minutes";
}
getLogger().info("BuildingGame has been enabled in " + time + '!');
}
Aggregations