Kellen
0f18d93e47
Remove unused imports
3 years ago
Stocker
5aa696ccfa
Fix typing issues and improve typing completeness across the library
Co-authored-by: Danny <[email protected] >
Co-authored-by: Josh <[email protected] >
3 years ago
chromacoat dreamkey
095aaa9ad1
Change wording of InvalidArgument removal in docs
3 years ago
Josh
147948af9b
Use typing.Self throughout library
3 years ago
Josh
2b69b5d545
Remove discord.InvalidArgument
This uses TypeError and ValueError instead.
3 years ago
Josh
4dbe1af32f
Update sphinx and fix documentation issues
3 years ago
jack1142
783513726f
Add support for role icons
* Document ROLE_ICONS guild feature
https://github.com/discord/discord-api-docs/pull/3847
* Add support for role icons
https://github.com/discord/discord-api-docs/pull/3847
* Add support for role icon/emoji changes in audit log
https://github.com/discord/discord-api-docs/pull/3847
3 years ago
Rapptz
490bbffc93
Remove in-place edits and return fresh instances instead
Fixes #4098
4 years ago
Rapptz
9d4fa0341e
Fix typing of move role position payload parameter
4 years ago
Rapptz
2d7c709235
Rework Role.edit to not rely on previous role state
4 years ago
Rapptz
c475218112
Typehint Role and RoleTags
4 years ago
Rapptz
35bef7af38
Fix Role.is_assignable() computing Guild.me twice
4 years ago
TheOneMusic
9ba5745e68
Check for guild owner in Role.is_assignable()
4 years ago
Tyler
6c8f1ccbdf
Add Role.is_assignable()
4 years ago
Rapptz
1954861668
Add warning for comparing with role positioning
4 years ago
Nadir Chowdhury
757cfad38f
Type up **kwargs of various methods
4 years ago
Rapptz
d85805ab6d
First pass at supporting v8 API
4 years ago
Rapptz
99fc950510
Use f-strings in more places that were missed.
4 years ago
Nadir Chowdhury
89456022cf
Add `__all__` to remaining modules
4 years ago
Rapptz
9d39b135f4
Modernize code to use f-strings
This also removes the encoding on the top, since Python 3 does it by
default. It also changes some methods to use `yield from`.
4 years ago
Rapptz
272339d5e6
Add support for the new permission serialization scheme.
5 years ago
Nihaal Sangha
69bdc3a184
Change copyright year to present
4 years ago
Rapptz
e65dab3b23
Implement role tags.
This comes with:
* The RoleTags class
* Role.is_premium_subscriber()
* Role.is_bot_managed()
* Role.is_integration()
* Guild.self_role
* Guild.premium_subscriber_role
4 years ago
Michael
93fa46713a
Fix and add documentation
5 years ago
Anurag Singh
5769511779
allow passing color int to role.edit
5 years ago
Saurabh Chaturvedi
3faa9799e3
Fix documentation problem with color
At readthedocs.io, for role `color`, it says "Returns the role colour. An alias exists under `color`". This PR fixes that to say "Returns the role color. An alias exists under `colour`".
5 years ago
Rapptz
6071607176
Bump copyright year to 2020
Closes #2510
5 years ago
Rapptz
5c0b127c96
Create Permissions and Colour objects when necessary in Role
This should have some memory savings of ~24 bytes per role.
* 8 bytes for Permissions
* 8 bytes for Colour
* 8 bytes for the alias
I'm not sure how significant it is but it should be a decent amount.
6 years ago
NCPlayz
3c9bcc2851
Improve documentation
6 years ago
NCPlayz
fb02191b80
Organise documentation
6 years ago
Dante Dam
9656a21ebe
Bumped copyright years to 2019.
6 years ago
Rapptz
77239e4f15
Fix NameError and duplicate insertion bug when moving roles.
7 years ago
Rapptz
95d8bb2e85
Change internal representation of roles in Member and Emoji.
Introduce a new internal type, SnowflakeList, which has better memory
footprint over a regular list or set of roles. It is suspected that
there will be a 9x reduction of memory for every Emoji instance and a
48 byte saving per Member instance. However, these savings will
probably only be evident on larger bots.
As a consequence of this change, Member.roles is now computed lazily.
Currently I am not sure if I want to do the initial sorting on the
SnowflakeList for Member, as this comes with a O(n log n) cost when
creating a Member for little purpose since SnowflakeList.has is not
overly relied on. If CPU time becomes an issue this might change.
7 years ago
Rapptz
3d03dbc451
Change internal role storage in Guild to a dict instead of a list.
This adds the following APIs:
* Guild.get_role
This removes the following APIs:
* Guild.role_hierarchy
To compensate for the removed APIs, Guild.roles is now a sorted list
based on hierarchy. The first element will always be the @everyone
role.
This speeds up access at the cost of some memory, theoretically.
7 years ago
Rapptz
12cb074316
Take the default role property into account when comparing roles.
7 years ago
Hornwitser
c8b49d37be
[lint] Fix incorrect and inconsistent whitespace
Adjust whitespace to be consistent with the rest of the library.
7 years ago
Hornwitser
d58fc0ccee
[lint] Remove unused imports
Left over from various refactoring and rewrites.
7 years ago
Rapptz
f25091efe1
Drop support for Python 3.4 and make minimum version 3.5.2.
7 years ago
Steve C
0e945915b7
Fixes various documentation errors/inconsistencies
Mostly dealing with permissions, also fixes Raw Events inclusion.
7 years ago
Tobotimus
3112e1c17e
Add intersphinx
7 years ago
Rapptz
f4e01b3a92
Make supported operations stand out more than attributes.
8 years ago
Rapptz
f73eb087c9
Use describe instead of tables for supported operations.
8 years ago
Rapptz
dff6bcc745
Add support for audit log reasons.
Most routes now have a 'reason' keyword argument.
8 years ago
Rapptz
d24c2a09b6
Change some format usage to use %-formatting.
Minor speed increase when we're not doing excessive attribute
access or any type of formatting.
8 years ago
Rapptz
c30ab8a3e5
Fix NameError in Role.edit when moving roles.
8 years ago
Rapptz
fde35848f6
Make Role.members use a list comprehension.
8 years ago
Rapptz
96a43fa9e3
Fix NameError in Role.edit
8 years ago
Rapptz
aa59762c04
Remove extra space.
8 years ago
Rapptz
81baafa1e2
Change Role.is_everyone to Role.is_default.
8 years ago
Rapptz
e77012f4d9
Make all public is_ functions into methods instead of properties.
8 years ago