Merge branch 'master' of ssh://cmpl.cc:2323/qutebrowser

This commit is contained in:
Florian Bruhin 2014-08-20 15:08:07 +02:00
commit 05727b2584
4 changed files with 76 additions and 50 deletions

View File

@ -106,8 +106,6 @@ https://docs.python.org/3.4/library/unittest.html[unittest] framework
* http://pylint.org/[pylint]
* A custom checker for the following things:
- untracked git files
- whitespace/CRLF problems
- `set_trace` invocations
- VCS conflict markers
If you changed `setup.py` or `MANIFEST.in`, add the `--setup` argument to run
@ -116,6 +114,9 @@ the following additional checkers:
* https://pypi.python.org/pypi/pyroma/0.9.3[pyroma]
* https://github.com/mgedmin/check-manifest[check-manifest]
It needs all the checkers to be installed and also needs
https://pypi.python.org/pypi/colorama/[colorama].
Please make sure this script runs without any warnings on your new
contributions. There's of course the possibility of false-positives, and the
following techniques are useful to handle these:

View File

@ -41,30 +41,29 @@ def _missing_str(name, debian=None, arch=None, windows=None, pip=None):
windows: String to be displayed for Windows.
pip: pypi package name.
"""
blocks = ["Fatal error: {} is required to run qutebrowser but could "
"not be imported! Maybe it's not installed?".format(name)]
blocks = ["Fatal error: <b>{}</b> is required to run qutebrowser but "
"could not be imported! Maybe it's not installed?".format(name)]
if debian is not None:
lines = ["On Debian/Ubuntu:"]
for line in debian.splitlines():
lines.append(' ' + line)
blocks.append('\n'.join(lines))
lines = ["<b>On Debian/Ubuntu:</b>"]
lines += debian.splitlines()
blocks.append('<br />'.join(lines))
if arch is not None:
lines = ["On Archlinux:"]
for line in arch.splitlines():
lines.append(' ' + line)
blocks.append('\n'.join(lines))
lines = ["<b>On Archlinux:</b>"]
lines += arch.splitlines()
blocks.append('<br />'.join(lines))
if windows is not None:
lines = ["On Windows:"]
for line in windows.splitlines():
lines.append(' ' + line)
blocks.append('\n'.join(lines))
lines = ["For other distributions:",
" Check your package manager for similiarly named packages."]
lines = ["<b>On Windows:</b>"]
lines += windows.splitlines()
blocks.append('<br />'.join(lines))
lines = ["<b>For other distributions:</b>",
"Check your package manager for similiarly named packages or "
"install via pip."]
blocks.append('<br />'.join(lines))
if pip is not None:
lines.append(" Or run pip install {} (using python3/pip3)".format(
pip))
blocks.append('\n'.join(lines))
return '\n\n'.join(blocks)
lines = ["<b>Using pip:</b>"]
lines.append("pip3 install {}".format(pip))
blocks.append('<br />'.join(lines))
return '<br /><br />'.join(blocks)
def _die(message, exception=True):
@ -77,12 +76,14 @@ def _die(message, exception=True):
exception: Whether to print an exception with --debug.
"""
from PyQt5.QtWidgets import QApplication, QMessageBox
from PyQt5.QtCore import Qt
if '--debug' in sys.argv and exception:
print(file=sys.stderr)
traceback.print_exc()
app = QApplication(sys.argv)
msgbox = QMessageBox(QMessageBox.Critical, "qutebrowser: Fatal error!",
message)
msgbox.setTextFormat(Qt.RichText)
msgbox.resize(msgbox.sizeHint())
msgbox.exec_()
app.quit()
@ -176,12 +177,15 @@ def check_pyqt_core():
text = _missing_str('PyQt5',
debian="apt-get install python3-pyqt5 "
"python3-pyqt5.qtwebkit",
arch="pacman -S python-pyqt5 qt5-webkit\n"
arch="pacman -S python-pyqt5 qt5-webkit<br />"
"or install the qutebrowser package from AUR",
windows="Use the installer by Riverbank computing "
"or the standalone qutebrowser exe.\n"
"or the standalone qutebrowser exe.<br />"
"http://www.riverbankcomputing.co.uk/"
"software/pyqt/download5")
text = text.replace('<b>', '')
text = text.replace('</b>', '')
text = text.replace('<br />', '\n')
if Tk:
root = Tk()
root.withdraw()
@ -237,15 +241,9 @@ def check_pypeg2():
import pypeg2 # pylint: disable=unused-variable
except ImportError:
text = _missing_str("pypeg2",
debian="No package available, try:\n"
"pip3 install pypeg2 "
"--allow-external pypeg2 "
"--allow-unverified pypeg2",
arch="pacman -S python-pypeg2",
windows="pip install pypeg2 "
"--allow-external pypeg2 "
"--allow-unverified pypeg2 "
"(using python3)",
debian="No package available, install via pip.",
arch="Install python-pypeg2 from the AUR",
windows="Install via pip.",
pip="pypeg2 --allow-external pypeg2 "
"--allow-unverified pypeg2")
_die(text)

