Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Allow ruff to be used as a formatter #216

Merged
merged 3 commits into from
Dec 19, 2024

Conversation

DarkaMaul
Copy link
Contributor

Until astral-sh/ruff#659 is implemented, it could still be helpful to use ruff to format the signatures.

Feel free to close the PR if you believe the perf impact is too big when spanning multiple subprocesses.

@pawamoy
Copy link
Member

pawamoy commented Dec 13, 2024

Thanks! I tried it in a project that renders quite a lot of docstrings, and I don't see any flagrant perf hit.

@pawamoy
Copy link
Member

pawamoy commented Dec 13, 2024

Thanks! I tried it in a project that renders quite a lot of docstrings, and I don't see any flagrant perf hit.

Something might be missing though: the signatures aren't actually formatted 😅 Does it work on your side?

@pawamoy
Copy link
Member

pawamoy commented Dec 13, 2024

Once I add and use the _find_ruff util, I then get this process error:

CalledProcessError(2, ['/media/data/dev/griffe/.venv/bin/ruff', 'format', '--config "line-length=60"', '--stdin-filename', 'file.py', '-'])

Its stderr is:

'error: unexpected argument '--config "line-length' found\n\n tip: a similar argument exists: '--config'\n\nUsage: ruff format --config <CONFIG_OPTION> [FILES]...\n\nFor more information, try '--help'.\n'

I guess we simply have to split that.

@pawamoy
Copy link
Member

pawamoy commented Dec 13, 2024

OK working with the suggestion above. Let me re-check the perfs. UPDATE: same, no perf hit.

@DarkaMaul
Copy link
Contributor Author

Before merging the PR (if that goes through), the documentation needs to be updated (and some of the docstrings) to reflect that now it can also use ruff when black is not found.

docs/schema.json Outdated Show resolved Hide resolved
@DarkaMaul DarkaMaul force-pushed the dm/add-ruff-formatter branch from d86eb0e to 4fc2f4a Compare December 16, 2024 13:20
@pawamoy
Copy link
Member

pawamoy commented Dec 19, 2024

Thanks! Looking great 🙂 I just noticed a "bug" within the code that handles cross-references in signatures: the code currently replaces **kwargs with a unique id. The issue is that Ruff then sees something like _FRmWcKw, and will complain that it doesn't have a default value while following other parameters with default values. Black doesn't seem to care about this.

def xxxxxxxxxxxxx(_N8CL: _8E, _CaOSB3U7V0pPKKf: _r9 | None = None, _qIcd: _cE3[_uQ] | None = None, _iaxfH: _pI = 'en', _kCT1PbcXbF3Nhl5kcSLp: _cIW | None = None, _FrMwcKw: _LW): pass
error: Failed to parse file.py:1:163: Parameter without a default cannot follow a parameter with a default

We should fix this before merging 🤔 I'll do this in another commit/PR. We'll probably have to modify the param_crossref Jinja macro in _base/expression.html.jinja to leave star characters outside of cross-references. Or maybe the unique ids could simply keep stars.

pawamoy added a commit that referenced this pull request Dec 19, 2024
@pawamoy
Copy link
Member

pawamoy commented Dec 19, 2024

Done, merging!

@pawamoy pawamoy merged commit d67215c into mkdocstrings:main Dec 19, 2024
26 checks passed
@pawamoy
Copy link
Member

pawamoy commented Dec 19, 2024

Thanks again @DarkaMaul 🚀

@lucas-nelson-uiuc
Copy link

Happy this is moving along - was just thinking about this

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants