From 8854b3f56585d480cd0c8151e7bbbf12d00cd984 Mon Sep 17 00:00:00 2001 From: snowleo Date: Sun, 23 Oct 2011 23:08:18 +0200 Subject: Moving the link between the states from the constructor of the state machine to the states classes. --- .../essentials/update/states/AbstractState.java | 18 ++++++++- .../update/states/AbstractYesNoState.java | 16 ++++++-- .../essentials/update/states/EssentialsChat.java | 8 ++-- .../update/states/EssentialsProtect.java | 46 ++++++++++++++++++++++ .../essentials/update/states/StateMachine.java | 9 ++--- .../essentials/update/states/StateMap.java | 12 ++++++ .../essentials/update/tasks/InstallChat.java | 12 ------ 7 files changed, 94 insertions(+), 27 deletions(-) create mode 100644 EssentialsUpdate/src/com/earth2me/essentials/update/states/EssentialsProtect.java create mode 100644 EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMap.java delete mode 100644 EssentialsUpdate/src/com/earth2me/essentials/update/tasks/InstallChat.java diff --git a/EssentialsUpdate/src/com/earth2me/essentials/update/states/AbstractState.java b/EssentialsUpdate/src/com/earth2me/essentials/update/states/AbstractState.java index b217ebd4b..22fadc0de 100644 --- a/EssentialsUpdate/src/com/earth2me/essentials/update/states/AbstractState.java +++ b/EssentialsUpdate/src/com/earth2me/essentials/update/states/AbstractState.java @@ -7,6 +7,17 @@ import org.bukkit.entity.Player; public abstract class AbstractState { private transient boolean abortion = false; + private final transient StateMap stateMap; + + public AbstractState(final StateMap stateMap) + { + this.stateMap = stateMap; + } + + public AbstractState getState(final Class stateClass) + { + return stateMap.get(stateClass); + } public abstract AbstractState getNextState(); @@ -40,7 +51,7 @@ public abstract class AbstractState || trimmedAnswer.equalsIgnoreCase("bye") || trimmedAnswer.equalsIgnoreCase("abort")) { - abortion = true; + abort(); return null; } final boolean found = reactOnAnswer(trimmedAnswer); @@ -64,4 +75,9 @@ public abstract class AbstractState { return abortion; } + + protected void abort() + { + abortion = true; + } } diff --git a/EssentialsUpdate/src/com/earth2me/essentials/update/states/AbstractYesNoState.java b/EssentialsUpdate/src/com/earth2me/essentials/update/states/AbstractYesNoState.java index 67701c8db..67baf6bb6 100644 --- a/EssentialsUpdate/src/com/earth2me/essentials/update/states/AbstractYesNoState.java +++ b/EssentialsUpdate/src/com/earth2me/essentials/update/states/AbstractYesNoState.java @@ -4,11 +4,17 @@ package com.earth2me.essentials.update.states; public abstract class AbstractYesNoState extends AbstractState { private boolean answer = false; - private final transient AbstractState yesState; - private final transient AbstractState noState; + private final transient Class yesState; + private final transient Class noState; - public AbstractYesNoState(final AbstractState yesState, final AbstractState noState) + public AbstractYesNoState(final StateMap states, final Class nextState) { + this(states, nextState, nextState); + } + + public AbstractYesNoState(final StateMap states, final Class yesState, final Class noState) + { + super(states); this.yesState = yesState; this.noState = noState; } @@ -16,7 +22,9 @@ public abstract class AbstractYesNoState extends AbstractState @Override public AbstractState getNextState() { - return answer ? yesState : noState; + return answer + ? (yesState == null ? null : getState(yesState)) + : (noState == null ? null : getState(noState)); } @Override diff --git a/EssentialsUpdate/src/com/earth2me/essentials/update/states/EssentialsChat.java b/EssentialsUpdate/src/com/earth2me/essentials/update/states/EssentialsChat.java index 6669161d4..516ec35b0 100644 --- a/EssentialsUpdate/src/com/earth2me/essentials/update/states/EssentialsChat.java +++ b/EssentialsUpdate/src/com/earth2me/essentials/update/states/EssentialsChat.java @@ -1,7 +1,7 @@ package com.earth2me.essentials.update.states; import com.earth2me.essentials.update.WorkListener; -import com.earth2me.essentials.update.tasks.InstallChat; +import com.earth2me.essentials.update.tasks.InstallModule; import org.bukkit.Bukkit; import org.bukkit.entity.Player; import org.bukkit.plugin.Plugin; @@ -9,9 +9,9 @@ import org.bukkit.plugin.Plugin; public class EssentialsChat extends AbstractYesNoState { - public EssentialsChat(final AbstractState next) + public EssentialsChat(final StateMap states) { - super(next, next); + super(states, EssentialsProtect.class); } @Override @@ -38,7 +38,7 @@ public class EssentialsChat extends AbstractYesNoState { if (getAnswer()) { - new InstallChat(listener).start(); + new InstallModule(listener, "EssentialsChat").start(); return; } listener.onWorkDone(); diff --git a/EssentialsUpdate/src/com/earth2me/essentials/update/states/EssentialsProtect.java b/EssentialsUpdate/src/com/earth2me/essentials/update/states/EssentialsProtect.java new file mode 100644 index 000000000..5300ca543 --- /dev/null +++ b/EssentialsUpdate/src/com/earth2me/essentials/update/states/EssentialsProtect.java @@ -0,0 +1,46 @@ +package com.earth2me.essentials.update.states; + +import com.earth2me.essentials.update.WorkListener; +import com.earth2me.essentials.update.tasks.InstallModule; +import org.bukkit.Bukkit; +import org.bukkit.entity.Player; +import org.bukkit.plugin.Plugin; + + +public class EssentialsProtect extends AbstractYesNoState +{ + public EssentialsProtect(final StateMap states) + { + super(states, null); + } + + @Override + public boolean guessAnswer() + { + final Plugin plugin = Bukkit.getPluginManager().getPlugin("EssentialsProtect"); + if (plugin != null) + { + setAnswer(true); + return true; + } + return false; + } + + @Override + public void askQuestion(final Player sender) + { + sender.sendMessage("Do you want to install EssentialsProtect? (yes/no)"); + sender.sendMessage("Short descriptive text about what EssentialsProtect does."); + } + + @Override + public void doWork(final WorkListener listener) + { + if (getAnswer()) + { + new InstallModule(listener, "EssentialsProtect").start(); + return; + } + listener.onWorkDone(); + } +} \ No newline at end of file diff --git a/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMachine.java b/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMachine.java index b69ee14a9..53612715e 100644 --- a/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMachine.java +++ b/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMachine.java @@ -2,8 +2,6 @@ package com.earth2me.essentials.update.states; import com.earth2me.essentials.update.WorkListener; import com.earth2me.essentials.update.VersionInfo; -import java.util.ArrayList; -import java.util.List; import org.bukkit.Bukkit; import org.bukkit.entity.Player; import org.bukkit.plugin.Plugin; @@ -15,7 +13,7 @@ public class StateMachine extends WorkListener { ABORT, WAIT, DONE } - private final transient List states = new ArrayList(); + private final transient StateMap states = new StateMap(); private transient AbstractState current; private final transient Player player; @@ -24,9 +22,8 @@ public class StateMachine extends WorkListener super(plugin, newVersionInfo); this.player = player; states.clear(); - final AbstractState state = new EssentialsChat(null); - states.add(state); - current = state; + states.put(EssentialsChat.class, new EssentialsChat(states)); + current = states.get(0); } public MachineResult askQuestion() diff --git a/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMap.java b/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMap.java new file mode 100644 index 000000000..02d6cc129 --- /dev/null +++ b/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMap.java @@ -0,0 +1,12 @@ +package com.earth2me.essentials.update.states; + +import java.util.LinkedHashMap; + + +public class StateMap extends LinkedHashMap, AbstractState> +{ + public StateMap() + { + super(); + } +} diff --git a/EssentialsUpdate/src/com/earth2me/essentials/update/tasks/InstallChat.java b/EssentialsUpdate/src/com/earth2me/essentials/update/tasks/InstallChat.java deleted file mode 100644 index 44b4e245d..000000000 --- a/EssentialsUpdate/src/com/earth2me/essentials/update/tasks/InstallChat.java +++ /dev/null @@ -1,12 +0,0 @@ -package com.earth2me.essentials.update.tasks; - -import com.earth2me.essentials.update.WorkListener; - - -public class InstallChat extends InstallModule -{ - public InstallChat(final WorkListener listener) - { - super(listener, "EssentialsChat"); - } -} -- cgit v1.2.3 From ff92e0bf6f9996542160b2f9de40878e1879202a Mon Sep 17 00:00:00 2001 From: snowleo Date: Sun, 23 Oct 2011 23:11:47 +0200 Subject: Less chance for C&P error --- .../src/com/earth2me/essentials/update/states/StateMachine.java | 2 +- .../src/com/earth2me/essentials/update/states/StateMap.java | 5 +++++ 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMachine.java b/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMachine.java index 53612715e..4a32b69e4 100644 --- a/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMachine.java +++ b/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMachine.java @@ -22,7 +22,7 @@ public class StateMachine extends WorkListener super(plugin, newVersionInfo); this.player = player; states.clear(); - states.put(EssentialsChat.class, new EssentialsChat(states)); + states.add(new EssentialsChat(states)); current = states.get(0); } diff --git a/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMap.java b/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMap.java index 02d6cc129..a2cf7b719 100644 --- a/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMap.java +++ b/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMap.java @@ -9,4 +9,9 @@ public class StateMap extends LinkedHashMap, Abst { super(); } + + public AbstractState add(AbstractState state) + { + return put(state.getClass(), state); + } } -- cgit v1.2.3 From b07b3fc37329165923fccc1a923cdc195f8ca4e8 Mon Sep 17 00:00:00 2001 From: snowleo Date: Sun, 23 Oct 2011 23:13:30 +0200 Subject: Another state added --- .../src/com/earth2me/essentials/update/states/StateMachine.java | 1 + 1 file changed, 1 insertion(+) diff --git a/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMachine.java b/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMachine.java index 4a32b69e4..79492a232 100644 --- a/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMachine.java +++ b/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMachine.java @@ -23,6 +23,7 @@ public class StateMachine extends WorkListener this.player = player; states.clear(); states.add(new EssentialsChat(states)); + states.add(new EssentialsProtect(states)); current = states.get(0); } -- cgit v1.2.3 From 9c793208adc9205c28ae12512dad2604c4876a40 Mon Sep 17 00:00:00 2001 From: snowleo Date: Sun, 23 Oct 2011 23:20:18 +0200 Subject: Minor changes because we use a map instead of a list --- .../com/earth2me/essentials/update/states/StateMachine.java | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMachine.java b/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMachine.java index 79492a232..fdbcb8cce 100644 --- a/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMachine.java +++ b/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMachine.java @@ -2,6 +2,8 @@ package com.earth2me.essentials.update.states; import com.earth2me.essentials.update.WorkListener; import com.earth2me.essentials.update.VersionInfo; +import java.util.Collections; +import java.util.Iterator; import org.bukkit.Bukkit; import org.bukkit.entity.Player; import org.bukkit.plugin.Plugin; @@ -24,7 +26,7 @@ public class StateMachine extends WorkListener states.clear(); states.add(new EssentialsChat(states)); states.add(new EssentialsProtect(states)); - current = states.get(0); + current = states.values().iterator().next(); } public MachineResult askQuestion() @@ -58,16 +60,17 @@ public class StateMachine extends WorkListener current = next; return askQuestion(); } - private int position = 0; + private transient Iterator iterator; public void startWork() { + iterator = states.values().iterator(); callStateWork(); } private void callStateWork() { - if (position > states.size()) + if (!iterator.hasNext()) { if (player.isOnline()) { @@ -75,14 +78,13 @@ public class StateMachine extends WorkListener } return; } - final AbstractState state = states.get(position); + final AbstractState state = iterator.next(); state.doWork(this); } @Override public void onWorkAbort(final String message) { - position = 0; Bukkit.getScheduler().scheduleSyncDelayedTask(getPlugin(), new Runnable() { @Override @@ -99,7 +101,6 @@ public class StateMachine extends WorkListener @Override public void onWorkDone(final String message) { - position++; Bukkit.getScheduler().scheduleSyncDelayedTask(getPlugin(), new Runnable() { @Override -- cgit v1.2.3 From c79bb03d5e1d1d7e8ea83d4aae00af99a4d56310 Mon Sep 17 00:00:00 2001 From: snowleo Date: Sun, 23 Oct 2011 23:22:04 +0200 Subject: Cleanup --- .../src/com/earth2me/essentials/update/states/StateMachine.java | 1 - 1 file changed, 1 deletion(-) diff --git a/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMachine.java b/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMachine.java index fdbcb8cce..9736d9510 100644 --- a/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMachine.java +++ b/EssentialsUpdate/src/com/earth2me/essentials/update/states/StateMachine.java @@ -2,7 +2,6 @@ package com.earth2me.essentials.update.states; import com.earth2me.essentials.update.WorkListener; import com.earth2me.essentials.update.VersionInfo; -import java.util.Collections; import java.util.Iterator; import org.bukkit.Bukkit; import org.bukkit.entity.Player; -- cgit v1.2.3