diff options
author | MacTrophy <macworld@sympatico.ca> | 2019-07-02 16:39:33 -0400 |
---|---|---|
committer | Decebal Suiu <decebal.suiu@gmail.com> | 2019-07-02 23:39:33 +0300 |
commit | 9ef232d34d7e75081571330bfc6ce0d2382d2bf7 (patch) | |
tree | 04e4c5905a84cf62bf26903c20a45ccb58dbb3a3 | |
parent | 36995ea486bdcf720f9403c05dbe6c84c3dbb1fa (diff) | |
download | pf4j-9ef232d34d7e75081571330bfc6ce0d2382d2bf7.tar.gz pf4j-9ef232d34d7e75081571330bfc6ce0d2382d2bf7.zip |
Modified org.pf4j.PluginState to an enum (#328)
-rw-r--r-- | pf4j/src/main/java/org/pf4j/PluginState.java | 40 |
1 files changed, 19 insertions, 21 deletions
diff --git a/pf4j/src/main/java/org/pf4j/PluginState.java b/pf4j/src/main/java/org/pf4j/PluginState.java index 51c3f48..7b5037a 100644 --- a/pf4j/src/main/java/org/pf4j/PluginState.java +++ b/pf4j/src/main/java/org/pf4j/PluginState.java @@ -18,33 +18,33 @@ package org.pf4j; /** * @author Decebal Suiu */ -public class PluginState { +public enum PluginState { /** * The runtime knows the plugin is there. It knows about the plugin path, the plugin descriptor. */ - public static final PluginState CREATED = new PluginState("CREATED"); - + CREATED("CREATED"), + /** * The plugin cannot be used. */ - public static final PluginState DISABLED = new PluginState("DISABLED"); - + DISABLED("DISABLED"), + /** * The plugin is created. All the dependencies are created and resolved. * The plugin is ready to be started. */ - public static final PluginState RESOLVED = new PluginState("RESOLVED"); + RESOLVED("RESOLVED"), /** * The {@link Plugin#start()} has executed. A started plugin may contribute extensions. */ - public static final PluginState STARTED = new PluginState("STARTED"); + STARTED("STARTED"), /** * The {@link Plugin#stop()} has executed. */ - public static final PluginState STOPPED = new PluginState("STOPPED"); + STOPPED("STOPPED"); private String status; @@ -52,19 +52,8 @@ public class PluginState { this.status = status; } - @Override - public boolean equals(Object o) { - if (this == o) return true; - if (o == null || getClass() != o.getClass()) return false; - - PluginState that = (PluginState) o; - - return status.equals(that.status); - } - - @Override - public int hashCode() { - return status.hashCode(); + public boolean equals(String status) { + return (status == null ? false : this.status.equalsIgnoreCase(status)); } @Override @@ -72,4 +61,13 @@ public class PluginState { return status; } + public static PluginState parse(String string) { + for (PluginState status : values()) { + if (status.equals(string)) { + return status; + } + } + + return null; + } } |