2014-08-06 23:51:44 +02:00
|
|
|
# vim: ft=python fileencoding=utf-8 sts=4 sw=4 et:
|
|
|
|
|
2016-01-04 07:12:39 +01:00
|
|
|
# Copyright 2014-2016 Florian Bruhin (The Compiler) <mail@qutebrowser.org>
|
2014-08-06 23:51:44 +02:00
|
|
|
|
2014-06-04 14:11:55 +02:00
|
|
|
# This file is part of qutebrowser.
|
|
|
|
#
|
|
|
|
# qutebrowser is free software: you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# qutebrowser is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with qutebrowser. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
2014-07-27 22:57:50 +02:00
|
|
|
"""Early initialization and main entry point."""
|
2014-06-04 14:11:55 +02:00
|
|
|
|
2014-07-27 22:57:50 +02:00
|
|
|
import sys
|
2015-04-01 21:28:56 +02:00
|
|
|
import json
|
2014-06-04 14:11:55 +02:00
|
|
|
|
2014-07-18 07:48:33 +02:00
|
|
|
import qutebrowser
|
2016-08-24 14:15:20 +02:00
|
|
|
from qutebrowser.utils import log
|
2014-07-27 22:57:50 +02:00
|
|
|
try:
|
2014-12-13 17:28:50 +01:00
|
|
|
from qutebrowser.misc.checkpyver import check_python_version
|
2014-07-27 22:57:50 +02:00
|
|
|
except ImportError:
|
|
|
|
try:
|
|
|
|
# python2
|
2014-12-13 17:28:50 +01:00
|
|
|
from .misc.checkpyver import check_python_version
|
2014-07-27 22:57:50 +02:00
|
|
|
except (SystemError, ValueError):
|
|
|
|
# Import without module - SystemError on Python3, ValueError (?!?) on
|
|
|
|
# Python2
|
|
|
|
sys.stderr.write("Please don't run this script directly, do something "
|
|
|
|
"like python3 -m qutebrowser instead.\n")
|
|
|
|
sys.stderr.flush()
|
|
|
|
sys.exit(100)
|
2014-06-04 14:11:55 +02:00
|
|
|
check_python_version()
|
2014-07-27 22:57:50 +02:00
|
|
|
|
2014-08-26 19:10:14 +02:00
|
|
|
import argparse
|
2014-12-13 17:28:50 +01:00
|
|
|
from qutebrowser.misc import earlyinit
|
2014-06-04 14:11:55 +02:00
|
|
|
|
|
|
|
|
2014-07-18 07:48:33 +02:00
|
|
|
def get_argparser():
|
|
|
|
"""Get the argparse parser."""
|
2015-11-22 23:09:39 +01:00
|
|
|
parser = argparse.ArgumentParser(prog='qutebrowser',
|
2014-08-26 19:10:14 +02:00
|
|
|
description=qutebrowser.__description__)
|
2016-11-15 07:09:46 +01:00
|
|
|
parser.add_argument('--basedir', help="Base directory for all storage.")
|
2014-06-06 15:52:37 +02:00
|
|
|
parser.add_argument('-V', '--version', help="Show version and quit.",
|
|
|
|
action='store_true')
|
2015-02-05 07:54:19 +01:00
|
|
|
parser.add_argument('-s', '--set', help="Set a temporary setting for "
|
2015-02-05 08:29:13 +01:00
|
|
|
"this session.", nargs=3, action='append',
|
2015-02-05 07:54:19 +01:00
|
|
|
dest='temp_settings', default=[],
|
|
|
|
metavar=('SECTION', 'OPTION', 'VALUE'))
|
2015-02-16 20:26:09 +01:00
|
|
|
parser.add_argument('-r', '--restore', help="Restore a named session.",
|
2015-03-24 07:12:35 +01:00
|
|
|
dest='session')
|
2015-03-24 07:50:23 +01:00
|
|
|
parser.add_argument('-R', '--override-restore', help="Don't restore a "
|
|
|
|
"session even if one would be restored.",
|
|
|
|
action='store_true')
|
2015-10-05 21:09:26 +02:00
|
|
|
parser.add_argument('--target', choices=['auto', 'tab', 'tab-bg',
|
|
|
|
'tab-silent', 'tab-bg-silent', 'window'],
|
2015-10-06 22:59:49 +02:00
|
|
|
help="How URLs should be opened if there is already a "
|
|
|
|
"qutebrowser instance running.")
|
2016-06-13 15:32:19 +02:00
|
|
|
parser.add_argument('--backend', choices=['webkit', 'webengine'],
|
2016-07-26 13:30:25 +02:00
|
|
|
help="Which backend to use (webengine backend is "
|
|
|
|
"EXPERIMENTAL!).", default='webkit')
|
2016-06-13 15:32:19 +02:00
|
|
|
|
2015-10-06 22:59:49 +02:00
|
|
|
parser.add_argument('--json-args', help=argparse.SUPPRESS)
|
2016-01-19 06:44:46 +01:00
|
|
|
parser.add_argument('--temp-basedir-restarted', help=argparse.SUPPRESS)
|
2015-02-05 07:54:19 +01:00
|
|
|
|
2014-06-06 15:52:37 +02:00
|
|
|
debug = parser.add_argument_group('debug arguments')
|
|
|
|
debug.add_argument('-l', '--loglevel', dest='loglevel',
|
2016-03-08 17:38:26 +01:00
|
|
|
help="Set loglevel", default='info',
|
|
|
|
choices=['critical', 'error', 'warning', 'info',
|
|
|
|
'debug', 'vdebug'])
|
2016-08-24 14:15:20 +02:00
|
|
|
debug.add_argument('--logfilter', type=logfilter_error,
|
2014-06-06 16:40:49 +02:00
|
|
|
help="Comma-separated list of things to be logged "
|
|
|
|
"to the debug log on stdout.")
|
2014-06-19 12:06:36 +02:00
|
|
|
debug.add_argument('--loglines',
|
|
|
|
help="How many lines of the debug log to keep in RAM "
|
|
|
|
"(-1: unlimited).",
|
2015-02-09 07:34:12 +01:00
|
|
|
default=2000, type=int)
|
2014-06-06 15:52:37 +02:00
|
|
|
debug.add_argument('--debug', help="Turn on debugging options.",
|
2014-06-06 16:40:49 +02:00
|
|
|
action='store_true')
|
2016-05-25 00:12:51 +02:00
|
|
|
debug.add_argument('--json-logging', action='store_true', help="Output log"
|
|
|
|
" lines in JSON format (one object per line).")
|
2014-06-06 15:52:37 +02:00
|
|
|
debug.add_argument('--nocolor', help="Turn off colored logging.",
|
2014-06-06 16:40:49 +02:00
|
|
|
action='store_false', dest='color')
|
2016-04-30 17:01:45 +02:00
|
|
|
debug.add_argument('--force-color', help="Force colored logging",
|
|
|
|
action='store_true')
|
2014-06-06 15:52:37 +02:00
|
|
|
debug.add_argument('--harfbuzz', choices=['old', 'new', 'system', 'auto'],
|
2014-06-06 16:40:49 +02:00
|
|
|
default='auto', help="HarfBuzz engine version to use. "
|
|
|
|
"Default: auto.")
|
2015-03-23 07:58:28 +01:00
|
|
|
debug.add_argument('--relaxed-config', action='store_true',
|
|
|
|
help="Silently remove unknown config options.")
|
2014-08-02 00:47:04 +02:00
|
|
|
debug.add_argument('--nowindow', action='store_true', help="Don't show "
|
|
|
|
"the main window.")
|
2014-08-05 22:17:29 +02:00
|
|
|
debug.add_argument('--debug-exit', help="Turn on debugging of late exit.",
|
|
|
|
action='store_true')
|
2015-03-29 19:45:00 +02:00
|
|
|
debug.add_argument('--pdb-postmortem', action='store_true',
|
|
|
|
help="Drop into pdb on exceptions.")
|
2015-05-16 23:26:15 +02:00
|
|
|
debug.add_argument('--temp-basedir', action='store_true', help="Use a "
|
|
|
|
"temporary basedir.")
|
2015-03-27 07:59:13 +01:00
|
|
|
debug.add_argument('--no-err-windows', action='store_true', help="Don't "
|
|
|
|
"show any error windows (used for tests/smoke.py).")
|
2016-11-16 22:32:44 +01:00
|
|
|
debug.add_argument('--qt-arg', help="Pass an argument with a value to Qt. "
|
|
|
|
"For example, you can do "
|
|
|
|
"`--qt-arg geometry 650x555+200+300` to set the window "
|
|
|
|
"geometry.", nargs=2, metavar=('NAME', 'VALUE'))
|
2016-09-09 17:56:58 +02:00
|
|
|
debug.add_argument('--qt-flag', help="Pass an argument to Qt as flag.",
|
2016-09-08 07:22:58 +02:00
|
|
|
nargs=1)
|
2014-06-04 14:11:55 +02:00
|
|
|
parser.add_argument('command', nargs='*', help="Commands to execute on "
|
|
|
|
"startup.", metavar=':command')
|
|
|
|
# URLs will actually be in command
|
2014-09-29 18:46:20 +02:00
|
|
|
parser.add_argument('url', nargs='*', help="URLs to open on startup "
|
|
|
|
"(empty as a window separator).")
|
2014-07-18 07:48:33 +02:00
|
|
|
return parser
|
2014-06-04 14:11:55 +02:00
|
|
|
|
|
|
|
|
2016-11-14 08:31:06 +01:00
|
|
|
def directory(arg):
|
|
|
|
if not arg:
|
|
|
|
raise argparse.ArgumentTypeError("Invalid empty value")
|
|
|
|
|
|
|
|
|
2016-08-24 15:12:32 +02:00
|
|
|
def logfilter_error(logfilter: str):
|
2016-08-24 16:09:34 +02:00
|
|
|
"""Validate logger names passed to --logfilter.
|
2016-08-24 15:12:32 +02:00
|
|
|
|
|
|
|
Args:
|
|
|
|
logfilter: A comma separated list of logger names.
|
|
|
|
"""
|
|
|
|
if set(logfilter.split(',')).issubset(log.LOGGER_NAMES):
|
|
|
|
return logfilter
|
|
|
|
else:
|
2016-08-25 23:12:51 +02:00
|
|
|
raise argparse.ArgumentTypeError(
|
|
|
|
"filters: Invalid value {} - expected a list of: {}".format(
|
|
|
|
logfilter, ', '.join(log.LOGGER_NAMES)))
|
2016-08-24 14:15:20 +02:00
|
|
|
|
|
|
|
|
2014-06-04 14:11:55 +02:00
|
|
|
def main():
|
2014-07-18 07:48:33 +02:00
|
|
|
parser = get_argparser()
|
2015-04-13 14:33:29 +02:00
|
|
|
if sys.platform == 'darwin' and getattr(sys, 'frozen', False):
|
|
|
|
# Ignore Mac OS X' idiotic -psn_* argument...
|
|
|
|
# http://stackoverflow.com/questions/19661298/
|
|
|
|
# http://sourceforge.net/p/cx-freeze/mailman/message/31041783/
|
|
|
|
argv = [arg for arg in sys.argv[1:] if not arg.startswith('-psn_0_')]
|
|
|
|
else:
|
|
|
|
argv = sys.argv[1:]
|
|
|
|
args = parser.parse_args(argv)
|
2015-04-01 21:28:56 +02:00
|
|
|
if args.json_args is not None:
|
|
|
|
# Restoring after a restart.
|
|
|
|
# When restarting, we serialize the argparse namespace into json, and
|
|
|
|
# construct a "fake" argparse.Namespace here based on the data loaded
|
|
|
|
# from json.
|
|
|
|
data = json.loads(args.json_args)
|
|
|
|
args = argparse.Namespace(**data)
|
2014-09-16 06:39:39 +02:00
|
|
|
earlyinit.earlyinit(args)
|
|
|
|
# We do this imports late as earlyinit needs to be run first (because of
|
|
|
|
# the harfbuzz fix and version checking).
|
2014-08-26 19:10:14 +02:00
|
|
|
from qutebrowser import app
|
2015-04-30 07:37:25 +02:00
|
|
|
return app.run(args)
|