-
Notifications
You must be signed in to change notification settings - Fork 33
run mypy in the directory of the nearest pyproject.toml or mypy.ini #316
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
run mypy in the directory of the nearest pyproject.toml or mypy.ini #316
Conversation
|
@microsoft-github-policy-service agree company="Gridcog" |
8b68a2c to
2d84c25
Compare
karthiknadig
left a comment
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for the PR. Some minor changes and suggestions.
README.md
Outdated
| <td>mypy-type-checker.cwd</td> | ||
| <td><code>${workspaceFolder}</code></td> | ||
| <td>Sets the current working directory used to lint Python files with Mypy. By default, it uses the root directory of the workspace <code>${workspaceFolder}</code>. You can set it to <code>${fileDirname}</code> to use the parent folder of the file being linted as the working directory for Mypy. | ||
| <td>Sets the current working directory used to lint Python files with Mypy. By default, it uses the root directory of the workspace <code>${workspaceFolder}</code>. You can set it to <code>${fileDirname}</code> to use the parent folder of the file being linted as the working directory for Mypy. You can also set it to <code>${filePyproject}</code> to use the folder of the nearest parent <code>pyproject.toml</code>. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The name should likely be ${nearestConfig} since it does both pyproject and ini.
/cc @luabud
bundled/tool/lsp_server.py
Outdated
| return settings["workspaceFS"] | ||
|
|
||
| if settings["cwd"] == "${filePyproject}": | ||
| if document is None: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
we can probably move (document is None) case to the beginning of the function. Since it is common to all scenarios.
3b4e9cd to
add689d
Compare
|
hey, rebased on new main, fixed fmt lint and squash a couple of fixups, but PR checks need approval again sorry |
|
hi @jwhitaker-gridcog! Thanks for the submission- could you just make sure the linting check passes? Thanks! |
|
ty both, sorry i got the js fmt but missed py. also tweaked log messages. |
…ion as well Co-authored-by: Luciana Abud <[email protected]>
48070a4 to
43e8e46
Compare

This should fix the issues #190 and #259 .
Implements a new variable for
cwd,${filePyproject}${nearestConfig}. Ifcwdis set as such, then the lsp will search upwards from the current file for apyproject.tomlormypy.ini. If found, mypy will be run in its directory. If not found, it will run inworkspaceFolder.Questions:
that variable is ugly, should I call it something else?->${nearestConfig}mypy.ini?done)