Language Server Settings
settings
for users migrating from pyright or pylance
with the exception of python.pythonPath
and python.venvPath
, settings prefixed with python.*
are not supported in basedpyright. use basedpyright.*
instead.
The basedpyright language server honors the following settings.
basedpyright.disableLanguageServices [boolean]: Disables all language services. This includes hover text, type completion, signature completion, find definition, find references, etc. This option is useful if you want to use pyright only as a type checker but want to run another Python language server for language service features.
basedpyright.disableOrganizeImports [boolean]: Disables the “Organize Imports” command. This is useful if you are using another extension that provides similar functionality and you don’t want the two extensions to fight each other.
basedpyright.disableTaggedHints [boolean]: Disables the use of hint diagnostics with special tags to tell the client to display text ranges in a "grayed out" manner (to indicate unreachable code or unreferenced symbols) or in a "strike through" manner (to indicate use of a deprecated feature).
basedpyright.openFilesOnly [boolean]: Determines whether pyright analyzes (and reports errors for) all files in the workspace, as indicated by the config file. If this option is set to true, pyright analyzes only open files. This setting is deprecated in favor of basedpyright.analysis.diagnosticMode. It will be removed at a future time.
basedpyright.useLibraryCodeForTypes [boolean]: This setting is deprecated in favor of basedpyright.analysis.useLibraryCodeForTypes. It will be removed at a future time.
basedpyright.analysis.autoImportCompletions [boolean]: Determines whether pyright offers auto-import completions.
Note
this setting is only for import suggestion completions, which are displayed as you type. it does not affect import suggestion code actions, which are tied to the reportUndefinedVariable
diagnostic rule. to disable those, you must disable the diagnostic rule itself.
basedpyright.analysis.autoSearchPaths [boolean]: Determines whether pyright automatically adds common search paths like "src" if there are no execution environments defined in the config file.
basedpyright.analysis.diagnosticMode ["openFilesOnly", "workspace"]: Determines whether pyright analyzes (and reports errors for) all files in the workspace, as indicated by the config file. If this option is set to "openFilesOnly", pyright analyzes only open files. Defaults to "openFilesOnly"
basedpyright.analysis.logLevel ["Error", "Warning", "Information", or "Trace"]: Level of logging for Output panel. The default value for this option is "Information".
python.pythonPath [path]: Path to Python interpreter. if you're using vscode, this setting is being deprecated by the VS Code Python extension in favor of a setting that is stored in the Python extension’s internal configuration store. Pyright supports both mechanisms but prefers the new one if both settings are present.
python.venvPath [path]: Path to folder with subdirectories that contain virtual environments. The python.pythonPath
setting is recommended over this mechanism for most users. For more details, refer to the import resolution documentation.
a note about python.venvPath
if your venv path is the same for all users working on your project (which should be the case if you're using uv or pdm), we recommend configuring venvPath
in a config file instead. see discouraged settings below for more information.
based settings
the following settings are exclusive to basedpyright
basedpyright.analysis.inlayHints.variableTypes [boolean]: Whether to show inlay hints on assignments to variables. Defaults to true
:
basedpyright.analysis.inlayHints.callArgumentNames [boolean]: Whether to show inlay hints on function arguments. Defaults to true
:
basedpyright.analysis.inlayHints.functionReturnTypes [boolean]: Whether to show inlay hints on function return types. Defaults to true
:
basedpyright.analysis.inlayHints.genericTypes [boolean]: Whether to show inlay hints on inferred generic types. Defaults to false
:
discouraged settings
these options can also be configured using a config file. it's recommended to use either a pyproject.toml
or pyrightconfig.json
file instead of the language server to configure type checking for the following reasons:
- the config should be the same for everybody working on your project. you should commit the config file so that other contributors don't have to manually configure their language server to match yours.
- it ensures that the basedpyright language server behaves the same as the
basedpyright
CLI, which is useful if you have your CI configured to type check your code (you should!)
however these settings are still suppored to maintain compatibility with pyright.
basedpyright.analysis.diagnosticSeverityOverrides [map]: Allows a user to override the severity levels for individual diagnostic rules. "reportXXX" rules in the type check diagnostics settings in configuration are supported. Use the rule name as a key and one of "error," "warning," "information," "true," "false," or "none" as value.
basedpyright.analysis.exclude [array of paths]: Paths of directories or files that should not be included. This can be overridden in the configuration file.
basedpyright.analysis.extraPaths [array of paths]: Paths to add to the default execution environment extra paths if there are no execution environments defined in the config file.
basedpyright.analysis.ignore [array of paths]: Paths of directories or files whose diagnostic output (errors and warnings) should be suppressed. This can be overridden in the configuration file.
basedpyright.analysis.include [array of paths]: Paths of directories or files that should be included. This can be overridden in the configuration file.
basedpyright.analysis.stubPath [path]: Path to directory containing custom type stub files.
basedpyright.analysis.typeCheckingMode ["off", "basic", "standard", "strict", "recommended", "all"]: Determines the default type-checking level used by pyright. This can be overridden in the configuration file. (Note: This setting used to be called "basedpyright.typeCheckingMode". The old name is deprecated but is still currently honored.)
basedpyright.analysis.typeshedPaths [array of paths]: Paths to look for typeshed modules. Pyright currently honors only the first path in the array.
basedpyright.analysis.useLibraryCodeForTypes [boolean]: Determines whether pyright reads, parses and analyzes library code to extract type information in the absence of type stub files. Type information will typically be incomplete. We recommend using type stubs where possible. The default value for this option is true.
where do i configure these settings?
the way you configure the basedpyright language server depends on your IDE. below are some examples for some of the supported editors. this is not a comprehensive list, so if your editor is missing, consult the documentation for its language server support.
vscode / vscodium
the basedpyright language server settings can be configured using a workspace or global settings.json
:
{
"basedpyright.analysis.diagnosticMode": "openFilesOnly"
}
neovim
The language server can be configured in your neovim settings:
require("lspconfig").basedpyright.setup {
settings = {
basedpyright = {
analysis = {
diagnosticMode = "openFilesOnly",
inlayHints = {
callArgumentNames = true
}
}
}
}
}
helix
[language-server.basedpyright]
command = "basedpyright-langserver"
args = ["--stdio"]
[language-server.basedpyright.config]
basedpyright.analysis.diagnosticMode = "openFilesOnly"
zed
{
"languages": {
"Python": {
"language_servers": ["basedpyright"]
}
},
"lsp": {
"basedpyright": {
"settings": {
"python": {
"pythonPath": ".venv/bin/python"
},
"basedpyright.analysis": {
"diagnosticMode": "openFilesOnly"
}
}
}
}
}
emacs
eglot
(use-package eglot
:ensure t
:config
(add-to-list 'eglot-server-programs '(
(python-mode python-ts-mode)
"basedpyright-langserver" "--stdio"
))
(setq-default
eglot-workspace-configuration
'(:basedpyright (
:typeCheckingMode "recommended"
)
:basedpyright.analysis (
:diagnosticSeverityOverrides (
:reportUnusedCallResult "none"
)
:inlayHints (
:callArgumentNames :json-false
)
)))
)