Commit Graph

634 Commits

Author SHA1 Message Date
Rapptz
d33d0bed69 Add support for async for in Client.logs_from.
This is a breaking change. Code will still work in Python 3.4 as-is but
if you use Python 3.5 you will have to change your code to the new
`async for` syntax as the older version is not supported in 3.5.

On the other hand, this comes with performance improvements if you use
Python 3.5 as it will lazily load 100 message chunks on an as needed
basis rather than loading all messages in one go.
2016-01-14 15:42:56 -05:00
Rapptz
bc7606a42c [commands] Add on_command and on_command_completion events. 2016-01-14 12:49:42 -05:00
Rapptz
855fa7e553 Documentation fixes for Permissions related code. 2016-01-14 12:24:59 -05:00
Rapptz
41d8dc63f4 [commands] Change behaviour of consume rest to be more useful.
You can get back the old behaviour by passing in `rest_is_raw` to the
command attributes.
2016-01-14 03:11:28 -05:00
Rapptz
18c71ab57c [commands] Fix issue where Bot would raise if not given a description. 2016-01-14 01:25:40 -05:00
Rapptz
b1d8e12609 [commands] Cleanup descriptions being passed. 2016-01-13 22:05:21 -05:00
Rapptz
4edff12f6b Proper exception chaining. 2016-01-13 20:08:55 -05:00
Khazhismel
bbe6455eb9 Guild member add will include deaf and mute now, do not provide default values 2016-01-12 11:49:22 -05:00
Khazhismel
000e7e57ea Change member constructor to not rely on order of json data object 2016-01-12 11:45:59 -05:00
Rapptz
8d76e7095e Basic bot example now shows documenting for the built-in help command. 2016-01-12 01:29:37 -05:00
Rapptz
31db6efc7f [commands] Fix handling of nested subcommand help handling. 2016-01-12 01:17:27 -05:00
Rapptz
c29f0ea544 [commands] Fix keyword-only case to actually do conversion. 2016-01-12 01:06:53 -05:00
Rapptz
b335e9ea30 [commands] Support invoking the help command with a cog name. 2016-01-12 00:45:45 -05:00
Rapptz
958d278771 [commands] Initial implementation of help command. 2016-01-11 23:59:11 -05:00
Rapptz
4ea015067f Handle cases where people put False-like values for game presences. 2016-01-11 19:50:13 -05:00
Rapptz
8974dffc4e Change internal update functions to have a leading underscore. 2016-01-11 14:44:13 -05:00
Rapptz
c49efc5412 [commands] Add Command.cog_name to get the cog name it belongs to. 2016-01-11 00:35:07 -05:00
Rapptz
1e941925c2 [commands] Add Command.clean_params to have nicer params.
These are params without the self/context parameters. Useful for
showing signature information in the help command without being
bogged down by knowing if the self/context parameters are there.
Hence it makes it easier to iterate knowing that you shouldn't care
about those two parameters.
2016-01-10 22:10:42 -05:00
Rapptz
a706c47f34 [commands] Remove all aliases if the main command is being deleted. 2016-01-10 20:08:13 -05:00
Rapptz
2c31c466b2 Fix Client.remove_roles to actually remove roles. 2016-01-10 03:19:41 -05:00
Rapptz
50c83b5a3c [commands] Strip arguments before searching for special cases. 2016-01-10 02:56:24 -05:00
Rapptz
efcc55bd32 [commands] Proper cleanup of cogs. 2016-01-10 02:26:57 -05:00
Rapptz
38bac7fa86 [commands] Add Group.invoke_without_command. 2016-01-10 01:52:51 -05:00
Rapptz
c6b31c9663 Attempt to satisfy RTD by using sphinxcontrib.napoleon. 2016-01-10 00:39:48 -05:00
Rapptz
604e931367 Add a Whats New page to have a nicer changelog. 2016-01-09 23:13:23 -05:00
Rapptz
b87d5e5337 [commands] Add basic support for extensions. 2016-01-09 18:33:37 -05:00
Rapptz
0a07fc088c [commands] Inject the internal variables for bot.say & co explicitly.
This is to catch cases where it wouldn't fail to find it when
inspecting the stack to catch these stack variables.
2016-01-09 15:16:28 -05:00
Rapptz
ad800e248b [commands] Add local error handlers. 2016-01-09 14:00:17 -05:00
Rapptz
b2e0632553 [commands] Propagate invoked_with to subcommands. 2016-01-09 12:24:01 -05:00
Rapptz
ec6b1997ad [commands] Add support for cogs.
Cogs are basically class instances that have commands and event
listeners. They allow for better organisation and grouping of
commands and state. Similar to subclassing discord.Client.
2016-01-09 02:18:03 -05:00
Rapptz
968e5514cb Update README to only point to async installation. 2016-01-08 22:41:09 -05:00
Rapptz
c06dbbd1f0 [commands] Add support for registering more than one event listener. 2016-01-08 20:37:13 -05:00
Rapptz
52eb0e3adb [commands] Change prefix callback signature and add when_mentioned.
The utility allows for easy addition of "when the bot is mentioned"
as the prefix. The change of signature was to facilitate this.
2016-01-08 19:40:00 -05:00
Rapptz
af94179be5 Change order of documentation by source declaration. 2016-01-08 19:19:53 -05:00
Rapptz
93e3c360a7 Fix conflicts with __slots__ and the new properties under Server. 2016-01-08 15:31:06 -05:00
Rapptz
a1a47c6f38 Document the breaking change with the new dictionary storage change.
Since the only things dict views support are iteration we should
advise people who want the old behaviour to change it to a list.
2016-01-08 14:04:58 -05:00
Rapptz
6d5175ad9a Document how Client.run should be the last function to call. 2016-01-08 13:31:03 -05:00
Steven Berler
777b5a09e2 document public get_ methods and make others private 2016-01-08 13:24:56 -05:00
Steven Berler
10b0b62f50 performance improvements
Replaced server member lists, channel lists, and private channel lists
with dicts. This allows O(1) lookups and removes (previously it would be
an O(N) operation to lookup or remove). I did pretty extensive testing
and benchmarking to compare the performance of using lists vs using
dicts. Iterating through lists to find an item is only faster in the
average case for extremely small lists (less than 3 items). For 100
items, using a dict is about 10 times faster on average (and about 100
times faster for 1000 items). The overhead in dicts is in memory usage
and initial creation time. Creating and populating a dict is about 2 to
3 times slower than creating and appending items to a list. However this
cost is still tiny.  For 1000 items this equates to about a 70
microsecond difference (on an i7 CPU) for populating the entire dict.
The memory overhead for a dict (compared to a list) is about 25-60 KB
per 1000 items (can vary depending on dict resizing).

