mirror of
https://github.com/BentoBoxWorld/BentoBox.git
synced 2025-01-10 10:28:21 +01:00
Adds stack trace to onLoad if there's a LinkageError (#1399)
Fixes https://github.com/BentoBoxWorld/BentoBox/issues/1362 There was already one for onEnable. This just adds the same to onLoad, which was missing.
This commit is contained in:
parent
09072282bb
commit
2cefdcca3f
@ -71,7 +71,7 @@ public class AddonClassLoader extends URLClassLoader {
|
|||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Convers the addon.yml to an AddonDescription
|
* Converts the addon.yml to an AddonDescription
|
||||||
* @param data - yaml config (addon.yml)
|
* @param data - yaml config (addon.yml)
|
||||||
* @return Addon Description
|
* @return Addon Description
|
||||||
* @throws InvalidAddonDescriptionException - if there's a bug in the addon.yml
|
* @throws InvalidAddonDescriptionException - if there's a bug in the addon.yml
|
||||||
|
@ -162,7 +162,7 @@ public class AddonsManager {
|
|||||||
addon.setState(Addon.State.LOADED);
|
addon.setState(Addon.State.LOADED);
|
||||||
} catch (NoClassDefFoundError | NoSuchMethodError | NoSuchFieldError e) {
|
} catch (NoClassDefFoundError | NoSuchMethodError | NoSuchFieldError e) {
|
||||||
// Looks like the addon is incompatible, because it tries to refer to missing classes...
|
// Looks like the addon is incompatible, because it tries to refer to missing classes...
|
||||||
handleAddonIncompatibility(addon);
|
handleAddonIncompatibility(addon, e);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
// Unhandled exception. We'll give a bit of debug here.
|
// Unhandled exception. We'll give a bit of debug here.
|
||||||
handleAddonError(addon, e);
|
handleAddonError(addon, e);
|
||||||
@ -248,10 +248,7 @@ public class AddonsManager {
|
|||||||
addon.setState(Addon.State.ENABLED);
|
addon.setState(Addon.State.ENABLED);
|
||||||
} catch (NoClassDefFoundError | NoSuchMethodError | NoSuchFieldError e) {
|
} catch (NoClassDefFoundError | NoSuchMethodError | NoSuchFieldError e) {
|
||||||
// Looks like the addon is incompatible, because it tries to refer to missing classes...
|
// Looks like the addon is incompatible, because it tries to refer to missing classes...
|
||||||
handleAddonIncompatibility(addon);
|
handleAddonIncompatibility(addon, e);
|
||||||
StringBuilder a = new StringBuilder();
|
|
||||||
addon.getDescription().getAuthors().forEach(author -> a.append(author).append(" "));
|
|
||||||
plugin.getLogger().log(Level.SEVERE, "Please report this stack trace to the addon's author(s): " + a.toString(), e);
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
// Unhandled exception. We'll give a bit of debug here.
|
// Unhandled exception. We'll give a bit of debug here.
|
||||||
handleAddonError(addon, e);
|
handleAddonError(addon, e);
|
||||||
@ -261,14 +258,19 @@ public class AddonsManager {
|
|||||||
/**
|
/**
|
||||||
* Handles an addon which failed to load due to an incompatibility (missing class, missing method).
|
* Handles an addon which failed to load due to an incompatibility (missing class, missing method).
|
||||||
* @param addon instance of the Addon.
|
* @param addon instance of the Addon.
|
||||||
|
* @param e
|
||||||
* @since 1.1
|
* @since 1.1
|
||||||
*/
|
*/
|
||||||
private void handleAddonIncompatibility(@NonNull Addon addon) {
|
private void handleAddonIncompatibility(@NonNull Addon addon, LinkageError e) {
|
||||||
// Set the AddonState as "INCOMPATIBLE".
|
// Set the AddonState as "INCOMPATIBLE".
|
||||||
addon.setState(Addon.State.INCOMPATIBLE);
|
addon.setState(Addon.State.INCOMPATIBLE);
|
||||||
plugin.logWarning("Skipping " + addon.getDescription().getName() + " as it is incompatible with the current version of BentoBox or of server software...");
|
plugin.logWarning("Skipping " + addon.getDescription().getName() + " as it is incompatible with the current version of BentoBox or of server software...");
|
||||||
plugin.logWarning("NOTE: The addon is referring to no longer existing classes.");
|
plugin.logWarning("NOTE: The addon is referring to no longer existing classes.");
|
||||||
plugin.logWarning("NOTE: DO NOT report this as a bug from BentoBox.");
|
plugin.logWarning("NOTE: DO NOT report this as a bug from BentoBox.");
|
||||||
|
StringBuilder a = new StringBuilder();
|
||||||
|
addon.getDescription().getAuthors().forEach(author -> a.append(author).append(" "));
|
||||||
|
plugin.getLogger().log(Level.SEVERE, "Please report this stack trace to the addon's author(s): " + a.toString(), e);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean isAddonCompatibleWithBentoBox(@NonNull Addon addon) {
|
private boolean isAddonCompatibleWithBentoBox(@NonNull Addon addon) {
|
||||||
|
Loading…
Reference in New Issue
Block a user