poezio/plugins/alias.py

102 lines
3.2 KiB
Python
Raw Normal View History

"""
Installation
------------
You only have to load the plugin:
``/load alias``
Usage
-----
This plugin defines two new global commands: :term:`/alias` and :term:`/unalias`.
.. glossary::
/alias
**Usage:** ``/alias <name> <command> [args]``
This command will create a new command, named ``name`` (and callable with
``/name``), that runs ``/command``, with ``[args]`` as fixed args for the command.
When you run the alias, you can also pass parameters to it, that will be fed
to the original command.
Example: ::
/alias toto say "koin "
Will bind ``/say koin `` to ``/toto``, so this alias will work in any
Chat tab. If someone calls it with ::
/toto koin
Poezio will then execute ``/say koin koin``.
/unalias
**Usage:** ``/unalias <name>``
This command removes a defined alias.
"""
2011-10-02 11:22:13 +00:00
from plugin import BasePlugin
import common
from common import shell_split
2011-10-02 11:22:13 +00:00
class Plugin(BasePlugin):
def init(self):
self.api.add_command('alias', self.command_alias,
usage='<alias> <command> [args]',
short='Create an alias command',
help='Create an alias for <command> with [args].')
self.api.add_command('unalias', self.command_unalias,
usage='<alias>',
help='Remove a previously created alias',
short='Remove an alias',
completion=self.completion_unalias)
2011-10-02 11:22:13 +00:00
self.commands = {}
def command_alias(self, line):
"""
/alias <alias> <command> [args]
"""
arg = common.shell_split(line)
2011-10-02 11:22:13 +00:00
if len(arg) < 2:
self.api.information('Alias: Not enough parameters', 'Error')
2011-10-02 11:22:13 +00:00
return
alias = arg[0]
command = arg[1]
tmp_args = arg[2] if len(arg) > 2 else ''
2011-10-02 11:22:13 +00:00
if alias in self.core.commands or alias in self.commands:
self.api.information('Alias: command already exists', 'Error')
2011-10-02 11:22:13 +00:00
return
self.commands[alias] = lambda arg: self.get_command(command)(tmp_args + arg)
self.api.add_command(alias, self.commands[alias], 'This command is an alias for /%s %s' %( command, tmp_args))
self.api.information('Alias /%s successfuly created' % alias, 'Info')
2011-10-02 11:22:13 +00:00
def command_unalias(self, alias):
"""
/unalias <existing alias>
"""
2011-10-02 11:22:13 +00:00
if alias in self.commands:
del self.commands[alias]
self.api.del_command(alias)
self.api.information('Alias /%s successfuly deleted' % alias, 'Info')
2011-10-02 11:22:13 +00:00
def completion_unalias(self, the_input):
aliases = [alias for alias in self.commands]
aliases.sort()
return the_input.auto_completion(aliases, '', quotify=False)
2011-10-02 11:22:13 +00:00
def get_command(self, name):
"""Returns the function associated with a command"""
def dummy(args):
"""Dummy function called if the command doesnt exist"""
pass
if name in self.core.commands:
return self.core.commands[name][0]
elif name in self.api.current_tab().commands:
return self.api.current_tab().commands[name][0]
2011-10-02 11:22:13 +00:00
return dummy