[trunk] quickfix for concurrent issues

git-svn-id: https://svn.java.net/svn/essentials~svn/trunk@1556 e251c2fe-e539-e718-e476-b85c1f46cddb
This commit is contained in:
ementalo 2011-06-01 15:10:59 +00:00
parent 8e151357ce
commit d313d0dc87

View File

@ -6,6 +6,7 @@ import java.util.Set;
import org.bukkit.plugin.Plugin;
import org.bukkit.plugin.PluginManager;
/***
* Methods.java
* Controls the getting / setting of methods & the method of payment used.
@ -14,7 +15,8 @@ import org.bukkit.plugin.PluginManager;
* @copyright: Copyright (C) 2011
* @license: GNUv3 Affero License <http://www.gnu.org/licenses/agpl-3.0.html>
*/
public class Methods {
public class Methods
{
private boolean self = false;
private Method Method = null;
private String preferred = "";
@ -22,19 +24,24 @@ public class Methods {
private Set<String> Dependencies = new HashSet<String>();
private Set<Method> Attachables = new HashSet<Method>();
public Methods() {
public Methods()
{
this.addMethod("iConomy", new com.earth2me.essentials.register.payment.methods.iCo4());
this.addMethod("iConomy", new com.earth2me.essentials.register.payment.methods.iCo5());
this.addMethod("BOSEconomy", new com.earth2me.essentials.register.payment.methods.BOSE());
}
public Set<String> getDependencies() {
public Set<String> getDependencies()
{
return Dependencies;
}
public Method createMethod(Plugin plugin) {
for (Method method: Methods) {
if (method.isCompatible(plugin)) {
public Method createMethod(Plugin plugin)
{
for (Method method : Methods)
{
if (method.isCompatible(plugin))
{
method.setPlugin(plugin);
return method;
}
@ -43,33 +50,46 @@ public class Methods {
return null;
}
private void addMethod(String name, Method method) {
private void addMethod(String name, Method method)
{
Dependencies.add(name);
Methods.add(method);
}
public boolean hasMethod() {
public boolean hasMethod()
{
return (Method != null);
}
public boolean setMethod(Plugin method) {
public boolean setMethod(Plugin method)
{
if (hasMethod()) return true;
if(self) { self = false; return false; }
if (self)
{
self = false;
return false;
}
int count = 0;
boolean match = false;
Plugin plugin = null;
PluginManager manager = method.getServer().getPluginManager();
for(String name: this.getDependencies()) {
for (String name : this.getDependencies())
{
if (hasMethod()) break;
if(method.getDescription().getName().equals(name)) plugin = method; else plugin = manager.getPlugin(name);
if (method.getDescription().getName().equals(name)) plugin = method;
else plugin = manager.getPlugin(name);
if (plugin == null) continue;
if(!plugin.isEnabled()) {
if (!plugin.isEnabled())
{
this.self = true;
if (!plugin.getDescription().getName().toLowerCase().equals("essentials"))
{
manager.enablePlugin(plugin);
}
}
if (plugin == null) continue;
@ -78,47 +98,61 @@ public class Methods {
if (this.preferred.isEmpty())
this.Method = current;
else {
else
{
this.Attachables.add(current);
}
}
if(!this.preferred.isEmpty()) {
do {
if(hasMethod()) {
if (!this.preferred.isEmpty())
{
do
{
if (hasMethod())
{
match = true;
} else {
for(Method attached: this.Attachables) {
}
else
{
for (Method attached : this.Attachables)
{
if (attached == null) continue;
if(hasMethod()) {
if (hasMethod())
{
match = true;
break;
}
if (this.preferred.isEmpty()) this.Method = attached;
if(count == 0) {
if (count == 0)
{
if (this.preferred.equalsIgnoreCase(attached.getName()))
this.Method = attached;
} else {
}
else
{
this.Method = attached;
}
}
count++;
}
} while(!match);
}
while (!match);
}
return hasMethod();
}
public Method getMethod() {
public Method getMethod()
{
return Method;
}
public boolean checkDisabled(Plugin method) {
public boolean checkDisabled(Plugin method)
{
if (!hasMethod()) return true;
if (Method.isCompatible(method)) Method = null;
return (Method == null);