From c7d6a98d991b49f5012866f0c8df89c6fd8c332c Mon Sep 17 00:00:00 2001 From: Decebal Suiu Date: Wed, 7 Oct 2015 14:07:08 +0300 Subject: [PATCH] make PluginManager available in Plugin via PluginWrapper --- .../java/ro/fortsoft/pf4j/DefaultPluginManager.java | 2 +- .../src/main/java/ro/fortsoft/pf4j/PluginWrapper.java | 11 ++++++++++- 2 files changed, 11 insertions(+), 2 deletions(-) diff --git a/pf4j/src/main/java/ro/fortsoft/pf4j/DefaultPluginManager.java b/pf4j/src/main/java/ro/fortsoft/pf4j/DefaultPluginManager.java index 865bc5f..3563cde 100644 --- a/pf4j/src/main/java/ro/fortsoft/pf4j/DefaultPluginManager.java +++ b/pf4j/src/main/java/ro/fortsoft/pf4j/DefaultPluginManager.java @@ -780,7 +780,7 @@ public class DefaultPluginManager implements PluginManager { // create the plugin wrapper log.debug("Creating wrapper for plugin '{}'", pluginPath); - PluginWrapper pluginWrapper = new PluginWrapper(pluginDescriptor, pluginPath, pluginClassLoader); + PluginWrapper pluginWrapper = new PluginWrapper(this, pluginDescriptor, pluginPath, pluginClassLoader); pluginWrapper.setPluginFactory(pluginFactory); pluginWrapper.setRuntimeMode(getRuntimeMode()); diff --git a/pf4j/src/main/java/ro/fortsoft/pf4j/PluginWrapper.java b/pf4j/src/main/java/ro/fortsoft/pf4j/PluginWrapper.java index 45dbc1e..8046be5 100644 --- a/pf4j/src/main/java/ro/fortsoft/pf4j/PluginWrapper.java +++ b/pf4j/src/main/java/ro/fortsoft/pf4j/PluginWrapper.java @@ -19,6 +19,7 @@ package ro.fortsoft.pf4j; */ public class PluginWrapper { + PluginManager pluginManager; PluginDescriptor descriptor; String pluginPath; PluginClassLoader pluginClassLoader; @@ -27,7 +28,8 @@ public class PluginWrapper { RuntimeMode runtimeMode; Plugin plugin; // cache - public PluginWrapper(PluginDescriptor descriptor, String pluginPath, PluginClassLoader pluginClassLoader) { + public PluginWrapper(PluginManager pluginManager, PluginDescriptor descriptor, String pluginPath, PluginClassLoader pluginClassLoader) { + this.pluginManager = pluginManager; this.descriptor = descriptor; this.pluginPath = pluginPath; this.pluginClassLoader = pluginClassLoader; @@ -35,6 +37,13 @@ public class PluginWrapper { pluginState = PluginState.CREATED; } + /** + * Returns the plugin manager. + */ + public PluginManager getPluginManager() { + return pluginManager; + } + /** * Returns the plugin descriptor. */