forked from pylint-dev/pylint
-
Notifications
You must be signed in to change notification settings - Fork 0
/
ChangeLog
3620 lines (2230 loc) · 120 KB
/
ChangeLog
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
------------------
Pylint's ChangeLog
------------------
What's New in Pylint 2.0?
=========================
Release date: |TBA|
* Add a check `chained-comparison` which is emitted if a boolean operation can be simplified
by chaining some of its operations.
e.g "a < b and b < c", can be simplified as "a < b < c".
Close #2032
* Add a check `consider-using-in` for comparisons of a variable against
multiple values with "==" and "or"s instead of checking if the variable
is contained "in" a tuple of those values.
* `in` is considered iterating context for some of the Python 3 porting checkers
Close #2186
* Add `--ignore-none` flag to control if pylint should warn about `no-member` where the owner is None
* Fix a false positive related to `too-many-arguments` and bounded `__get__` methods
Close #2172
* `mcs` as the first parameter of metaclass's `__new__` method was replaced by `cls`
Close #2028
* `assignment-from-no-return` considers methods as well.
Close #2081
* Support typing.TYPE_CHECKING for *unused-import* errors
Close #1948
* Inferred classes at a function level no longer emit `invalid-name`
when they don't respect the variable regular expression
Close #1049
* Added basic support for postponed evaluation of function annotations.
Close #2069
* Fix a bug with `missing-kwoa` and variadics parameters
Close #1111
* `simplifiable-if-statement` takes in account only when assigning to same targets
Close #1984
* Make `len-as-condition` test more cases, such as `len() < 1` or `len <= 0'
* Fix false-positive ``line-too-long`` message emission for
commented line at the end of a module
Close #1950
* Don't warn about `stop-iteration-return` when using `next()` over `itertools.count`
Close #2158
* Add a check `consider-using-get` for unidiomatic usage of value/default-retrieval
for a key from a dictionary
Close #2076
* invalid-slice-index is not emitted when the slice is used as index for a complex object.
We only use a handful of known objects (list, set and friends) to figure out if
we should emit invalid-slice-index when the slice is used to subscript an object.
* Don't emit `unused-import` anymore for typing imports used in type comments.
* Add a new check 'useless-import-alias'.
Close #2052
* Add `comparison-with-callable` to warn for comparison with bare callable, without calling it.
Close #2082
* Don't warn for ``missing-type-doc`` and/or ``missing-return-type-doc``, if type
annotations exist on the function signature for a parameter and/or return type.
Close #2083
* Add `--exit-zero` option for continuous integration scripts to more
easily call Pylint in environments that abort when a program returns a
non-zero (error) status code.
Close #2042
* Warn if the first argument of an instance/ class method gets assigned
Close #977
* New check `comparison-with-itself` to check comparison between same value.
Close #2051
* Add a new warning, 'logging-fstring-interpolation', emitted when f-string
is used within logging function calls.
Close #1998
* Don't show 'useless-super-delegation' if the subclass method has different type annotations.
Close #1923
* Add `unhashable-dict-key` check.
Closes #586
* Don't warn that a global variable is unused if it is defined by an import
Close #1453
* Skip wildcard import check for `__init__.py`.
Close #2026
* The Python 3 porting mode can now run with Python 3 as well.
* `too-few-public-methods` is not emitted for dataclasses.
Close #1793
* New verbose mode option, enabled with `--verbose` command line flag, to
display of extra non-checker-related output. It is disabled by default.
Close #1863
* `undefined-loop-variable` takes in consideration non-empty iterred objects before emitting
Close #2039
* Add support for nupmydoc optional return value names.
Close #2030
* `singleton-comparison` accounts for negative checks
Close #2037
* Add a check `consider-using-in` for comparisons of a variable against
multiple values with "==" and "or"s instead of checking if the variable
is contained "in" a tuple of those values.
Close #1977
* defaultdict and subclasses of dict are now handled for dict-iter-* checks
Close #2005
* `logging-format-interpolation` also emits when f-strings are used instead of % syntax.
Close #1788
* Don't trigger misplaced-bare-raise when the raise is in a finally clause
Close #1924
* Add a new check, `possibly-unused-variable`.
This is similar to `unused-variable`, the only difference is that it is
emitted when we detect a locals() call in the scope of the unused variable.
The `locals()` call could potentially use the said variable, by consuming
all values that are present up to the point of the call. This new check
allows to disable this error when the user intentionally uses `locals()`
to consume everything.
Close #1909.
* `no-else-return` accounts for multiple cases
The check was a bit overrestrictive because we were checking for
return nodes in the .orelse node. At that point though the if statement
can be refactored to not have the orelse. This improves the detection of
other cases, for instance it now detects TryExcept nodes that are part of
the .else branch.
Close #1852
* Added two new checks, `invalid-envvar-value` and `invalid-envvar-default`.
The former is trigger whenever pylint detects that environment variable manipulation
functions uses a different type than strings, while the latter is emitted whenever
the said functions are using a default variable of different type than expected.
* Add a check `consider-using-join` for concatenation of strings using str.join(sequence)
Close #1952
* Add a check `consider-swap-variables` for swapping variables with tuple unpacking
Close #1922
* Add new checker `try-except-raise` that warns the user if an except handler block
has a ``raise`` statement as its first operator. The warning is shown when there is
a bare raise statement, effectively re-raising the exception that was caught or the
type of the exception being raised is the same as the one being handled.
* Don't crash on invalid strings when checking for `logging-format-interpolation`
Close #1944
* Exempt `__doc__` from triggering a `redefined-builtin`
`__doc__` can be used to specify a docstring for a module without
passing it as a first-statement string.
* Fix false positive bad-whitespace from function arguments with default
values and annotations
Close #1831
* Fix stop-iteration-return false positive when next builtin has a
default value in a generator
Close #1830
* Fix emission of false positive ``no-member`` message for class with "private" attributes whose name is mangled.
Close #1643
* Fixed a crash which occurred when `Uninferable` wasn't properly handled in `stop-iteration-return`
Close #1779
* Use the proper node to get the name for redefined functions (#1792)
Close #1774
* Don't crash when encountering bare raises while checking inconsistent returns
Close #1773
* Fix a false positive ``inconsistent-return-statements`` message when if statement is inside try/except.
Close #1770
* Fix a false positive ``inconsistent-return-statements`` message when while loop are used.
Close #1772
* Correct column number for whitespace conventions.
Previously the column was stuck at 0
Close #1649
* Fix ``unused-argument`` false positives with overshadowed variable in
dictionary comprehension.
Close #1731
* Fix false positive ``inconsistent-return-statements`` message when never
returning functions are used (i.e sys.exit for example).
Close #1771
* Fix error when checking if function is exception, as in ``bad-exception-context``.
* Fix false positive ``inconsistent-return-statements`` message when a
function is defined under an if statement.
Close #1794
* New ``useless-return`` message when function or method ends with a "return" or
"return None" statement and this is the only return statement in the body.
* Fix false positive ``inconsistent-return-statements`` message by
avoiding useless exception inference if the exception is not handled.
Close #1794 (second part)
* Fix bad thread instantiation check when target function is provided in args.
Close #1840
* Fixed false positive when a numpy Attributes section follows a Parameters
section
Close #1867
* Fix incorrect file path when file absolute path contains multiple ``path_strip_prefix`` strings.
Close #1120
* Fix false positive undefined-variable for lambda argument in class definitions
Close #1824
* Add of a new checker that warns the user if some messages are enabled or disabled
by id instead of symbol.
Close #1599
* Suppress false-positive ``not-callable`` messages from certain
staticmethod descriptors
Close #1699
* Fix indentation handling with tabs
Close #1148
* Fix false-positive ``bad-continuation`` error
Close #638
* Updated the default report format to include paths that can be clicked on in some terminals (e.g. iTerm).
* Fix inline def behavior with ``too-many-statements`` checker
Close #1978
* Fix `KeyError` raised when using docparams and NotImplementedError is documented.
Close #2102
* Fix 'method-hidden' raised when assigning to a property or data descriptor.
* Fix emitting ``useless-super-delegation`` when changing the default value of keyword arguments.
Close #2022
What's New in Pylint 1.9?
=========================
Release date: 2018-05-15
* Added two new Python 3 porting checks, `exception-escape` and `comprehension-escape`
These two are emitted whenever pylint detects that a variable defined in the
said blocks is used outside of the given block. On Python 3 these values are deleted.
* Added a new `deprecated-sys-function`, emitted when accessing removed sys members.
* Added `xreadlines-attribute`, emitted when the `xreadlines()` attribute is accessed.
* The Python 3 porting mode can now run with Python 3 as well.
* docparams extension allows abstract methods to document what overriding
implementations should return, and to raise NotImplementedError without
documenting it.
Closes #2044
* Special methods do not count towards `too-few-methods`,
and are considered part of the public API.
* Enum classes do not trigger `too-few-methods`
Close #605
* Added a new Python 2/3 check for accessing `operator.div`, which is removed in Python 3
Close #1936
* Added a new Python 2/3 check for accessing removed urllib functions
Close #1997
What's New in Pylint 1.8.1?
=========================
Release date: 2017-12-15
* Wrong version number in __pkginfo__.
What's New in Pylint 1.8?
=========================
Release date: 2017-12-15
* Respect disable=... in config file when running with --py3k.
* New warning `shallow-copy-environ` added
Shallow copy of os.environ doesn't work as people may expect. os.environ
is not a dict object but rather a proxy object, so any changes made
on copy may have unexpected effects on os.environ
Instead of copy.copy(os.environ) method os.environ.copy() should be
used.
See https://bugs.python.org/issue15373 for details.
Close #1301
* Do not display no-absolute-import warning multiple times per file.
* `trailing-comma-tuple` refactor check now extends to assignment with
more than one element (such as lists)
Close #1713
* Fixing u'' string in superfluous-parens message
Close #1420
* `abstract-class-instantiated` is now emitted for all inference paths.
Close #1673
* Add set of predefined naming style to ease configuration of checking
naming conventions.
Closes #1013
* Added a new check, ``keyword-arg-before-vararg``
This is emitted for function definitions
in which keyword arguments are placed before variable
positional arguments (*args).
This may lead to args list getting modified if keyword argument's value
is not provided in the function call assuming it will take default value
provided in the definition.
* The `invalid-name` check contains the name of the template that caused the failure
Close #1176
* Using the -j flag won't start more child linters than needed.
Contributed by Roman Ivanov in #1614
* Fix a false positive with bad-python3-import on relative imports
Close #1608
* Added a new Python 3 check, ``non-ascii-bytes-literals``
Close #1545
* Added a couple of new Python 3 checks for accessing dict methods in non-iterable context
* Protocol checks (not-a-mapping, not-an-iterable and co.) aren't emitted on classes with dynamic getattr
* Added a new warning, 'bad-thread-instantiation'
This message is emitted when the threading.Thread class does not
receive the target argument, but receives just one argument, which
is by default the group parameter.
Close #1327
* In non-quiet mode, absolute path of used config file is logged to
standard error.
Close #1519
* Raise meaningful exception for invalid reporter class being selected
When unknown reporter class will be selected as Pylint reporter,
meaningful error message would be raised instead of bare ``ImportError``
or ``AttribueError`` related to module or reporter class being not found.
Close #1388
* Added a new Python 3 check for accessing removed functions from itertools
like ``izip`` or ``ifilterfalse``
* Added a new Python 3 check for accessing removed fields from the types
module like ``UnicodeType`` or ``XRangeType``
* Added a new Python 3 check for declaring a method ``next`` that would have
been treated as an iterator in Python 2 but a normal function in Python 3.
* Added a new key-value pair in json output. The key is ``message-id``
and the value is the message id.
Close #1512
* Added a new Python 3.0 check for raising a StopIteration inside a generator.
The check about raising a StopIteration inside a generator is also valid if the exception
raised inherit from StopIteration.
Close #1385
* Added a new warning, ``raising-format-tuple``, to detect multi-argument
exception construction instead of message string formatting.
* Added a new check for method of logging module that concatenate string via + operator
Close #1479
* Added parameter for limiting number of suggestions in spellchecking checkers
* Fix a corner-case in ``consider-using-ternary`` checker.
When object ``A`` used in ``X and A or B`` was falsy in boolean context,
Pylint incorrectly emitted non-equivalent ternary-based suggestion.
After a change message is correctly not emitted for this case.
Close #1559
* Added ``suggestion-mode`` configuration flag. When flag is enabled, informational
message is emitted instead of cryptic error message for attributes accessed on
c-extensions.
Close #1466
* Fix a false positive ``useless-super-delegation`` message when
parameters default values are different from those used in the base class.
Close #1085
* Disabling 'wrong-import-order', 'wrong-import-position', or
'ungrouped-imports' for a single line now prevents that line from
triggering violations on subsequent lines.
Close #1336
* Added a new Python check for inconsistent return statements inside method or function.
Close #1267
* Fix ``superfluous-parens`` false positive related to handling logical statements
involving ``in`` operator.
Close #574
* ``function-redefined`` message is no longer emitted for functions and
methods which names matches dummy variable name regular expression.
Close #1369
* Fix ``missing-param-doc`` and ``missing-type-doc`` false positives when
mixing ``Args`` and ``Keyword Args`` in Google docstring.
Close #1409
* Fix ``missing-docstring`` false negatives when modules, classes, or methods
consist of compound statements that exceed the ``docstring-min-length``
* Fix ``useless-else-on-loop`` false positives when break statements are
deeply nested inside loop.
Close #1661
* Fix no ``wrong-import-order`` message emitted on ordering of first and third party
libraries. With this fix, pylint distinguishes third and first party
modules when checking import order.
Close #1702
* Fix ``pylint disable=fixme`` directives ignored for comments following the
last statement in a file.
Close #1681
* Fix ``line-too-long`` message deactivated by wrong disable directive.
The directive ``disable=fixme`` doesn't deactivate anymore the emission
of ``line-too-long`` message for long commented lines.
Close #1741
* If the rcfile specified on the command line doesn't exist, then an
IOError exception is raised.
Close #1747
* Fix the wrong scope of the ``disable=`` directive after a commented line.
For example when a ``disable=line-too-long`` directive is at the end of
a long commented line, it no longer disables the emission of ``line-too-long``
message for lines that follow.
Close #1742
What's New in Pylint 1.7.1?
=========================
Release date: 2017-04-17
* Fix a false positive which occurred when an exception was reraised
Close #1419
* Fix a false positive of ``disallow-trailing-tuple``
The check was improved by verifying for non-terminating newlines, which
should exempt function calls and function definitions from the check
Close #1424
What's New in Pylint 1.7?
=========================
Release date: 2017-04-13
* Don't emit missing-final-newline or trailing-whitespace for formfeeds (page breaks).
Close #1218 and #1219
* Don't emit by default no-member if we have opaque inference objects in the inference results
This is controlled through the new flag ignore-on-opaque-inference, which is by
default True. The inference can return multiple potential results while
evaluating a Python object, but some branches might not be evaluated, which
results in partial inference. In that case, it might be useful to still emit
no-member and other checks for the rest of the inferred objects.
* Added new message `assign-to-new-keyword` to warn about assigning to names which
will become a keyword in future Python releases.
Close #1351
* Split the 'missing or differing' in parameter documentation in different error.
'differing-param-doc' covers the differing part of the old 'missing-param-doc',
and 'differing-type-doc' covers the differing part of the old 'missing-type-doc'
Close #1342
* Added a new error, 'used-prior-global-declaration', which is emitted when a name
is used prior a global declaration in a function. This causes a SyntaxError in
Python 3.6
Close #1257
* The protocol checks are emitting their messages when a special method is set to None.
Close #1263
* Properly detect if imported name is assigned to same name in different
scope.
Close #636, #848, #851, and #900
* Require one space for annotations with type hints, as per PEP 8.
* 'trailing-comma-tuple' check was added
This message is emitted when pylint finds an one-element tuple,
created by a stray comma. This can suggest a potential problem in the
code and it is recommended to use parantheses in order to emphasise the
creation of a tuple, rather than relying on the comma itself.
* Don't emit not-callable for instances with unknown bases.
Close #1213
* Treat keyword only arguments the same as positional arguments with regard to unused-argument check
* Don't try to access variables defined in a separate scope when checking for ``protected-access``
* Added new check to detect incorrect usage of len(SEQUENCE) inside
test conditions.
* Added new extension to detect comparisons against empty string constants
* Added new extension to detect comparisons of integers against zero
* Added new error conditions for 'bad-super-call'
Now detects ``super(type(self), self)`` and ``super(self.__class__, self)``
which can lead to recursion loop in derived classes.
* PyLinter.should_analyze_file has a new optional parameter, called `is_argument`
Close #1079
* Add attribute hints for missing members
Closes #1035
* Add a new warning, 'redefined-argument-from-local'
Closes #649
* Support inline comments for comma separated values in the config file
Closes #1024
* epylint.py_run's *script* parameter was removed.
* epylint.py_run now uses ``shell=False`` for running the underlying process.
Closes #441
* Added a new warning, 'useless-super-delegation'
Close 839.
* Added a new error, 'invalid-metaclass', raised when
we can detect that a class is using an improper metaclass.
Close #579
* Added a new refactoring message, 'literal-comparison'.
Close #786
* arguments-differ takes in consideration kwonlyargs and variadics
Close #983
* Removed --optimized-ast. Part of #975.
* Removed --files-output option. Part of #975.
* Removed pylint-gui from the package.
* Removed the HTML reporter. Part of #975.
* ignored-argument-names is now used for ignoring arguments for unused-variable check.
This option was used for ignoring arguments when computing the correct number of arguments
a function should have, but for handling the arguments with regard
to unused-variable check, dummy-variables-rgx was used instead. Now, ignored-argument-names
is used for its original purpose and also for ignoring the matched arguments for
the unused-variable check. This offers a better control of what should be ignored
and how.
Also, the same option was moved from the design checker to the variables checker,
which means that the option now appears under the ``[VARIABLES]`` section inside
the configuration file.
Close #862.
* Fix a false positive for keyword variadics with regard to keyword only arguments.
If a keyword only argument was necessary for a function, but that function was called
with keyword variadics (**kwargs), then we were emitting a missing-kwoa false positive,
which is now fixed.
Close #934.
* Fix some false positives with unknown sized variadics.
Close #878
* Added a new extension, check_docstring, for checking PEP 257 conventions.
Closes #868.
* config files with BOM markers can now be read.
Close #864.
* epylint.py_run does not crash on big files, using .communicate() instead of .wait()
Close #599
* Disable reports by default and show the evaluation score by default
As per discussion from issue #746, the reports were disabled by
default in order to simplify the interaction between the tool
and the users. The score is still shown by default, as a way of
closely measuring when it increases or decreases due to changes
brought to the code.
* Disable the information category messages by default.
This is a step towards making pylint more sane, as
per the discussion from issue #746.
* Catch more cases as not proper iterables for __slots__ with
regard to invalid-slots pattern. Closes issue #775.
* empty indent strings are rejected.
* Added a new error, 'relative-beyond-top-level', which is emitted
when a relative import was attempted beyond the top level package.
Closes issue #588.
* Added a new warning, 'unsupported-assignment-operation', which is
emitted when item assignment is tried on an object which doesn't
have this ability. Closes issue #591.
* Added a new warning, 'unsupported-delete-operation', which is
emitted when item deletion is tried on an object which doesn't
have this ability. Closes issue #592.
* Fix a false positive of 'redundant-returns-doc', occurred when the documented
function was using *yield* instead of *return*.
Closes issue #984.
* Fix false positives of 'missing-[raises|params|type]-doc' due to not
recognizing keyword synonyms supported by Sphinx.
* Added a new refactoring message, 'consider-merging-isinstance', which is
emitted whenever we can detect that consecutive isinstance calls can be
merged together.
Closes issue #968
* Fix a false positive of 'missing-param-doc' and 'missing-type-doc',
occurred when a class docstring uses the 'For the parameters, see'
magic string but the class __init__ docstring does not, or vice versa.
* `redefined-outer-name` is now also emitted when a nested loop's target
variable is the same as a target variable in an outer loop.
Closes issue #911.
* Added proper exception type inference for 'missing-raises-doc'.
* Added InvalidMessageError exception class to replace asserts in
pylint.utils.
* More thorough validation in MessagesStore.register_messages() to avoid
one message accidentally overwriting another.
* InvalidMessageError, UnknownMessage, and EmptyReport exceptions are
moved to the new pylint.exceptions submodule.
* UnknownMessage and EmptyReport are renamed to UnknownMessageError and
EmptyReportError.
* Warnings 'missing-returns-type-doc' and 'missing-yields-type-doc'
have each been split into two warnings - 'missing-[return|yield]-doc'
and 'missing-[return|yield]-type-doc'.
* Added epytext support to docparams extension.
Closes #1029.
* Support having plugins with the same name and with options defined
Closes #1018
* Sort configuration options in a section
Closes #1087
* Added a new Python 3 warning around implementing '__div__', '__idiv__', or
'__rdiv__' as those methods are phased out in Python 3.
* Added a new warning, 'overlapping-except', which is
emitted when two exceptions in the same except-clause are aliases
for each other or one exceptions is an ancestor of another.
* Avoid crashing on ill-formatted strings when checking for string formatting errors.
* Added a new Python 3 warning for calling 'str.encode' or 'str.decode' with a non-text
encoding.
* Added new coding convention message, 'single-string-used-for-slots'.
Closes #1166
* Added a new Python 3 check for accessing 'sys.maxint' which was removed in Python 3 in favor
of 'sys.maxsize'
* Added a new Python 3 check for bad imports.
* Added a new Python 3 check for accessing deprecated string functions.
* Do not warn about unused arguments or function being redefined in singledispatch
registered implementations.
Closes #1032 and #1034
* Added refactoring message 'no-else-return'.
* Improve unused-variable checker to warn about unused variables in module scope.
Closes #919
* Ignore modules import as _ when checking for unused imports.
Closes #1190
* Improve handing of Python 3 classes with metaclasses declared in nested scopes.
Closes #1177
* Added refactoring message 'consider-using-ternary'.
Closes #1204
* Bug-fix for false-positive logging-format-interpolation` when format specifications
are used in formatted string.
Fixes #572
* Added a new switch ``single-line-class-stmt`` to allow single-line declaration
of empty class bodies.
Closes #738
* Protected access in form `type(self)._attribute` are now allowed.
Fixes #1031
* Let the user modify msg-template when Pylint is called from a Python script
Fixes #1269
* Imports checker supports new switch ``allow-wildcard-with-all`` which disables
warning on wildcard import when imported module defines `__all__` variable.
Fixes #831
* `too-many-format-args` and `too-few-format-args` are emitted correctly when
starred expression are used in RHS tuple.
Fixes #957
* `cyclic-import` checker supports local disable clauses. When one
of cycle imports was done in scope where disable clause was active,
cycle is not reported as violation.
Fixes #59
What's new in Pylint 1.6.3?
===========================
Release date: 2016-07-18
* Do not crash when inferring uninferable exception types for docparams extension
Close #998
What's new in Pylint 1.6.2?
===========================
Release date: TBA
* Do not crash when printing the help of options with default regular expressions
Close #990
* More granular versions for deprecated modules.
Close #991
What's new in Pylint 1.6.1?
===========================
Release date: 2016-07-07
* Use environment markers for supporting conditional dependencies.
What's New in Pylint 1.6.0?
===========================
Release date: 2016-07-03
* Added a new extension, `pylint.extensions.mccabe`, for warning
about complexity in code.
* Deprecate support for --optimize-ast. Part of #975.
* Deprecate support for the HTML output. Part of #975.
* Deprecate support for --output-files. Part of #975.
* Fixed a documentation error for the check_docs extension. Fixes #735.
* Made the list of property-defining decorators configurable.
* Fix a bug where the top name of a qualified import was detected as unused variable.
Close #923.
* bad-builtin is now an extension check.
* generated-members support qualified name through regular expressions.
For instance, one can specify a regular expression as --generated-members=astroid.node_classes.*
for ignoring every no-member error that is accessed as in `astroid.node_classes.missing.object`.
* Add the ability to ignore files based on regex matching, with the new ``--ignore-patterns``
option.
This addresses issue #156 by allowing for multiple ignore patterns
to be specified. Rather than clobber the existing ignore option, we
introduced a new one called ignore-patterns.
* Added a new error, 'trailing-newlines', which is emitted when a file
has trailing new lines.
Closes issue #682.
* Add a new option, 'redefining-builtins-modules', for controlling the modules
which can redefine builtins, such as six.moves and future.builtins.
Close #464.
* 'reimported' is emitted when the same name is imported from different module.
Close #162.
* Add a new recommendation checker, 'consider-iterating-dictionary', which is emitted
which is emitted when a dictionary is iterated through .keys().
Close #699
* Use the configparser backport for Python 2
This fixes a problem we were having with comments inside values, which is fixed
in Python 3's configparser.
Close #828
* A new error was added, 'invalid-length-returned', when the `__len__`
special method returned something else than a non-negative number.
Close issue #557
* Switch to using isort internally for wrong-import-order.