diff options
author | Giuseppe Bilotta <giuseppe.bilotta@gmail.com> | 2008-04-10 14:48:22 +0200 |
---|---|---|
committer | Giuseppe Bilotta <giuseppe.bilotta@gmail.com> | 2008-04-10 14:48:22 +0200 |
commit | 1a5651d2ea7dbd4d385c97727db2029dd3c9c5c5 (patch) | |
tree | 36d8595bd5b08b96d2d4f9b0f68d5182a3bdbd83 /data/rbot/plugins/games/uno.rb | |
parent | 201333cdd1a74ecd5a74fb53c2b6a37fb25e52b5 (diff) |
uno plugin: player replacement
Diffstat (limited to 'data/rbot/plugins/games/uno.rb')
-rw-r--r-- | data/rbot/plugins/games/uno.rb | 37 |
1 files changed, 36 insertions, 1 deletions
diff --git a/data/rbot/plugins/games/uno.rb b/data/rbot/plugins/games/uno.rb index a8c22cad..c22dc8a1 100644 --- a/data/rbot/plugins/games/uno.rb +++ b/data/rbot/plugins/games/uno.rb @@ -126,7 +126,7 @@ class UnoGame class Player attr_accessor :cards - attr_reader :user + attr_accessor :user def initialize(user) @user = user @cards = [] @@ -566,6 +566,31 @@ class UnoGame @dropouts << @players.delete_one(p) end + def replace_player(old, new) + # The new user + user = channel.get_user(new) + if p = get_player(user) + announce _("%{p} is already playing %{uno} here") % { + :p => p, :uno => UNO + } + return + end + # We scan the player list of the player with the old nick, instead + # of using get_player, in case of IRC drops etc + @players.each do |p| + if p.user.nick == old + p.user = user + announce _("%{p} takes %{b}%{old}%{b}'s place at %{uno}") % { + :p => p, :b => Bold, :old => old, :uno => UNO + } + return + end + end + announce _("%{b}%{old}%{b} isn't playing %{uno} here") % { + :uno => UNO, :b => Bold, :old => old + } + end + def end_game(halted = false) if halted announce _("%{uno} game halted after %{time}") % { @@ -732,6 +757,14 @@ class UnoPlugin < Plugin @games.delete(channel) end + def replace_player(m, p) + unless @games.key?(m.channel) + m.reply _("There is no %{uno} game running here") % { :uno => UnoGame::UNO } + return + end + @games[m.channel].replace_player(p[:old], p[:new]) + end + def drop_player(m, p) unless @games.key?(m.channel) m.reply _("There is no %{uno} game running here") % { :uno => UnoGame::UNO } @@ -761,8 +794,10 @@ pg.map 'uno end', :private => false, :action => :end_game pg.map 'uno drop', :private => false, :action => :drop_player pg.map 'uno giveup', :private => false, :action => :drop_player pg.map 'uno drop :nick', :private => false, :action => :drop_player, :auth_path => ':other' +pg.map 'uno replace :old [with] :new', :private => false, :action => :replace_player pg.map 'uno stock', :private => false, :action => :print_stock pg.default_auth('stock', false) pg.default_auth('end', false) pg.default_auth('drop::other', false) +pg.default_auth('replace', false) |