.. _plugin-Aka: Aka === Purpose ------- This plugin allows the user to create various aliases (known as "Akas", since Alias is the name of another plugin Aka is based on) to other commands or combinations of other commands (via nested commands). Usage ----- This plugin allows users to define aliases to commands and combinations of commands (via nesting). Importing from Alias ^^^^^^^^^^^^^^^^^^^^ Add an aka, Alias, which eases the transitioning to Aka from Alias. First we will load Alias and Aka:: @load Alias jamessan: The operation succeeded. @load Aka jamessan: The operation succeeded. Then we import the Alias database to Aka in case it exists and unload Alias:: @importaliasdatabase jamessan: The operation succeeded. @unload Alias jamessan: The operation succeeded. And now we will finally add the Aka ``alias`` itself:: @aka add "alias" "aka $1 $*" jamessan: The operation succeeded. Now you can use Aka as you used Alias before. Trout ^^^^^ Add an aka, ``trout``, which expects a word as an argument:: @aka add trout "reply action slaps $1 with a large trout" jamessan: The operation succeeded. @trout me * bot slaps me with a large trout This ``trout`` aka requires the plugin ``Reply`` to be loaded since it provides the ``action`` command. Random percentage ^^^^^^^^^^^^^^^^^ Add an aka, ``randpercent``, which returns a random percentage value:: @aka add randpercent "squish [dice 1d100]%" This requires the ``Filter`` and ``Games`` plugins to be loaded. Note that nested commands in an alias should be quoted, or they will only run once when you create the alias, and not each time the alias is called. (In this case, not quoting the nested command would mean that ``@randpercent`` always responds with the same value!) .. _commands-Aka: Commands -------- .. _command-aka-add: add [--channel <#channel>] Defines an alias that executes . The should be in the standard "command argument [nestedcommand argument]" arguments to the alias; they'll be filled with the first, second, etc. arguments. $1, $2, etc. can be used for required arguments. @1, @2, etc. can be used for optional arguments. $* simply means "all arguments that have not replaced $1, $2, etc.", ie. it will also include optional arguments. .. _command-aka-remove: remove [--channel <#channel>] Removes the given alias, if unlocked. .. _command-aka-lock: lock [--channel <#channel>] Locks an alias so that no one else can change it. .. _command-aka-unlock: unlock [--channel <#channel>] Unlocks an alias so that people can define new aliases over it. .. _command-aka-importaliasdatabase: importaliasdatabase takes no arguments Imports the Alias database into Aka's, and clean the former. .. _command-aka-show: show [--channel <#channel>] This command shows the content of an Aka. .. _command-aka-list: list [--channel <#channel>] [--keys] [--unlocked|--locked] Lists all Akas defined for . If is not specified, lists all global Akas. If --keys is given, lists only the Aka names and not their commands. .. _command-aka-set: set [--channel <#channel>] Overwrites an existing alias to execute instead. The should be in the standard "command argument [nestedcommand argument]" arguments to the alias; they'll be filled with the first, second, etc. arguments. $1, $2, etc. can be used for required arguments. @1, @2, etc. can be used for optional arguments. $* simply means "all arguments that have not replaced $1, $2, etc.", ie. it will also include optional arguments. .. _command-aka-search: search [--channel <#channel>] Searches Akas defined for . If is not specified, searches all global Akas. .. _conf-Aka: Configuration ------------- .. _conf-supybot.plugins.Aka.maximumWordsInName: supybot.plugins.Aka.maximumWordsInName This config variable defaults to "5", is not network-specific, and is not channel-specific. The maximum number of words allowed in a command name. Setting this to an high value may slow down your bot on long commands. .. _conf-supybot.plugins.Aka.public: supybot.plugins.Aka.public This config variable defaults to "True", is not network-specific, and is not channel-specific. Determines whether this plugin is publicly visible. .. _conf-supybot.plugins.Aka.web: supybot.plugins.Aka.web This is a group of: .. _conf-supybot.plugins.Aka.web.enable: supybot.plugins.Aka.web.enable This config variable defaults to "False", is not network-specific, and is not channel-specific. Determines whether the Akas will be browsable through the HTTP server.