[iagno/gnome-3-8] Add cancel_pending_computer_moves utility methods
- From: Michael Catanzaro <mcatanzaro src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [iagno/gnome-3-8] Add cancel_pending_computer_moves utility methods
- Date: Sun, 29 Sep 2013 23:48:47 +0000 (UTC)
commit aeeae48e1caff6d65bfbd010c9cedebfe524d32f
Author: Michael Catanzaro <mcatanzaro gnome org>
Date: Sat Sep 28 19:11:28 2013 -0500
Add cancel_pending_computer_moves utility methods
Also, properly use it at the start of computer_move_cb
This should avoid the situation where computer_move_cb gets called
multiple times in succession.
src/iagno.vala | 28 ++++++++++++----------------
1 files changed, 12 insertions(+), 16 deletions(-)
---
diff --git a/src/iagno.vala b/src/iagno.vala
index e0eb13b..f77e4c7 100644
--- a/src/iagno.vala
+++ b/src/iagno.vala
@@ -200,12 +200,7 @@ public class Iagno : Gtk.Application
private void start_game ()
{
- /* Cancel any pending computer moves */
- if (computer_timer != 0)
- {
- Source.remove (computer_timer);
- computer_timer = 0;
- }
+ cancel_pending_computer_moves ();
if (game != null)
SignalHandler.disconnect_by_func (game, null, this);
@@ -270,12 +265,7 @@ public class Iagno : Gtk.Application
private void undo_move_cb ()
{
- /* Cancel any pending computer moves */
- if (computer_timer != 0)
- {
- Source.remove (computer_timer);
- computer_timer = 0;
- }
+ cancel_pending_computer_moves ();
/* Undo once if the human player just moved, otherwise undo both moves */
if ((game.current_color == Player.DARK && dark_computer != null) ||
@@ -357,10 +347,7 @@ public class Iagno : Gtk.Application
private bool computer_move_cb ()
{
- /* set computer_timer to 0 *before* calling move() since that will
- * call game_move_cb and possibly create a new timer.
- */
- computer_timer = 0;
+ cancel_pending_computer_moves ();
if (game.current_color == Player.LIGHT)
light_computer.move ();
else
@@ -368,6 +355,15 @@ public class Iagno : Gtk.Application
return false;
}
+ private void cancel_pending_computer_moves ()
+ {
+ if (computer_timer != 0)
+ {
+ Source.remove (computer_timer);
+ computer_timer = 0;
+ }
+ }
+
private void game_complete_cb ()
{
update_ui ();
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]