refactor: Rewrite the role tags mess#2708
refactor: Rewrite the role tags mess#2708Paillat-dev wants to merge 12 commits intoPycord-Development:masterfrom
Conversation
20d75bb to
696dcbf
Compare
plun1331
left a comment
There was a problem hiding this comment.
This looks really easy to make backwards compatible, can we just do that and deprecate all the compatibility methods?
|
Yeah maybe i'll try, but it sucks when I reused method names to become properties |
|
What are your thoughts on adding something like an enum, e.g. |
|
As we previously talked on dcs, the role type enum is the best way. Like plun said, deprecated all current methods and just create the type on role. But the docs should clarify that it's calculated since it's not returned by discord |
0c18960 to
7e7d40e
Compare
7e7d40e to
5810fa3
Compare
27a15ee to
54f1baa
Compare
|
Here is a handy snippet for testing this: import logging
import os
from datetime import datetime, UTC
from dotenv import load_dotenv
import discord
load_dotenv()
logging.basicConfig(level=logging.DEBUG)
TOKEN = os.getenv("TOKEN_3")
bot = discord.Bot()
@bot.slash_command()
async def test_roles(ctx: discord.ApplicationContext, role: discord.Role):
await ctx.defer()
if not ctx.guild:
return await ctx.respond("This command must be used in a guild.")
fetched_role = await ctx.guild.fetch_role(role.id)
await ctx.respond(f"""```
Role:
{role!r}
Role tags:
{role.tags!r}
Role tags data:
{role.tags._data if role.tags else None}
Fetched role:
{fetched_role!r}
Fetched role tags:
{fetched_role.tags!r}
Fetched role tags data:
{fetched_role.tags._data if fetched_role.tags else None}
```""")
bot.run(TOKEN) |
|
Do not merge yet |
c41d7ee to
2dc7e65
Compare
|
Any news on this topic ? |
|
@Lulalaby Any news on this btw ? |
|
not yet :( |
b55c125 to
82659b2
Compare
|
@Lulalaby News on this 2 ? |
|
Nope. Still a mess |
|
rewrite it in rust atp |
|
Yeah. Idk @Lulalaby do you maybe have some updates ? If not, I'm gonna see if I can clean this up again and we can maybe merge it as is, because it technically works except for one specific edge case (see the enum's documentation). What do yall think ? |
|
Yes no news here :/ lets go with that (after u fixed conflicts) |
Summary
Rewrite the role tags mess.

Information
examples, ...).
Checklist
type: ignorecomments were used, a comment is also left explaining why.