Rewrote the command_system/implementation/custom.py
This commit is contained in:
parent
44fb0529d0
commit
7c1f4bf23e
|
@ -1,38 +1,56 @@
|
||||||
# Copyright (C) 2009-2010 Alexander Cherniuk <ts33kr@gmail.com>
|
# Copyright (c) 2009-2010, Alexander Cherniuk (ts33kr@gmail.com)
|
||||||
|
# All rights reserved.
|
||||||
#
|
#
|
||||||
# This program is free software: you can redistribute it and/or modify
|
# Redistribution and use in source and binary forms, with or without
|
||||||
# it under the terms of the GNU General Public License as published by
|
# modification, are permitted provided that the following conditions
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
# are met:
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
#
|
||||||
# This program is distributed in the hope that it will be useful,
|
# * Redistributions of source code must retain the above copyright
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
# notice, this list of conditions and the following disclaimer.
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
#
|
||||||
# You should have received a copy of the GNU General Public License
|
# * Redistributions in binary form must reproduce the above copyright
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
# notice, this list of conditions and the following disclaimer in the
|
||||||
|
# documentation and/or other materials provided with the distribution.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
# HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
"""
|
"""
|
||||||
The module contains examples of how to create your own commands, by
|
This module contains examples of how to create your own commands, by
|
||||||
creating a new command container and definding a set of commands.
|
creating a new command container, bounded to a specific command host,
|
||||||
|
and definding a set of commands inside of it.
|
||||||
|
|
||||||
Keep in mind that this module is not being loaded, so the code will not
|
Keep in mind that this module is not being loaded from anywhere, so the
|
||||||
be executed and commands defined here will not be detected.
|
code in here will not be executed and commands defined here will not be
|
||||||
|
detected.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from ..framework import CommandContainer, command, doc
|
from ..framework import CommandContainer, command, doc
|
||||||
from hosts import ChatCommands, PrivateChatCommands, GroupChatCommands
|
from hosts import *
|
||||||
|
|
||||||
class CustomCommonCommands(CommandContainer):
|
class CustomCommonCommands(CommandContainer):
|
||||||
"""
|
"""
|
||||||
|
The AUTOMATIC class variable, set to a positive value, instructs the
|
||||||
|
command system to automatically discover the command container and
|
||||||
|
enable it.
|
||||||
|
|
||||||
This command container bounds to all three available in the default
|
This command container bounds to all three available in the default
|
||||||
implementation command hosts. This means that commands defined in
|
implementation command hosts. This means that commands defined in
|
||||||
this container will be available to all - chat, private chat and a
|
this container will be available to all: chat, private chat and a
|
||||||
group chat.
|
group chat.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
HOSTS = (ChatCommands, PrivateChatCommands, GroupChatCommands)
|
AUTOMATIC = True
|
||||||
|
HOSTS = ChatCommands, PrivateChatCommands, GroupChatCommands
|
||||||
|
|
||||||
@command
|
@command
|
||||||
def dance(self):
|
def dance(self):
|
||||||
|
@ -46,45 +64,58 @@ class CustomCommonCommands(CommandContainer):
|
||||||
|
|
||||||
After all the documentation - there will be autogenerated (based
|
After all the documentation - there will be autogenerated (based
|
||||||
on the method signature) usage information appended. You can
|
on the method signature) usage information appended. You can
|
||||||
turn it off though, if you want.
|
turn it off, if you want.
|
||||||
"""
|
"""
|
||||||
return "I can't dance, you stupid fuck, I'm just a command system! A cool one, though..."
|
return "I don't dance."
|
||||||
|
|
||||||
class CustomChatCommands(CommandContainer):
|
class CustomChatCommands(CommandContainer):
|
||||||
"""
|
"""
|
||||||
This command container bounds only to the ChatCommands command host.
|
This command container bounds only to the ChatCommands command host.
|
||||||
Therefore command defined here will be available only to a chat.
|
Therefore commands defined inside of the container will be available
|
||||||
|
only to a chat.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
AUTOMATIC = True
|
||||||
HOSTS = (ChatCommands,)
|
HOSTS = (ChatCommands,)
|
||||||
|
|
||||||
@doc(_("The same as using a doc-string, except it supports translation"))
|
@command("squal", "bawl")
|
||||||
@command
|
|
||||||
def sing(self):
|
def sing(self):
|
||||||
return "Are you phreaking kidding me? Buy yourself a damn stereo..."
|
"""
|
||||||
|
This command has an additional aliases. It means the command will
|
||||||
|
be available under three names: sing (the native name), squal
|
||||||
|
(the first alias), bawl (the second alias).
|
||||||
|
|
||||||
|
You can turn off the usage of the native name, if you want, and
|
||||||
|
specify a name or a set of names, as aliases, under which a
|
||||||
|
command will be available.
|
||||||
|
"""
|
||||||
|
return "Buy yourself a stereo."
|
||||||
|
|
||||||
class CustomPrivateChatCommands(CommandContainer):
|
class CustomPrivateChatCommands(CommandContainer):
|
||||||
"""
|
"""
|
||||||
This command container bounds only to the PrivateChatCommands
|
This command container bounds only to the PrivateChatCommands
|
||||||
command host. Therefore command defined here will be available only
|
command host. Therefore commands defined inside of the container
|
||||||
to a private chat.
|
will be available only to a private chat.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
AUTOMATIC = True
|
||||||
HOSTS = (PrivateChatCommands,)
|
HOSTS = (PrivateChatCommands,)
|
||||||
|
|
||||||
@command
|
@command
|
||||||
|
@doc(_("The same as using a doc-string, except it supports translation"))
|
||||||
def make_coffee(self):
|
def make_coffee(self):
|
||||||
return "What do I look like, you ass? A coffee machine!?"
|
return "I'm not a coffee machine!"
|
||||||
|
|
||||||
class CustomGroupChatCommands(CommandContainer):
|
class CustomGroupChatCommands(CommandContainer):
|
||||||
"""
|
"""
|
||||||
This command container bounds only to the GroupChatCommands command
|
This command container bounds only to the GroupChatCommands command
|
||||||
host. Therefore command defined here will be available only to a
|
host. Therefore commands defined inside of the container will be
|
||||||
group chat.
|
available only to a group chat.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
AUTOMATIC = True
|
||||||
HOSTS = (GroupChatCommands,)
|
HOSTS = (GroupChatCommands,)
|
||||||
|
|
||||||
@command
|
@command
|
||||||
def fetch(self):
|
def fetch(self):
|
||||||
return "You should really buy yourself a dog and start torturing it instead of me..."
|
return "Buy yourself a dog."
|
Loading…
Reference in New Issue