add more logging to the importer
This commit is contained in:
parent
d73543408e
commit
ba51f803ba
@ -30,6 +30,7 @@ import com.google.common.base.Strings;
|
|||||||
import com.google.common.collect.ImmutableSet;
|
import com.google.common.collect.ImmutableSet;
|
||||||
import com.google.common.collect.ListMultimap;
|
import com.google.common.collect.ListMultimap;
|
||||||
import com.google.common.collect.MultimapBuilder;
|
import com.google.common.collect.MultimapBuilder;
|
||||||
|
import com.google.common.util.concurrent.ThreadFactoryBuilder;
|
||||||
|
|
||||||
import me.lucko.luckperms.common.command.CommandManager;
|
import me.lucko.luckperms.common.command.CommandManager;
|
||||||
import me.lucko.luckperms.common.command.CommandResult;
|
import me.lucko.luckperms.common.command.CommandResult;
|
||||||
@ -89,6 +90,8 @@ public class Importer implements Runnable {
|
|||||||
// start an update task in the background - we'll #join this later
|
// start an update task in the background - we'll #join this later
|
||||||
CompletableFuture<Void> updateTask = CompletableFuture.runAsync(() -> this.commandManager.getPlugin().getUpdateTaskBuffer().requestDirectly());
|
CompletableFuture<Void> updateTask = CompletableFuture.runAsync(() -> this.commandManager.getPlugin().getUpdateTaskBuffer().requestDirectly());
|
||||||
|
|
||||||
|
this.notify.forEach(s -> Message.IMPORT_INFO.send(s, "Processing commands..."));
|
||||||
|
|
||||||
// form instances for all commands, and register them
|
// form instances for all commands, and register them
|
||||||
int index = 1;
|
int index = 1;
|
||||||
for (String command : this.commandList) {
|
for (String command : this.commandList) {
|
||||||
@ -106,15 +109,18 @@ public class Importer implements Runnable {
|
|||||||
// holder id --> commands
|
// holder id --> commands
|
||||||
ListMultimap<String, ImportCommand> sections = MultimapBuilder.linkedHashKeys().arrayListValues().build();
|
ListMultimap<String, ImportCommand> sections = MultimapBuilder.linkedHashKeys().arrayListValues().build();
|
||||||
for (ImportCommand cmd : this.commands) {
|
for (ImportCommand cmd : this.commands) {
|
||||||
String target = Strings.nullToEmpty(cmd.getTarget());
|
sections.put(Strings.nullToEmpty(cmd.getTarget()), cmd);
|
||||||
sections.put(target, cmd);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.notify.forEach(s -> Message.IMPORT_INFO.send(s, "Waiting for initial update task to complete..."));
|
||||||
|
|
||||||
// join the update task future before scheduling command executions
|
// join the update task future before scheduling command executions
|
||||||
updateTask.join();
|
updateTask.join();
|
||||||
|
|
||||||
|
this.notify.forEach(s -> Message.IMPORT_INFO.send(s, "Setting up command executor..."));
|
||||||
|
|
||||||
// create a threadpool for the processing
|
// create a threadpool for the processing
|
||||||
ExecutorService executor = Executors.newFixedThreadPool(128);
|
ExecutorService executor = Executors.newFixedThreadPool(128, new ThreadFactoryBuilder().setNameFormat("luckperms-importer-%d").build());
|
||||||
|
|
||||||
// A set of futures, which are really just the processes we need to wait for.
|
// A set of futures, which are really just the processes we need to wait for.
|
||||||
Set<CompletableFuture<Void>> futures = new HashSet<>();
|
Set<CompletableFuture<Void>> futures = new HashSet<>();
|
||||||
@ -138,6 +144,8 @@ public class Importer implements Runnable {
|
|||||||
// all of the threads have been scheduled now and are running. we just need to wait for them all to complete
|
// all of the threads have been scheduled now and are running. we just need to wait for them all to complete
|
||||||
CompletableFuture<Void> overallFuture = CompletableFuture.allOf(futures.toArray(new CompletableFuture[futures.size()]));
|
CompletableFuture<Void> overallFuture = CompletableFuture.allOf(futures.toArray(new CompletableFuture[futures.size()]));
|
||||||
|
|
||||||
|
this.notify.forEach(s -> Message.IMPORT_INFO.send(s, "All commands have been processed and scheduled - now waiting for the execution to complete."));
|
||||||
|
|
||||||
while (true) {
|
while (true) {
|
||||||
try {
|
try {
|
||||||
overallFuture.get(2, TimeUnit.SECONDS);
|
overallFuture.get(2, TimeUnit.SECONDS);
|
||||||
|
@ -419,6 +419,7 @@ public enum Message {
|
|||||||
IMPORT_PROGRESS("&b(Import) &b-> &f{}&f% complete &7- &b{}&f/&b{} &foperations complete with &c{} &ferrors.", true),
|
IMPORT_PROGRESS("&b(Import) &b-> &f{}&f% complete &7- &b{}&f/&b{} &foperations complete with &c{} &ferrors.", true),
|
||||||
IMPORT_PROGRESS_SIN("&b(Import) &b-> &f{}&f% complete &7- &b{}&f/&b{} &foperations complete with &c{} &ferror.", true),
|
IMPORT_PROGRESS_SIN("&b(Import) &b-> &f{}&f% complete &7- &b{}&f/&b{} &foperations complete with &c{} &ferror.", true),
|
||||||
IMPORT_START("&b(Import) &b-> &fStarting import process.", true),
|
IMPORT_START("&b(Import) &b-> &fStarting import process.", true),
|
||||||
|
IMPORT_INFO("&b(Import) &b-> &f{}.", true),
|
||||||
|
|
||||||
IMPORT_END_COMPLETE("&b(Import) &a&lCOMPLETED &7- took &b{} &7seconds - &7No errors.", true),
|
IMPORT_END_COMPLETE("&b(Import) &a&lCOMPLETED &7- took &b{} &7seconds - &7No errors.", true),
|
||||||
IMPORT_END_COMPLETE_ERR("&b(Import) &a&lCOMPLETED &7- took &b{} &7seconds - &c{} errors.", true),
|
IMPORT_END_COMPLETE_ERR("&b(Import) &a&lCOMPLETED &7- took &b{} &7seconds - &c{} errors.", true),
|
||||||
|
Loading…
Reference in New Issue
Block a user