diff options
author | Giuseppe Bilotta <giuseppe.bilotta@gmail.com> | 2008-04-11 12:26:45 +0200 |
---|---|---|
committer | Giuseppe Bilotta <giuseppe.bilotta@gmail.com> | 2008-04-11 12:26:45 +0200 |
commit | 5aeef49abc6959b45989bc65d25357b16f062030 (patch) | |
tree | f4e5caa9ff0cd5a802efe39aeb10977aed0aea0f /data/rbot/plugins/games/uno.rb | |
parent | ac10728090f28a34593da1d125ebf0811d7d9691 (diff) |
uno plugin: correct handling of drops and forced game ends
Diffstat (limited to 'data/rbot/plugins/games/uno.rb')
-rw-r--r-- | data/rbot/plugins/games/uno.rb | 36 |
1 files changed, 29 insertions, 7 deletions
diff --git a/data/rbot/plugins/games/uno.rb b/data/rbot/plugins/games/uno.rb index 7a1477d2..f1573dc7 100644 --- a/data/rbot/plugins/games/uno.rb +++ b/data/rbot/plugins/games/uno.rb @@ -161,11 +161,15 @@ class UnoGame @players = [] @dropouts = [] @discard = nil + @value = nil + @color = nil make_base_stock @stock = [] make_stock @start_time = nil @join_timer = nil + @picker = 0 + @last_picker = 0 end def get_player(user) @@ -229,6 +233,14 @@ class UnoGame @start_time = Time.now end + def elapsed_time + if @start_time + Utils.secs_to_string(Time.now-@start_time) + else + _("no time") + end + end + def reverse_turn if @players.length > 2 @players.reverse! @@ -421,7 +433,7 @@ class UnoGame if @start_time announce _("This %{uno} game has been going on for %{time}") % { :uno => UNO, - :time => Utils.secs_to_string(Time.now - @start_time) + :time => elapsed_time } else announce _("The game hasn't started yet") @@ -551,12 +563,16 @@ class UnoGame announce _("%{p} gives up this game of %{uno}") % { :p => p, :uno => UNO } - if @players.length == 2 + case @players.length + when 2 if p == @players.first next_turn end end_game return + when 1 + end_game(true) + return end debug @stock.length while p.cards.length > 0 @@ -593,13 +609,19 @@ class UnoGame def end_game(halted = false) if halted - announce _("%{uno} game halted after %{time}") % { - :time => Utils.secs_to_string(Time.now-@start_time), - :uno => UNO - } + if @start_time + announce _("%{uno} game halted after %{time}") % { + :time => elapsed_time, + :uno => UNO + } + else + announce _("%{uno} game halted before it could start") % { + :uno => UNO + } + end else announce _("%{uno} game finished after %{time}! The winner is %{p}") % { - :time => Utils.secs_to_string(Time.now-@start_time), + :time => elapsed_time, :uno => UNO, :p => @players.first } end |