View File

@ -36,7 +36,7 @@ try:
except ImportError:
USER_SITE = None
DEFAULT_VERSION = "5.5.1"
DEFAULT_VERSION = "5.6"
DEFAULT_URL = "https://pypi.python.org/packages/source/s/setuptools/"
def _python_cmd(*args):

View File

@ -18,7 +18,7 @@
# You should have received a copy of the GNU General Public License
# along with qutebrowser. If not, see <http://www.gnu.org/licenses/>.
# pylint: disable=broad-except
# pylint: disable=broad-except, no-member
""" Run different codecheckers over a codebase.
@ -42,6 +42,7 @@ from collections import OrderedDict
from functools import partial
from contextlib import contextmanager
import colorama as col
import pep257
from pkg_resources import load_entry_point, DistributionNotFound
@ -154,7 +155,7 @@ def check_git():
untracked.append(name)
if untracked:
status = False
print("Untracked files:")
print("{}Untracked files:{}".format(col.Fore.RED, col.Fore.RESET))
print('\n'.join(untracked))
else:
status = True
@ -260,9 +261,22 @@ def _get_checkers():
return checkers
def _checker_enabled(args, group, name):
"""Check if a named checker is enabled."""
if args.checkers == 'all':
if not args.setup and group == 'setup':
return False
else:
return True
else:
return name in args.checkers.split(',')
def main():
"""Main entry point."""
col.init()
exit_status = OrderedDict()
exit_status_bool = {}
parser = argparse.ArgumentParser(description='Run various checkers.')
parser.add_argument('-s', '--setup', help="Run additional setup checks",
action='store_true')
@ -274,27 +288,40 @@ def main():
groups = ['global']
groups += config.get('DEFAULT', 'targets').split(',')
if args.setup:
groups.append('setup')
groups.append('setup')
for group in groups:
print()
print("==================== {} ====================".format(group))
if args.checkers == 'all':
configured_checkers = None
else:
configured_checkers = args.checkers.split(',')
print("{}==================== {} ===================={}".format(
col.Fore.YELLOW, group, col.Fore.RESET))
for name, func in checkers[group].items():
if configured_checkers is None or name in configured_checkers:
print("------ {} ------".format(name))
print("{}------ {} ------{}".format(col.Fore.CYAN, name,
col.Fore.RESET))
if _checker_enabled(args, group, name):
status = func()
exit_status['{}_{}'.format(group, name)] = status
print("Exit status values:")
key = '{}_{}'.format(group, name)
exit_status[key] = status
if name == 'flake8':
# pyflakes uses True for errors and False for ok.
exit_status_bool[key] = not status
elif isinstance(status, bool):
exit_status_bool[key] = status
else:
# sys.exit(0) means no problems -> True, anything != 0
# means problems.
exit_status_bool[key] = (status == 0)
else:
print("{}Checker disabled.{}".format(
col.Fore.BLUE, col.Fore.RESET))
print()
print("{}Exit status values:{}".format(col.Fore.YELLOW, col.Fore.RESET))
for (k, v) in exit_status.items():
print(' {} - {}'.format(k, v))
ok = exit_status_bool[k]
color = col.Fore.GREEN if ok else col.Fore.RED
print('{} {} - {} ({}){}'.format(color, k, 'ok' if ok else 'FAIL',
v, col.Fore.RESET))
if all(val in (True, 0) for val in exit_status):
if all(exit_status_bool):
return 0
else:
return 1