Summary -- Release highlights¶
With 2.14 pylint only supports Python version 3.7.2 and above.
We introduced several new checks among which duplicate-value for sets,
comparison-of-constants, and checks related to lambdas. We removed no-init and
made no-self-use optional as they were too opinionated. We also added an option
to generate a toml configuration: --generate-toml-config.
We migrated to argparse from optparse and refactored the configuration handling
thanks to Daniël van Noord. On the user side it should change the output of the
--help command, and some inconsistencies and bugs should disappear. The behavior
between options set in a config file versus on the command line will be more consistent. For us,
it will permit to maintain this part of the code easily in the future and anticipate
optparse's removal in Python 3.12.
As a result of the refactor there are a lot of internal deprecations. If you're a library maintainer that depends on pylint, please verify that you're ready for pylint 3.0 by activating deprecation warnings.
We continued the integration of pylint-error and are now at 33%!. We still welcome any community effort
to help review, integrate, and add good/bad examples <https://github.com/PyCQA/pylint/issues/5953>`_. This should be doable
without any pylint or astroid knowledge, so this is the perfect entrypoint if you want
to contribute to pylint or open source without any experience with our code!
New checkers¶
Added new checker
comparison-of-constants.Closes #6076
Added new checker
typevar-name-mismatch: TypeVar must be assigned to a variable with the same name as its name argument.Closes #5224
invalid-enum-extension: Used when a class tries to extend an inherited Enum class.Closes #5501
Added new checker
typevar-double-variance: The "covariant" and "contravariant" keyword arguments cannot both be set to "True" in a TypeVar.Closes #5895
Add new check
unnecessary-dunder-callfor unnecessary dunder method calls.Closes #5936
unnecessary-lambda-assignment: Lambda expression assigned to a variable. Define a function using the "def" keyword instead.unnecessary-direct-lambda-call: Lambda expression called directly. Execute the expression inline instead.Closes #5976
potential-index-error: Emitted when the index of a list or tuple exceeds its length. This checker is currently quite conservative to avoid false positives. We welcome suggestions for improvements.Closes #578
Added new checker
unnecessary-list-index-lookupfor indexing into a list while iterating overenumerate().Closes #4525
Added new message called
duplicate-valuewhich identifies duplicate values inside sets.Closes #5880
Added the
super-without-bracketschecker, raised when a super call is missing its brackets.Closes #4008
Removed checkers¶
The
no-init(W0232) warning has been removed. It's ok to not have an__init__in a class.Closes #2409
Removed the
assign-to-new-keywordmessage as there are no new keywords in the supported Python versions any longer.Closes #4683
Moved
no-self-usecheck to optional extension. You now need to explicitly enable this check usingload-plugins=pylint.extensions.no_self_use.Closes #5502
Extensions¶
RedefinedLoopNameCheckerAdded optional extension
redefined-loop-nameto emit messages when a loop variable is redefined in the loop body.
Closes #5072
DocStringStyleCheckerRe-enable checker
bad-docstring-quotesfor Python <= 3.7.
Closes #6087
NoSelfUseCheckerAdded
no-self-usecheck, previously enabled by default.
Closes #5502
Other Changes¶
Started ignoring underscore as a local variable for
too-many-locals.Closes #6488
Pylint can now be installed with an extra-require called
spelling(pip install pylint[spelling]). This will addpyenchantto pylint's dependencies. You will still need to install the requirements forpyenchant(theenchantlibrary and any dictionaries) yourself. You will also need to set thespelling-dictoption.Refs #6462
Improved wording of the message of
deprecated-moduleCloses #6169
Pylintnow requires Python 3.7.2 or newer to run.Closes #4301
We made a greater effort to reraise failures stemming from the
astroidlibrary asAstroidError, with the effect that pylint emitsastroid-errorrather than merelyfatal. Regardless, please report any such issues you encounter!We have improved our recognition of inline disable and enable comments. It is now possible to disable
bad-option-valueinline (as long as you disable it before the bad option value is raised, i.e.disable=bad-option-value,bad-messagenotdisable=bad-message,bad-option-value) as well as certain other previously unsupported messages.Closes #3312
The main checker name is now
maininstead ofmaster. The configuration does not need to be updated as sections' name are optional.Closes #5467
Update
invalid-slots-objectmessage to show bad object rather than its inferred value.Closes #6101
Fixed a crash in the
not-an-iterablechecker involving multiple starred expressions inside a call.Closes #6372
Fixed a crash in the
unused-private-memberchecker involving chained private attributes.Closes #6709
Disable spellchecking of mypy rule names in ignore directives.
Closes #5929
implicit-str-concatwill now be raised on calls likeopen("myfile.txt" "a+b")too.Closes #6441
Fix a failure to respect inline disables for
fixmeoccurring on the last line of a module when pylint is launched with--enable=fixme.Removed the broken
generate-manoption.Closes #5283 Closes #1887
Fixed failure to enable
deprecated-moduleafter adisable=allby makingImportsCheckersolely responsible for emittingdeprecated-moduleinstead of sharing responsibility withStdlibChecker. (This could have led to double messages.)Added the
generate-toml-configoption.Refs #5462
bad-option-valuewill be emitted whenever a configuration value or command line invocation includes an unknown message.Closes #4324
Added the
unrecognized-optionmessage. Raised if we encounter any unrecognized options.Closes #5259
Fix false negative for
bad-string-format-typeif the value to be formatted is passed in as a variable holding a constant.The concept of checker priority has been removed.
The
cache-max-size-nonechecker has been renamed tomethod-cache-max-size-none.Closes #5670
The
method-cache-max-size-nonechecker will now also checkfunctools.cache.Closes #5670
BaseCheckerclasses now require thelinterargument to be passed.The
set_config_directlydecorator has been removed.Don't report
useless-super-delegationfor the__hash__method in classes that also override the__eq__method.Closes #3934
Fix falsely issuing
useless-suppressionon thewrong-import-positionchecker.Closes #5219
Fixed false positive
no-memberfor Enums with self-defined members.Closes #5138
Fix false negative for
no-memberwhen attempting to assign an instance attribute to itself without any prior assignment.Closes #1555
Changed message type from
redefined-outer-nametoredefined-loop-name(optional extension) for redefinitions of outer loop variables by inner loops.Closes #5608
By default the similarity checker will now ignore imports and ignore function signatures when computing duplication. If you want to keep the previous behaviour set
ignore-importsandignore-signaturestoFalse.Pylint now expands the user path (i.e.
~tohome/yusef/) and expands environment variables (i.e.home/$USER/$projecttohome/yusef/pylintforUSER=yusefandproject=pylint) for pyreverse'soutput-directory,import-graph,ext-import-graph,int-import-graphoptions, and the spell checker'sspelling-private-dict-fileoption.Refs #6493
Don't emit
unsubscriptable-objectfor string annotations. Pylint doesn't check if class is only generic in type stubs only.Closes #4369 and #6523
Fix pyreverse crash
RuntimeError: dictionary changed size during iterationRefs #6612
Fix syntax for return type annotations in MermaidJS diagrams produced with
pyreverse.Closes #6467
Fix type annotations of class and instance attributes using the alternative union syntax in
pyreversediagrams.Fix bug where it writes a plain text error message to stdout, invalidating output formats.
Closes #6597
The refactoring checker now also raises 'consider-using-a-generator' messages for
max(),min()andsum().Refs #6595
Update ranges for
using-constant-testandmissing-parentheses-for-call-in-testerror messages.Don't emit
no-memberinside type annotations withfrom __future__ import annotations.Closes #6594
Fix
unexpected-special-method-signaturefalse positive for__init_subclass__methods with one or more arguments.Closes #6644
Deprecations¶
The
ignore-mixin-membersoption has been deprecated. You should now use the newignored-checks-for-mixinsoption.Closes #5205
interfaces.implementshas been deprecated and will be removed in 3.0. Please use standard inheritance patterns instead of__implements__.Refs #2287
All
Interfaceclasses inpylint.interfaceshave been deprecated. You can subclass the respective normal classes to get the same behaviour. The__implements__functionality was based on a rejected PEP from 2001: https://peps.python.org/pep-0245/Closes #2287
MapReduceMixinhas been deprecated.BaseCheckernow implementsget_map_dataandreduce_map_data. If a checker actually needs to reduce data it should defineget_map_dataas returning something different thanNoneand let itsreduce_map_datahandle a list of the types returned byget_map_data. An example can be seen by looking atpylint/checkers/similar.py.The
configattribute ofBaseCheckerhas been deprecated. You can usechecker.linter.configto access the global configuration object instead of a checker-specific object.Refs #5392
The
levelattribute ofBaseCheckerhas been deprecated: everything is now displayed in--help, all the time.Refs #5392
The
set_optionmethod ofBaseCheckerhas been deprecated. You can usechecker.linter.set_optionto set an option on the global configuration object instead of a checker-specific object.Refs #5392
The
options_providersattribute ofArgumentsManagerhas been deprecated.Refs #5392
Fix saving of persistent data files in environments where the user's cache directory and the linted file are on a different drive.
Closes #6394
The
method-cache-max-size-nonechecker will now also checkfunctools.cache.The
configattribute ofPyLinteris now of theargparse.Namespacetype instead ofoptparse.Values.Refs #5392
UnsupportedActionhas been deprecated.Refs #5392
OptionsManagerMixInhas been deprecated.Refs #5392
OptionParserhas been deprecated.Refs #5392
Optionhas been deprecated.Refs #5392
OptionsProviderMixInhas been deprecated.Refs #5392
ConfigurationMixInhas been deprecated.The
option_groupsattribute ofPyLinterhas been deprecated.Refs #5392
get_global_confighas been deprecated. You can now access all global options fromchecker.linter.config.Refs #5392
OptionsManagerMixInhas been replaced withArgumentsManager.ArgumentsManageris considered private API and most methods that were public onOptionsManagerMixInhave now been deprecated and will be removed in a future release.Refs #5392
OptionsProviderMixInhas been replaced withArgumentsProvider.ArgumentsProvideris considered private API and most methods that were public onOptionsProviderMixInhave now been deprecated and will be removed in a future release.Refs #5392
pylint.pyreverse.ASTWalkerhas been removed, as it was only used internally by a single child class.Refs #6712
pyreverse: Resolving and displaying implemented interfaces that are defined by the__implements__attribute has been deprecated and will be removed in 3.0.Refs #6713
is_class_subscriptable_pep585_with_postponed_evaluation_enabledhas been deprecated. Useis_postponed_evaluation_enabled(node) and is_node_in_type_annotation_context(node)instead.Refs #6536