mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-16 05:11:27 +01:00
Close library classloader and improve PluginDescriptionFile (#8901)
This commit is contained in:
parent
eb56bf3058
commit
751beefa8e
@ -770,6 +770,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+import java.io.File;
|
+import java.io.File;
|
||||||
+import java.io.IOException;
|
+import java.io.IOException;
|
||||||
+import java.net.URL;
|
+import java.net.URL;
|
||||||
|
+import java.net.URLClassLoader;
|
||||||
+import java.nio.file.Path;
|
+import java.nio.file.Path;
|
||||||
+import java.util.ArrayList;
|
+import java.util.ArrayList;
|
||||||
+import java.util.Collections;
|
+import java.util.Collections;
|
||||||
@ -793,7 +794,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ registerAsParallelCapable();
|
+ registerAsParallelCapable();
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ private final ClassLoader libraryLoader;
|
+ private final URLClassLoader libraryLoader;
|
||||||
+ private final Set<String> seenIllegalAccess = Collections.newSetFromMap(new ConcurrentHashMap<>());
|
+ private final Set<String> seenIllegalAccess = Collections.newSetFromMap(new ConcurrentHashMap<>());
|
||||||
+ private final Logger logger;
|
+ private final Logger logger;
|
||||||
+ @Nullable
|
+ @Nullable
|
||||||
@ -801,7 +802,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ @Nullable
|
+ @Nullable
|
||||||
+ private PluginClassLoaderGroup group;
|
+ private PluginClassLoaderGroup group;
|
||||||
+
|
+
|
||||||
+ public PaperPluginClassLoader(Logger logger, Path source, JarFile file, PaperPluginMeta configuration, ClassLoader parentLoader, ClassLoader libraryLoader) throws IOException {
|
+ public PaperPluginClassLoader(Logger logger, Path source, JarFile file, PaperPluginMeta configuration, ClassLoader parentLoader, URLClassLoader libraryLoader) throws IOException {
|
||||||
+ super(source, file, configuration, parentLoader);
|
+ super(source, file, configuration, parentLoader);
|
||||||
+ this.libraryLoader = libraryLoader;
|
+ this.libraryLoader = libraryLoader;
|
||||||
+
|
+
|
||||||
@ -904,9 +905,9 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ config.getProvidedPlugins(),
|
+ config.getProvidedPlugins(),
|
||||||
+ config.getMainClass(),
|
+ config.getMainClass(),
|
||||||
+ "", // Classloader load order api
|
+ "", // Classloader load order api
|
||||||
+ List.of(), // Dependencies
|
+ config.getPluginDependencies(), // Dependencies
|
||||||
+ List.of(), // Soft Depends
|
+ config.getPluginSoftDependencies(), // Soft Depends
|
||||||
+ List.of(), // Load Before
|
+ config.getLoadBeforePlugins(), // Load Before
|
||||||
+ config.getVersion(),
|
+ config.getVersion(),
|
||||||
+ Map.of(), // Commands, we use a separate system
|
+ Map.of(), // Commands, we use a separate system
|
||||||
+ config.getDescription(),
|
+ config.getDescription(),
|
||||||
@ -945,6 +946,15 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ ", group=" + this.group +
|
+ ", group=" + this.group +
|
||||||
+ '}';
|
+ '}';
|
||||||
+ }
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public void close() throws IOException {
|
||||||
|
+ try {
|
||||||
|
+ super.close();
|
||||||
|
+ } finally {
|
||||||
|
+ this.libraryLoader.close();
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
+}
|
+}
|
||||||
diff --git a/src/main/java/io/papermc/paper/plugin/entrypoint/classloader/PaperSimplePluginClassLoader.java b/src/main/java/io/papermc/paper/plugin/entrypoint/classloader/PaperSimplePluginClassLoader.java
|
diff --git a/src/main/java/io/papermc/paper/plugin/entrypoint/classloader/PaperSimplePluginClassLoader.java b/src/main/java/io/papermc/paper/plugin/entrypoint/classloader/PaperSimplePluginClassLoader.java
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
|
Loading…
Reference in New Issue
Block a user