mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-19 14:51:27 +01:00
More provider source fixup
This commit is contained in:
parent
6fba18bac1
commit
f2da18d62e
@ -3822,7 +3822,6 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+class PaperPluginInstanceManager {
|
+class PaperPluginInstanceManager {
|
||||||
+
|
+
|
||||||
+ private static final FileProviderSource FILE_PROVIDER_SOURCE = new FileProviderSource("File '%s'"::formatted);
|
+ private static final FileProviderSource FILE_PROVIDER_SOURCE = new FileProviderSource("File '%s'"::formatted);
|
||||||
+ private static final DirectoryProviderSource DIRECTORY_PROVIDER_SOURCE = new DirectoryProviderSource();
|
|
||||||
+
|
+
|
||||||
+ private final List<Plugin> plugins = new ArrayList<>();
|
+ private final List<Plugin> plugins = new ArrayList<>();
|
||||||
+ private final Map<String, Plugin> lookupNames = new HashMap<>();
|
+ private final Map<String, Plugin> lookupNames = new HashMap<>();
|
||||||
@ -3904,8 +3903,8 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+
|
+
|
||||||
+ RuntimePluginEntrypointHandler<MultiRuntimePluginProviderStorage> runtimePluginEntrypointHandler = new RuntimePluginEntrypointHandler<>(new MultiRuntimePluginProviderStorage(this.dependencyTree));
|
+ RuntimePluginEntrypointHandler<MultiRuntimePluginProviderStorage> runtimePluginEntrypointHandler = new RuntimePluginEntrypointHandler<>(new MultiRuntimePluginProviderStorage(this.dependencyTree));
|
||||||
+ try {
|
+ try {
|
||||||
+ directory = DIRECTORY_PROVIDER_SOURCE.prepareContext(directory);
|
+ List<Path> files = DirectoryProviderSource.INSTANCE.prepareContext(directory);
|
||||||
+ DIRECTORY_PROVIDER_SOURCE.registerProviders(runtimePluginEntrypointHandler, directory);
|
+ DirectoryProviderSource.INSTANCE.registerProviders(runtimePluginEntrypointHandler, files);
|
||||||
+ runtimePluginEntrypointHandler.enter(Entrypoint.PLUGIN);
|
+ runtimePluginEntrypointHandler.enter(Entrypoint.PLUGIN);
|
||||||
+ } catch (Exception e) {
|
+ } catch (Exception e) {
|
||||||
+ // This should never happen, any errors that occur in this provider should instead be logged.
|
+ // This should never happen, any errors that occur in this provider should instead be logged.
|
||||||
@ -5489,55 +5488,54 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+import com.mojang.logging.LogUtils;
|
+import com.mojang.logging.LogUtils;
|
||||||
+import io.papermc.paper.plugin.entrypoint.EntrypointHandler;
|
+import io.papermc.paper.plugin.entrypoint.EntrypointHandler;
|
||||||
+import java.io.IOException;
|
+import java.io.IOException;
|
||||||
+import java.util.function.Consumer;
|
|
||||||
+import org.slf4j.Logger;
|
|
||||||
+
|
|
||||||
+import java.nio.file.FileVisitOption;
|
+import java.nio.file.FileVisitOption;
|
||||||
+import java.nio.file.Files;
|
+import java.nio.file.Files;
|
||||||
+import java.nio.file.Path;
|
+import java.nio.file.Path;
|
||||||
|
+import java.util.ArrayList;
|
||||||
|
+import java.util.List;
|
||||||
|
+import java.util.function.Consumer;
|
||||||
|
+import org.slf4j.Logger;
|
||||||
+
|
+
|
||||||
+/**
|
+/**
|
||||||
+ * Loads all plugin providers in the given directory.
|
+ * Loads all plugin providers in the given directory.
|
||||||
+ */
|
+ */
|
||||||
+public class DirectoryProviderSource extends FileProviderSource {
|
+public class DirectoryProviderSource implements ProviderSource<Path, List<Path>> {
|
||||||
+
|
+
|
||||||
+ public static final DirectoryProviderSource INSTANCE = new DirectoryProviderSource();
|
+ public static final DirectoryProviderSource INSTANCE = new DirectoryProviderSource();
|
||||||
|
+ private static final FileProviderSource FILE_PROVIDER_SOURCE = new FileProviderSource("Directory '%s'"::formatted);
|
||||||
+ private static final Logger LOGGER = LogUtils.getClassLogger();
|
+ private static final Logger LOGGER = LogUtils.getClassLogger();
|
||||||
+
|
+
|
||||||
+ public DirectoryProviderSource() {
|
|
||||||
+ super("Directory '%s'"::formatted);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ @Override
|
+ @Override
|
||||||
+ public Path prepareContext(Path context) throws IOException {
|
+ public List<Path> prepareContext(Path context) throws IOException {
|
||||||
+ // Symlink happy, create file if missing.
|
+ // Symlink happy, create file if missing.
|
||||||
+ if (!Files.isDirectory(context)) {
|
+ if (!Files.isDirectory(context)) {
|
||||||
+ Files.createDirectories(context);
|
+ Files.createDirectories(context);
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
|
+ final List<Path> files = new ArrayList<>();
|
||||||
+ this.walkFiles(context, path -> {
|
+ this.walkFiles(context, path -> {
|
||||||
+ try {
|
+ try {
|
||||||
+ super.prepareContext(path);
|
+ files.add(FILE_PROVIDER_SOURCE.prepareContext(path));
|
||||||
+ } catch (IllegalArgumentException ignored) {
|
+ } catch (IllegalArgumentException ignored) {
|
||||||
+ // Ignore illegal argument exceptions from jar checking
|
+ // Ignore illegal argument exceptions from jar checking
|
||||||
+ } catch (IOException e) {
|
+ } catch (IOException e) {
|
||||||
+ throw new RuntimeException(e);
|
+ LOGGER.error("Error preparing plugin context: " + e.getMessage(), e);
|
||||||
+ }
|
+ }
|
||||||
+ });
|
+ });
|
||||||
+ return context;
|
+ return files;
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ @Override
|
+ @Override
|
||||||
+ public void registerProviders(EntrypointHandler entrypointHandler, Path context) throws IOException {
|
+ public void registerProviders(EntrypointHandler entrypointHandler, List<Path> context) {
|
||||||
+ this.walkFiles(context, path -> {
|
+ for (Path path : context) {
|
||||||
+ try {
|
+ try {
|
||||||
+ super.registerProviders(entrypointHandler, path);
|
+ FILE_PROVIDER_SOURCE.registerProviders(entrypointHandler, path);
|
||||||
+ } catch (IllegalArgumentException ignored) {
|
+ } catch (IllegalArgumentException ignored) {
|
||||||
+ // Ignore illegal argument exceptions from jar checking
|
+ // Ignore illegal argument exceptions from jar checking
|
||||||
+ } catch (Exception e) {
|
+ } catch (Exception e) {
|
||||||
+ LOGGER.error("Error loading plugin: " + e.getMessage(), e);
|
+ LOGGER.error("Error loading plugin: " + e.getMessage(), e);
|
||||||
+ }
|
+ }
|
||||||
+ });
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ private void walkFiles(Path context, Consumer<Path> consumer) throws IOException {
|
+ private void walkFiles(Path context, Consumer<Path> consumer) throws IOException {
|
||||||
@ -5580,7 +5578,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+/**
|
+/**
|
||||||
+ * Loads a plugin provider at the given plugin jar file path.
|
+ * Loads a plugin provider at the given plugin jar file path.
|
||||||
+ */
|
+ */
|
||||||
+public class FileProviderSource implements ProviderSource<Path> {
|
+public class FileProviderSource implements ProviderSource<Path, Path> {
|
||||||
+
|
+
|
||||||
+ private final Function<Path, String> contextChecker;
|
+ private final Function<Path, String> contextChecker;
|
||||||
+
|
+
|
||||||
@ -5731,6 +5729,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+import com.mojang.logging.LogUtils;
|
+import com.mojang.logging.LogUtils;
|
||||||
+import io.papermc.paper.plugin.entrypoint.EntrypointHandler;
|
+import io.papermc.paper.plugin.entrypoint.EntrypointHandler;
|
||||||
+import java.nio.file.Path;
|
+import java.nio.file.Path;
|
||||||
|
+import java.util.ArrayList;
|
||||||
+import org.slf4j.Logger;
|
+import org.slf4j.Logger;
|
||||||
+
|
+
|
||||||
+import java.util.List;
|
+import java.util.List;
|
||||||
@ -5738,22 +5737,30 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+/**
|
+/**
|
||||||
+ * Registers providers at the provided files in the add-plugin argument.
|
+ * Registers providers at the provided files in the add-plugin argument.
|
||||||
+ */
|
+ */
|
||||||
+public class PluginFlagProviderSource implements ProviderSource<List<Path>> {
|
+public class PluginFlagProviderSource implements ProviderSource<List<Path>, List<Path>> {
|
||||||
+
|
+
|
||||||
+ public static final PluginFlagProviderSource INSTANCE = new PluginFlagProviderSource();
|
+ public static final PluginFlagProviderSource INSTANCE = new PluginFlagProviderSource();
|
||||||
|
+ private static final FileProviderSource FILE_PROVIDER_SOURCE = new FileProviderSource("File '%s' specified through 'add-plugin' argument"::formatted);
|
||||||
+ private static final Logger LOGGER = LogUtils.getClassLogger();
|
+ private static final Logger LOGGER = LogUtils.getClassLogger();
|
||||||
+ private final FileProviderSource providerSource = new FileProviderSource("File '%s' specified through 'add-plugin' argument"::formatted);
|
|
||||||
+
|
+
|
||||||
+ @Override
|
+ @Override
|
||||||
+ public List<Path> prepareContext(List<Path> context) {
|
+ public List<Path> prepareContext(List<Path> context) {
|
||||||
+ return context;
|
+ final List<Path> files = new ArrayList<>();
|
||||||
|
+ for (Path path : context) {
|
||||||
|
+ try {
|
||||||
|
+ files.add(FILE_PROVIDER_SOURCE.prepareContext(path));
|
||||||
|
+ } catch (Exception e) {
|
||||||
|
+ LOGGER.error("Error preparing plugin context: " + e.getMessage(), e);
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ return files;
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ @Override
|
+ @Override
|
||||||
+ public void registerProviders(EntrypointHandler entrypointHandler, List<Path> context) {
|
+ public void registerProviders(EntrypointHandler entrypointHandler, List<Path> context) {
|
||||||
+ for (Path path : context) {
|
+ for (Path path : context) {
|
||||||
+ try {
|
+ try {
|
||||||
+ this.providerSource.registerProviders(entrypointHandler, path);
|
+ FILE_PROVIDER_SOURCE.registerProviders(entrypointHandler, path);
|
||||||
+ } catch (Exception e) {
|
+ } catch (Exception e) {
|
||||||
+ LOGGER.error("Error loading plugin: " + e.getMessage(), e);
|
+ LOGGER.error("Error loading plugin: " + e.getMessage(), e);
|
||||||
+ }
|
+ }
|
||||||
@ -5775,13 +5782,28 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ * A provider source is responsible for giving PluginTypes an EntrypointHandler for
|
+ * A provider source is responsible for giving PluginTypes an EntrypointHandler for
|
||||||
+ * registering providers at.
|
+ * registering providers at.
|
||||||
+ *
|
+ *
|
||||||
|
+ * @param <I> input context
|
||||||
+ * @param <C> context
|
+ * @param <C> context
|
||||||
+ */
|
+ */
|
||||||
+public interface ProviderSource<C> {
|
+public interface ProviderSource<I, C> {
|
||||||
+
|
+
|
||||||
+ C prepareContext(C context) throws IOException;
|
+ /**
|
||||||
|
+ * Prepares the context for use in {@link #registerProviders(EntrypointHandler, Object)}.
|
||||||
|
+ *
|
||||||
|
+ * @param context the context to prepare
|
||||||
|
+ * @return the prepared context, ready for use in {@link #registerProviders(EntrypointHandler, Object)}
|
||||||
|
+ * @throws IOException if an error occurs while preparing the context
|
||||||
|
+ */
|
||||||
|
+ C prepareContext(I context) throws IOException;
|
||||||
+
|
+
|
||||||
+ void registerProviders(EntrypointHandler entrypointHandler, C context) throws Throwable;
|
+ /**
|
||||||
|
+ * Uses the prepared context to register providers at the given entrypoint handler.
|
||||||
|
+ *
|
||||||
|
+ * @param entrypointHandler the entrypoint handler to register providers at
|
||||||
|
+ * @param context the context to register providers at
|
||||||
|
+ * @throws Exception if an error occurs while registering providers
|
||||||
|
+ */
|
||||||
|
+ void registerProviders(EntrypointHandler entrypointHandler, C context) throws Exception;
|
||||||
+}
|
+}
|
||||||
diff --git a/src/main/java/io/papermc/paper/plugin/provider/type/PluginFileType.java b/src/main/java/io/papermc/paper/plugin/provider/type/PluginFileType.java
|
diff --git a/src/main/java/io/papermc/paper/plugin/provider/type/PluginFileType.java b/src/main/java/io/papermc/paper/plugin/provider/type/PluginFileType.java
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
@ -6995,9 +7017,9 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+
|
+
|
||||||
+ private static final Logger LOGGER = LogUtils.getClassLogger();
|
+ private static final Logger LOGGER = LogUtils.getClassLogger();
|
||||||
+
|
+
|
||||||
+ public static <C> void registerProvidersFromSource(ProviderSource<C> source, C context) {
|
+ public static <I, C> void registerProvidersFromSource(ProviderSource<I, C> source, I contextInput) {
|
||||||
+ try {
|
+ try {
|
||||||
+ context = source.prepareContext(context);
|
+ C context = source.prepareContext(contextInput);
|
||||||
+ source.registerProviders(LaunchEntryPointHandler.INSTANCE, context);
|
+ source.registerProviders(LaunchEntryPointHandler.INSTANCE, context);
|
||||||
+ } catch (Throwable e) {
|
+ } catch (Throwable e) {
|
||||||
+ LOGGER.error(e.getMessage(), e);
|
+ LOGGER.error(e.getMessage(), e);
|
||||||
|
Loading…
Reference in New Issue
Block a user