summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorYaohan Chen <yaohan.chen@gmail.com>2007-11-26 04:25:19 +0000
committerYaohan Chen <yaohan.chen@gmail.com>2007-11-26 04:25:19 +0000
commit02d0166ba355be0419c39eea85f9f8dcf13f04d9 (patch)
treed254d1f4b0d9bfbf315c73e6b4e4a1cf980dba52
parent1ff0b683756532ff07023a7c17529c6a32cd3e99 (diff)
alias.rb:
* fix bug in alias checking code which prevented aliases with more than one parameters + reply with error message if mapping alias fails
-rw-r--r--data/rbot/plugins/alias.rb11
1 files changed, 8 insertions, 3 deletions
diff --git a/data/rbot/plugins/alias.rb b/data/rbot/plugins/alias.rb
index 289ef1ad..3339db7f 100644
--- a/data/rbot/plugins/alias.rb
+++ b/data/rbot/plugins/alias.rb
@@ -109,12 +109,17 @@ class AliasPlugin < Plugin
# each alias is implemented by adding a message map, whose handler creates a message
# containing the aliased command
- command.grep(/<(\w+)>/) {$1}.to_set ==
- text.grep(/(?:^|\s)[:*](\w+)(?:\s|$)/) {$1}.to_set or
+ command.scan(/<(\w+)>/).flatten.to_set ==
+ text.split.grep(/\A[:*](\w+)\Z/) {$1}.to_set or
raise AliasDefinitionError.new(_('The arguments in alias must match the substitutions in command, and vice versa'))
+ begin
+ map text, :action => :"alias_handle<#{text}>", :auth_path => 'run'
+ rescue
+ raise AliasDefinitionError.new(_('Error mapping %{text} as command: %{error}') %
+ {:text => text, :error => $!})
+ end
@aliases[text] = command
- map text, :action => :"alias_handle<#{text}>", :auth_path => 'run'
end
def respond_to?(name, include_private=false)