Originally I wanted to use OrderedDicts to presereve order, but in my
testing OrderedDicts have about 6x the memory overhead compared to
normal dicts.
2016-01-08 13:24:55 -05:00
Rapptz
25588955e4 [commands] Add a way to enable or disable certain commands. 2016-01-07 17:59:26 -05:00
Rapptz
b79a4549ab [commands] Special handling for when the converter is bool. 2016-01-07 17:31:56 -05:00
Rapptz
542ddc4938 [commands] Allow registration of multiple command prefixes. 2016-01-07 16:20:33 -05:00
Rapptz
a2b97ae2db Fix handling of embed-only MESSAGE_UPDATE. 2016-01-07 02:54:01 -05:00
Rapptz
5ca13cac8e Add Message.nonce attribute. 2016-01-07 02:06:11 -05:00
Rapptz
0fbb58cde9 Change the way MESSAGE_UPDATE events are handled.
Previously we created a copy of the object and did some strange
iteration over the data and set the attributes that we thought
were valid. This worked back then in v0.1.0 of the library when
it was written, but it no longer works nowadays when we want to
be as future proof as possible.
2016-01-07 01:27:38 -05:00
Rapptz
6ddfbc4b36 Add missing roles attribute to Server.__slots__ 2016-01-07 00:57:04 -05:00
Rapptz
9d881ad475 Add missing documentation for discord.Game 2016-01-07 00:25:18 -05:00
Rapptz
e88bc28236 Documentation fixes to quiet Sphinx warnings. 2016-01-07 00:21:00 -05:00
Rapptz
2fd63fc3dd Document the fact that data classes use __slots__. 2016-01-07 00:13:38 -05:00
Rapptz
89a418a388 Add __slots__ for missing classes that didn't have it. 2016-01-06 23:40:20 -05:00