[ci skip] Refactor context records for easier expansion (#9589)

This commit is contained in:
Jake Potrebic 2023-08-22 20:34:57 -07:00
parent 86a90ebe3e
commit 4e461ccab9

View File

@ -609,10 +609,21 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
+import net.kyori.adventure.text.logger.slf4j.ComponentLogger; +import net.kyori.adventure.text.logger.slf4j.ComponentLogger;
+import org.jetbrains.annotations.NotNull; +import org.jetbrains.annotations.NotNull;
+ +
+public record PluginBootstrapContextImpl(PluginMeta config, Path dataFolder, +public final class PluginBootstrapContextImpl implements BootstrapContext {
+ ComponentLogger logger, Path pluginSource) implements BootstrapContext {
+ +
+ public static PluginBootstrapContextImpl of(PluginProvider<?> provider, Path pluginFolder) { + private final PluginMeta config;
+ private final Path dataFolder;
+ private final ComponentLogger logger;
+ private final Path pluginSource;
+
+ public PluginBootstrapContextImpl(PluginMeta config, Path dataFolder, ComponentLogger logger, Path pluginSource) {
+ this.config = config;
+ this.dataFolder = dataFolder;
+ this.logger = logger;
+ this.pluginSource = pluginSource;
+ }
+
+ public static PluginBootstrapContextImpl create(PluginProvider<?> provider, Path pluginFolder) {
+ Path dataFolder = pluginFolder.resolve(provider.getMeta().getName()); + Path dataFolder = pluginFolder.resolve(provider.getMeta().getName());
+ +
+ return new PluginBootstrapContextImpl(provider.getMeta(), dataFolder, provider.getLogger(), provider.getSource()); + return new PluginBootstrapContextImpl(provider.getMeta(), dataFolder, provider.getLogger(), provider.getSource());
@ -653,10 +664,21 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
+ +
+import java.nio.file.Path; +import java.nio.file.Path;
+ +
+public record PluginProviderContextImpl(PluginMeta config, Path dataFolder, +public final class PluginProviderContextImpl implements PluginProviderContext {
+ ComponentLogger logger, Path pluginSource) implements PluginProviderContext {
+ +
+ public static PluginProviderContextImpl of(PluginMeta config, ComponentLogger logger, Path pluginSource) { + private final PluginMeta config;
+ private final Path dataFolder;
+ private final ComponentLogger logger;
+ private final Path pluginSource;
+
+ public PluginProviderContextImpl(PluginMeta config, Path dataFolder, ComponentLogger logger, Path pluginSource) {
+ this.config = config;
+ this.dataFolder = dataFolder;
+ this.logger = logger;
+ this.pluginSource = pluginSource;
+ }
+
+ public static PluginProviderContextImpl create(PluginMeta config, ComponentLogger logger, Path pluginSource) {
+ Path dataFolder = PluginInitializerManager.instance().pluginDirectoryPath().resolve(config.getName()); + Path dataFolder = PluginInitializerManager.instance().pluginDirectoryPath().resolve(config.getName());
+ +
+ return new PluginProviderContextImpl(config, dataFolder, logger, pluginSource); + return new PluginProviderContextImpl(config, dataFolder, logger, pluginSource);
@ -6161,7 +6183,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
+ public PaperPluginParent build(JarFile file, PaperPluginMeta configuration, Path source) throws Exception { + public PaperPluginParent build(JarFile file, PaperPluginMeta configuration, Path source) throws Exception {
+ Logger jul = PaperPluginLogger.getLogger(configuration); + Logger jul = PaperPluginLogger.getLogger(configuration);
+ ComponentLogger logger = ComponentLogger.logger(jul.getName()); + ComponentLogger logger = ComponentLogger.logger(jul.getName());
+ PluginProviderContext context = PluginProviderContextImpl.of(configuration, logger, source); + PluginProviderContext context = PluginProviderContextImpl.create(configuration, logger, source);
+ +
+ PaperClasspathBuilder builder = new PaperClasspathBuilder(context); + PaperClasspathBuilder builder = new PaperClasspathBuilder(context);
+ +
@ -6559,7 +6581,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
+ @Override + @Override
+ public boolean load(PluginProvider<PluginBootstrap> provider, PluginBootstrap provided) { + public boolean load(PluginProvider<PluginBootstrap> provider, PluginBootstrap provided) {
+ try { + try {
+ BootstrapContext context = PluginBootstrapContextImpl.of(provider, PluginInitializerManager.instance().pluginDirectoryPath()); + BootstrapContext context = PluginBootstrapContextImpl.create(provider, PluginInitializerManager.instance().pluginDirectoryPath());
+ provided.bootstrap(context); + provided.bootstrap(context);
+ return true; + return true;
+ } catch (Throwable e) { + } catch (Throwable e) {