diff --git a/.github/workflows/lint.yml b/.github/workflows/lint.yml index 7a1908dea8..d7238f4c3c 100644 --- a/.github/workflows/lint.yml +++ b/.github/workflows/lint.yml @@ -21,7 +21,7 @@ jobs: pip install -r requirements/dev.txt - name: Setup cache id: cache-pylint - uses: actions/cache@v3 + uses: actions/cache@v4 with: path: .pylint.d key: pylint @@ -43,7 +43,7 @@ jobs: pip install -r requirements/dev.txt - name: Setup cache id: cache-mypy - uses: actions/cache@v3 + uses: actions/cache@v4 with: path: .mypy_cache key: mypy diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 020847ffc1..aa77843552 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -35,7 +35,7 @@ jobs: pip install -r requirements/dev.txt - name: Setup cache id: cache-pytest - uses: actions/cache@v3 + uses: actions/cache@v4 with: path: .pytest_cache key: ${{ matrix.os }}-${{ matrix.python-version }}-pytest diff --git a/CHANGELOG.md b/CHANGELOG.md index e8878fadad..fea137c75a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -205,6 +205,8 @@ These changes are available on the `master` branch, but have not yet been releas ([#2295](https://github.com/Pycord-Development/pycord/issues/2295)) - Fixed `AttributeError` when failing to establish initial websocket connection. ([#2301](https://github.com/Pycord-Development/pycord/pull/2301)) +- Fixed `AttributeError` caused by `command.cog` being `MISSING`. + ([#2303](https://github.com/Pycord-Development/pycord/issues/2303)) ## [2.4.1] - 2023-03-20 diff --git a/discord/commands/core.py b/discord/commands/core.py index c7bd4efd40..aff52c8108 100644 --- a/discord/commands/core.py +++ b/discord/commands/core.py @@ -846,7 +846,7 @@ def _is_typing_annotated(self, annotation): @property def cog(self): - return getattr(self, "_cog", MISSING) + return getattr(self, "_cog", None) @cog.setter def cog(self, val): @@ -1162,7 +1162,7 @@ def __init__( self._before_invoke = None self._after_invoke = None - self.cog = MISSING + self.cog = None self.id = None # Permissions @@ -1238,10 +1238,7 @@ def to_dict(self) -> dict: return as_dict def add_command(self, command: SlashCommand) -> None: - # check if subcommand has no cog set - # also check if cog is MISSING because it - # might not have been set by the cog yet - if command.cog is MISSING and self.cog is not MISSING: + if command.cog is None and self.cog is not None: command.cog = self.cog self.subcommands.append(command)