Creat a "DummyAction", if actions.txt does not contain a definition of

a custom action. Fixed newlines in "explainations" section of config
file.
This commit is contained in:
Evenprime 2011-11-27 15:05:07 +01:00
parent 1f9a2643e8
commit 5ce7bc04cd
4 changed files with 38 additions and 1 deletions

View File

@ -0,0 +1,13 @@
package cc.co.evenprime.bukkit.nocheat.actions.types;
/**
* This is only used to not lose config entries in case an action isn't defined correctly
*
*/
public class DummyAction extends Action {
public DummyAction(String name, int delay, int repeat) {
super(name, delay, repeat);
}
}

View File

@ -9,6 +9,7 @@ import cc.co.evenprime.bukkit.nocheat.NoCheatPlayer;
import cc.co.evenprime.bukkit.nocheat.actions.types.Action; import cc.co.evenprime.bukkit.nocheat.actions.types.Action;
import cc.co.evenprime.bukkit.nocheat.actions.types.ActionWithParameters.WildCard; import cc.co.evenprime.bukkit.nocheat.actions.types.ActionWithParameters.WildCard;
import cc.co.evenprime.bukkit.nocheat.actions.types.ConsolecommandAction; import cc.co.evenprime.bukkit.nocheat.actions.types.ConsolecommandAction;
import cc.co.evenprime.bukkit.nocheat.actions.types.DummyAction;
import cc.co.evenprime.bukkit.nocheat.actions.types.LogAction; import cc.co.evenprime.bukkit.nocheat.actions.types.LogAction;
import cc.co.evenprime.bukkit.nocheat.actions.types.SpecialAction; import cc.co.evenprime.bukkit.nocheat.actions.types.SpecialAction;
import cc.co.evenprime.bukkit.nocheat.config.cache.ConfigurationCache; import cc.co.evenprime.bukkit.nocheat.config.cache.ConfigurationCache;
@ -51,6 +52,8 @@ public abstract class Check {
special = true; special = true;
} else if(ac instanceof ConsolecommandAction) { } else if(ac instanceof ConsolecommandAction) {
executeConsoleCommand((ConsolecommandAction) ac, this, player, cc); executeConsoleCommand((ConsolecommandAction) ac, this, player, cc);
} else if(ac instanceof DummyAction) {
// nothing - it's a "DummyAction" after all
} }
} }
} }

View File

@ -7,8 +7,11 @@ import java.io.FileInputStream;
import java.io.FileWriter; import java.io.FileWriter;
import java.io.IOException; import java.io.IOException;
import java.io.InputStreamReader; import java.io.InputStreamReader;
import java.util.LinkedList;
import java.util.List;
import cc.co.evenprime.bukkit.nocheat.actions.types.Action; import cc.co.evenprime.bukkit.nocheat.actions.types.Action;
import cc.co.evenprime.bukkit.nocheat.actions.types.DummyAction;
import cc.co.evenprime.bukkit.nocheat.config.util.ActionList; import cc.co.evenprime.bukkit.nocheat.config.util.ActionList;
import cc.co.evenprime.bukkit.nocheat.config.util.ActionMapper; import cc.co.evenprime.bukkit.nocheat.config.util.ActionMapper;
import cc.co.evenprime.bukkit.nocheat.config.util.OptionNode; import cc.co.evenprime.bukkit.nocheat.config.util.OptionNode;
@ -100,8 +103,20 @@ public class FlatFileConfiguration extends Configuration {
al = new ActionList(); al = new ActionList();
} }
int th = Integer.parseInt(treshold); int th = Integer.parseInt(treshold);
al.setActions(th, action.getActions(value.split("\\s+")));
List<Action> actions = new LinkedList<Action>();
for(String name : value.split("\\s+")) {
Action a2 = action.getAction(name);
if(a2 == null) {
System.out.println("Nocheat: Action with name " + name + " isn't defined. You need to define it in your actions.txt file to make it work.");
actions.add(new DummyAction(name, 0, 0));
} else {
actions.add(action.getAction(name));
}
}
al.setActions(th, actions.toArray(new Action[actions.size()]));
return al; return al;
} }
@ -184,6 +199,7 @@ public class FlatFileConfiguration extends Configuration {
for(String line : explainationLines) { for(String line : explainationLines) {
w.write("# " + line); w.write("# " + line);
w.newLine();
} }
} }

View File

@ -30,4 +30,9 @@ public class ActionMapper {
return result; return result;
} }
public Action getAction(String actionName) {
return this.actions.get(actionName.toLowerCase());
}
} }