diff --git a/.flake8 b/.flake8 index 1d33859fc..e29e7037c 100644 --- a/.flake8 +++ b/.flake8 @@ -33,18 +33,12 @@ ignore = D102,D103,D104,D105,D209,D211,D402,D403 min-version = 3.4.0 max-complexity = 12 -putty-auto-ignore = True -putty-ignore = - /# pylint: disable=invalid-name/ : +N801,N806 - /# pragma: no mccabe/ : +C901 - tests/*/test_*.py : +D100,D101,D401 - tests/conftest.py : +F403 - tests/unit/browser/test_history.py : +N806 - tests/helpers/fixtures.py : +N806 - tests/unit/browser/webkit/http/test_content_disposition.py : +D400 - scripts/dev/ci/appveyor_install.py : +FI53 - # FIXME:conf - tests/unit/completion/test_models.py : +F821 +per-file-ignores = + tests/*/test_*.py : D100,D101,D401 + tests/unit/browser/test_history.py : N806 + tests/helpers/fixtures.py : N806 + tests/unit/browser/webkit/http/test_content_disposition.py : D400 + scripts/dev/ci/appveyor_install.py : FI53 copyright-check = True copyright-regexp = # Copyright [\d-]+ .* copyright-min-file-size = 110 diff --git a/misc/requirements/requirements-flake8.txt b/misc/requirements/requirements-flake8.txt index 053d06ec4..ff33c19e1 100644 --- a/misc/requirements/requirements-flake8.txt +++ b/misc/requirements/requirements-flake8.txt @@ -1,23 +1,21 @@ # This file is automatically generated by scripts/dev/recompile_requirements.py -flake8==2.6.2 # rq.filter: < 3.0.0 +flake8==3.5.0 flake8-copyright==0.2.0 flake8-debugger==3.0.0 -flake8-deprecated==1.2.1 # rq.filter: < 1.3 +flake8-deprecated==1.3 flake8-docstrings==1.0.3 # rq.filter: < 1.1.0 flake8-future-import==0.4.3 flake8-mock==0.3 flake8-pep3101==1.0 # rq.filter: < 1.1 +flake8-per-file-ignores==0.4 flake8-polyfill==1.0.1 -flake8-putty==0.4.0 flake8-string-format==0.2.3 flake8-tidy-imports==1.1.0 flake8-tuple==0.2.13 mccabe==0.6.1 -packaging==16.8 pep8-naming==0.4.1 pycodestyle==2.3.1 pydocstyle==1.1.1 # rq.filter: < 2.0.0 pyflakes==1.6.0 -pyparsing==2.2.0 six==1.11.0 diff --git a/misc/requirements/requirements-flake8.txt-raw b/misc/requirements/requirements-flake8.txt-raw index 7f0b5153a..2baced0d0 100644 --- a/misc/requirements/requirements-flake8.txt-raw +++ b/misc/requirements/requirements-flake8.txt-raw @@ -1,12 +1,12 @@ -flake8<3.0.0 +flake8 flake8-copyright flake8-debugger -flake8-deprecated<1.3 +flake8-deprecated flake8-docstrings<1.1.0 flake8-future-import flake8-mock flake8-pep3101<1.1 -flake8-putty +flake8-per-file-ignores flake8-string-format flake8-tidy-imports flake8-tuple @@ -14,14 +14,7 @@ pep8-naming pydocstyle<2.0.0 pyflakes -# Pinned to 2.0.0 otherwise -pycodestyle==2.3.1 -# Pinned to 0.5.3 otherwise -mccabe==0.6.1 - # Waiting until flake8-putty updated -#@ filter: flake8 < 3.0.0 #@ filter: pydocstyle < 2.0.0 #@ filter: flake8-docstrings < 1.1.0 #@ filter: flake8-pep3101 < 1.1 -#@ filter: flake8-deprecated < 1.3 diff --git a/qutebrowser/browser/qutescheme.py b/qutebrowser/browser/qutescheme.py index 11dcfe004..3fb6459a5 100644 --- a/qutebrowser/browser/qutescheme.py +++ b/qutebrowser/browser/qutescheme.py @@ -91,7 +91,7 @@ class Redirect(Exception): self.url = url -class add_handler: # pylint: disable=invalid-name +class add_handler: # noqa: N801,N806 pylint: disable=invalid-name """Decorator to register a qute://* URL handler. diff --git a/qutebrowser/browser/webkit/network/networkmanager.py b/qutebrowser/browser/webkit/network/networkmanager.py index beaa690ca..a19687eb1 100644 --- a/qutebrowser/browser/webkit/network/networkmanager.py +++ b/qutebrowser/browser/webkit/network/networkmanager.py @@ -206,7 +206,7 @@ class NetworkManager(QNetworkAccessManager): # No @pyqtSlot here, see # https://github.com/qutebrowser/qutebrowser/issues/2213 - def on_ssl_errors(self, reply, errors): # pragma: no mccabe + def on_ssl_errors(self, reply, errors): # noqa: C901 pragma: no mccabe """Decide if SSL errors should be ignored or not. This slot is called on SSL/TLS errors by the self.sslErrors signal. diff --git a/qutebrowser/browser/webkit/network/networkreply.py b/qutebrowser/browser/webkit/network/networkreply.py index a4a4f59ca..22263c96b 100644 --- a/qutebrowser/browser/webkit/network/networkreply.py +++ b/qutebrowser/browser/webkit/network/networkreply.py @@ -34,7 +34,7 @@ class FixedDataNetworkReply(QNetworkReply): """QNetworkReply subclass for fixed data.""" - def __init__(self, request, fileData, mimeType, # flake8: disable=N803 + def __init__(self, request, fileData, mimeType, # noqa: N803 parent=None): """Constructor. diff --git a/qutebrowser/commands/cmdutils.py b/qutebrowser/commands/cmdutils.py index 8111a1dd4..2f7af2f9f 100644 --- a/qutebrowser/commands/cmdutils.py +++ b/qutebrowser/commands/cmdutils.py @@ -61,7 +61,7 @@ def check_exclusive(flags, names): argstr)) -class register: # pylint: disable=invalid-name +class register: # noqa: N801,N806 pylint: disable=invalid-name """Decorator to register a new command handler. @@ -114,7 +114,7 @@ class register: # pylint: disable=invalid-name return func -class argument: # pylint: disable=invalid-name +class argument: # noqa: N801,N806 pylint: disable=invalid-name """Decorator to customize an argument for @cmdutils.register. diff --git a/qutebrowser/commands/command.py b/qutebrowser/commands/command.py index bbc79a0d8..afb6253db 100644 --- a/qutebrowser/commands/command.py +++ b/qutebrowser/commands/command.py @@ -393,7 +393,7 @@ class Command: if isinstance(typ, tuple): raise TypeError("{}: Legacy tuple type annotation!".format( self.name)) - elif type(typ) is type(typing.Union): # flake8: disable=E721 + elif type(typ) is type(typing.Union): # noqa: E721 # this is... slightly evil, I know # We also can't use isinstance here because typing.Union doesn't # support that. diff --git a/qutebrowser/config/config.py b/qutebrowser/config/config.py index ff09e2a5b..058f96087 100644 --- a/qutebrowser/config/config.py +++ b/qutebrowser/config/config.py @@ -38,7 +38,7 @@ key_instance = None change_filters = [] -class change_filter: # pylint: disable=invalid-name +class change_filter: # noqa: N801,N806 pylint: disable=invalid-name """Decorator to filter calls based on a config section/option matching. diff --git a/qutebrowser/keyinput/modeman.py b/qutebrowser/keyinput/modeman.py index cd35913ad..ad9bd06ee 100644 --- a/qutebrowser/keyinput/modeman.py +++ b/qutebrowser/keyinput/modeman.py @@ -62,7 +62,7 @@ class NotInModeError(Exception): def init(win_id, parent): """Initialize the mode manager and the keyparsers for the given win_id.""" - KM = usertypes.KeyMode # pylint: disable=invalid-name + KM = usertypes.KeyMode # noqa: N801,N806 pylint: disable=invalid-name modeman = ModeManager(win_id, parent) objreg.register('mode-manager', modeman, scope='window', window=win_id) keyparsers = { diff --git a/qutebrowser/mainwindow/statusbar/bar.py b/qutebrowser/mainwindow/statusbar/bar.py index 61bb35ace..ae7a3954d 100644 --- a/qutebrowser/mainwindow/statusbar/bar.py +++ b/qutebrowser/mainwindow/statusbar/bar.py @@ -113,7 +113,7 @@ def _generate_stylesheet(): color: {{ conf.colors.%s }}; background-color: {{ conf.colors.%s }}; } - """ % (flag, flag, flag, # flake8: disable=S001 + """ % (flag, flag, flag, # noqa: S001 option + '.fg', option + '.bg') return stylesheet diff --git a/qutebrowser/misc/crashsignal.py b/qutebrowser/misc/crashsignal.py index 68c17d93f..60ef2fbad 100644 --- a/qutebrowser/misc/crashsignal.py +++ b/qutebrowser/misc/crashsignal.py @@ -22,7 +22,7 @@ import os import sys import bdb -import pdb # flake8: disable=T002 +import pdb # noqa: T002 import signal import functools import faulthandler diff --git a/qutebrowser/misc/split.py b/qutebrowser/misc/split.py index 045d9fe4b..bdde2b7ee 100644 --- a/qutebrowser/misc/split.py +++ b/qutebrowser/misc/split.py @@ -55,7 +55,7 @@ class ShellLexer: self.token = '' self.state = ' ' - def __iter__(self): # pragma: no mccabe + def __iter__(self): # noqa: C901 pragma: no mccabe """Read a raw token from the input stream.""" self.reset() for nextchar in self.string: diff --git a/qutebrowser/utils/debug.py b/qutebrowser/utils/debug.py index 5da5234a9..2c86e1142 100644 --- a/qutebrowser/utils/debug.py +++ b/qutebrowser/utils/debug.py @@ -232,7 +232,7 @@ def format_call(func, args=None, kwargs=None, full=True): return '{}({})'.format(name, format_args(args, kwargs)) -class log_time: # pylint: disable=invalid-name +class log_time: # noqa: N801,N806 pylint: disable=invalid-name """Log the time an operation takes. diff --git a/qutebrowser/utils/log.py b/qutebrowser/utils/log.py index 0d87a5f7c..b1966d2f7 100644 --- a/qutebrowser/utils/log.py +++ b/qutebrowser/utils/log.py @@ -360,7 +360,7 @@ def qt_message_handler(msg_type, context, msg): # PNGs in Qt with broken color profile # https://bugreports.qt.io/browse/QTBUG-39788 'libpng warning: iCCP: Not recognizing known sRGB profile that has ' - 'been edited', # flake8: disable=E131 + 'been edited', # noqa: E131 'libpng warning: iCCP: known incorrect sRGB profile', # Hopefully harmless warning 'OpenType support missing for script ', @@ -419,7 +419,7 @@ def qt_message_handler(msg_type, context, msg): 'libpng warning: iCCP: known incorrect sRGB profile', # https://bugreports.qt.io/browse/QTBUG-47154 'virtual void QSslSocketBackendPrivate::transmit() SSLRead failed ' - 'with: -9805', # flake8: disable=E131 + 'with: -9805', # noqa: E131 ] if any(msg.strip().startswith(pattern) for pattern in suppressed_msgs): diff --git a/qutebrowser/utils/utils.py b/qutebrowser/utils/utils.py index f59c9f553..8debc6688 100644 --- a/qutebrowser/utils/utils.py +++ b/qutebrowser/utils/utils.py @@ -584,7 +584,7 @@ def disabled_excepthook(): sys.excepthook = old_excepthook -class prevent_exceptions: # pylint: disable=invalid-name +class prevent_exceptions: # noqa: N801,N806 pylint: disable=invalid-name """Decorator to ignore and log exceptions. diff --git a/tests/conftest.py b/tests/conftest.py index 9c52f6800..da0bded55 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -35,7 +35,7 @@ pytest.register_assert_rewrite('helpers') from helpers import logfail from helpers.logfail import fail_on_logging from helpers.messagemock import message_mock -from helpers.fixtures import * +from helpers.fixtures import * # noqa: F403 from qutebrowser.utils import qtutils, standarddir, usertypes, utils from qutebrowser.misc import objects diff --git a/tests/helpers/fixtures.py b/tests/helpers/fixtures.py index 5cbf01aad..427cdcc0d 100644 --- a/tests/helpers/fixtures.py +++ b/tests/helpers/fixtures.py @@ -17,7 +17,7 @@ # You should have received a copy of the GNU General Public License # along with qutebrowser. If not, see . -# pylint: disable=invalid-name +# noqa: N801,N806 pylint: disable=invalid-name """pytest fixtures used by the whole testsuite. diff --git a/tests/helpers/stubs.py b/tests/helpers/stubs.py index 878c9e166..9fc04aba3 100644 --- a/tests/helpers/stubs.py +++ b/tests/helpers/stubs.py @@ -17,7 +17,7 @@ # You should have received a copy of the GNU General Public License # along with qutebrowser. If not, see . -# pylint: disable=invalid-name,abstract-method +# noqa: N801,N806 pylint: disable=invalid-name,abstract-method """Fake objects/stubs.""" diff --git a/tests/unit/commands/test_cmdutils.py b/tests/unit/commands/test_cmdutils.py index e123ce2d2..ca751074d 100644 --- a/tests/unit/commands/test_cmdutils.py +++ b/tests/unit/commands/test_cmdutils.py @@ -103,7 +103,7 @@ class TestRegister: def test_lowercasing(self): """Make sure the function name is normalized correctly (uppercase).""" @cmdutils.register() - def Test(): # pylint: disable=invalid-name + def Test(): # noqa: N801,N806 pylint: disable=invalid-name """Blah.""" pass diff --git a/tests/unit/config/test_config.py b/tests/unit/config/test_config.py index bf1969e8a..32a7a8119 100644 --- a/tests/unit/config/test_config.py +++ b/tests/unit/config/test_config.py @@ -591,7 +591,7 @@ class StyleObj(QObject): def __init__(self, stylesheet=None, parent=None): super().__init__(parent) if stylesheet is not None: - self.STYLESHEET = stylesheet # pylint: disable=invalid-name + self.STYLESHEET = stylesheet # noqa: N801,N806 pylint: disable=invalid-name self.rendered_stylesheet = None def setStyleSheet(self, stylesheet): diff --git a/tests/unit/utils/test_debug.py b/tests/unit/utils/test_debug.py index 9b77b9628..e32f564c8 100644 --- a/tests/unit/utils/test_debug.py +++ b/tests/unit/utils/test_debug.py @@ -252,8 +252,8 @@ class TestGetAllObjects: root = QObject() o1 = self.Object('Object 1', root) - o2 = self.Object('Object 2', o1) # flake8: disable=F841 - o3 = self.Object('Object 3', root) # flake8: disable=F841 + o2 = self.Object('Object 2', o1) # noqa: F841 + o3 = self.Object('Object 3', root) # noqa: F841 expected = textwrap.dedent(""" Qt widgets - 2 objects: