Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Sign in / Register
Toggle navigation
Menu
Open sidebar
ziqian zhang
Grasscutter
Commits
730c9938
Commit
730c9938
authored
May 07, 2022
by
Magix
Committed by
GitHub
May 07, 2022
Browse files
Merge pull request #628 from exzork/development
PluginManager: Use the same class loader and add getPlugin method
parents
ab5131e9
84c1cd7a
Changes
1
Hide whitespace changes
Inline
Side-by-side
src/main/java/emu/grasscutter/plugin/PluginManager.java
View file @
730c9938
...
@@ -4,12 +4,12 @@ import emu.grasscutter.Grasscutter;
...
@@ -4,12 +4,12 @@ import emu.grasscutter.Grasscutter;
import
emu.grasscutter.server.event.Event
;
import
emu.grasscutter.server.event.Event
;
import
emu.grasscutter.server.event.EventHandler
;
import
emu.grasscutter.server.event.EventHandler
;
import
emu.grasscutter.server.event.HandlerPriority
;
import
emu.grasscutter.server.event.HandlerPriority
;
import
emu.grasscutter.utils.EventConsumer
;
import
emu.grasscutter.utils.Utils
;
import
emu.grasscutter.utils.Utils
;
import
java.io.File
;
import
java.io.File
;
import
java.io.InputStreamReader
;
import
java.io.InputStreamReader
;
import
java.lang.reflect.Method
;
import
java.lang.reflect.Method
;
import
java.net.MalformedURLException
;
import
java.net.URL
;
import
java.net.URL
;
import
java.net.URLClassLoader
;
import
java.net.URLClassLoader
;
import
java.util.*
;
import
java.util.*
;
...
@@ -47,12 +47,23 @@ public final class PluginManager {
...
@@ -47,12 +47,23 @@ public final class PluginManager {
List
<
File
>
plugins
=
Arrays
.
stream
(
files
)
List
<
File
>
plugins
=
Arrays
.
stream
(
files
)
.
filter
(
file
->
file
.
getName
().
endsWith
(
".jar"
))
.
filter
(
file
->
file
.
getName
().
endsWith
(
".jar"
))
.
toList
();
.
toList
();
URL
[]
pluginNames
=
new
URL
[
plugins
.
size
()];
plugins
.
forEach
(
plugin
->
{
try
{
pluginNames
[
plugins
.
indexOf
(
plugin
)]
=
plugin
.
toURI
().
toURL
();
}
catch
(
MalformedURLException
exception
)
{
Grasscutter
.
getLogger
().
warn
(
"Unable to load plugin."
,
exception
);
}
});
URLClassLoader
classLoader
=
new
URLClassLoader
(
pluginNames
);
plugins
.
forEach
(
plugin
->
{
plugins
.
forEach
(
plugin
->
{
try
{
try
{
URL
url
=
plugin
.
toURI
().
toURL
();
URL
url
=
plugin
.
toURI
().
toURL
();
try
(
URLClassLoader
loader
=
new
URLClassLoader
(
new
URL
[]{
url
}))
{
try
(
URLClassLoader
loader
=
new
URLClassLoader
(
new
URL
[]{
url
}))
{
URL
configFile
=
loader
.
findResource
(
"plugin.json"
);
URL
configFile
=
loader
.
findResource
(
"plugin.json"
);
// Find the plugin.json file for each plugin.
InputStreamReader
fileReader
=
new
InputStreamReader
(
configFile
.
openStream
());
InputStreamReader
fileReader
=
new
InputStreamReader
(
configFile
.
openStream
());
PluginConfig
pluginConfig
=
Grasscutter
.
getGsonFactory
().
fromJson
(
fileReader
,
PluginConfig
.
class
);
PluginConfig
pluginConfig
=
Grasscutter
.
getGsonFactory
().
fromJson
(
fileReader
,
PluginConfig
.
class
);
...
@@ -68,10 +79,10 @@ public final class PluginManager {
...
@@ -68,10 +79,10 @@ public final class PluginManager {
JarEntry
entry
=
entries
.
nextElement
();
JarEntry
entry
=
entries
.
nextElement
();
if
(
entry
.
isDirectory
()
||
!
entry
.
getName
().
endsWith
(
".class"
)
||
entry
.
getName
().
contains
(
"module-info"
))
continue
;
if
(
entry
.
isDirectory
()
||
!
entry
.
getName
().
endsWith
(
".class"
)
||
entry
.
getName
().
contains
(
"module-info"
))
continue
;
String
className
=
entry
.
getName
().
replace
(
".class"
,
""
).
replace
(
"/"
,
"."
);
String
className
=
entry
.
getName
().
replace
(
".class"
,
""
).
replace
(
"/"
,
"."
);
l
oader
.
loadClass
(
className
);
classL
oader
.
loadClass
(
className
);
// Use the same class loader for ALL plugins.
}
}
Class
<?>
pluginClass
=
l
oader
.
loadClass
(
pluginConfig
.
mainClass
);
Class
<?>
pluginClass
=
classL
oader
.
loadClass
(
pluginConfig
.
mainClass
);
Plugin
pluginInstance
=
(
Plugin
)
pluginClass
.
getDeclaredConstructor
().
newInstance
();
Plugin
pluginInstance
=
(
Plugin
)
pluginClass
.
getDeclaredConstructor
().
newInstance
();
this
.
loadPlugin
(
pluginInstance
,
PluginIdentifier
.
fromPluginConfig
(
pluginConfig
),
loader
);
this
.
loadPlugin
(
pluginInstance
,
PluginIdentifier
.
fromPluginConfig
(
pluginConfig
),
loader
);
...
@@ -156,6 +167,10 @@ public final class PluginManager {
...
@@ -156,6 +167,10 @@ public final class PluginManager {
.
toList
().
forEach
(
handler
->
this
.
invokeHandler
(
event
,
handler
));
.
toList
().
forEach
(
handler
->
this
.
invokeHandler
(
event
,
handler
));
}
}
public
Plugin
getPlugin
(
String
name
)
{
return
this
.
plugins
.
get
(
name
);
}
/**
/**
* Performs logic checks then invokes the provided event handler.
* Performs logic checks then invokes the provided event handler.
* @param event The event passed through to the handler.
* @param event The event passed through to the handler.
...
@@ -167,4 +182,4 @@ public final class PluginManager {
...
@@ -167,4 +182,4 @@ public final class PluginManager {
(
event
.
isCanceled
()
&&
handler
.
ignoresCanceled
())
(
event
.
isCanceled
()
&&
handler
.
ignoresCanceled
())
)
handler
.
getCallback
().
consume
((
T
)
event
);
)
handler
.
getCallback
().
consume
((
T
)
event
);
}
}
}
}
\ No newline at end of file
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment