summaryrefslogtreecommitdiff
path: root/qutebrowser/config
diff options
context:
space:
mode:
authorAnder Punnar <ander@kvlt.ee>2021-05-20 20:52:42 +0300
committerAnder Punnar <ander@kvlt.ee>2021-05-20 20:52:42 +0300
commit4e47af21586aad3846c2458dc0c8243e9d6eb792 (patch)
tree11b2073411b7decc68ba049bdfd4d97e8ab48343 /qutebrowser/config
parent2fc588358b27153721cc83e728e0d15b0e4d0d22 (diff)
parent90fbe1e181463379f38b8f0b01d488d1f7a586e0 (diff)
downloadqutebrowser-4e47af21586aad3846c2458dc0c8243e9d6eb792.tar.gz
qutebrowser-4e47af21586aad3846c2458dc0c8243e9d6eb792.zip
Merge remote-tracking branch 'origin/master' into 4nd3r/hostblock_subdomains
Diffstat (limited to 'qutebrowser/config')
-rw-r--r--qutebrowser/config/config.py13
-rw-r--r--qutebrowser/config/configcommands.py4
-rw-r--r--qutebrowser/config/configdata.yml11
-rw-r--r--qutebrowser/config/configfiles.py38
-rw-r--r--qutebrowser/config/websettings.py39
5 files changed, 78 insertions, 27 deletions
diff --git a/qutebrowser/config/config.py b/qutebrowser/config/config.py
index 374019677..437a54a33 100644
--- a/qutebrowser/config/config.py
+++ b/qutebrowser/config/config.py
@@ -97,7 +97,10 @@ class change_filter: # noqa: N801,N806 pylint: disable=invalid-name
else:
return False
- def __call__(self, func: Callable) -> Callable:
+ def __call__(
+ self,
+ func: Callable[..., None],
+ ) -> Callable[..., None]:
"""Filter calls to the decorated function.
Gets called when a function should be decorated.
@@ -105,7 +108,9 @@ class change_filter: # noqa: N801,N806 pylint: disable=invalid-name
Adds a filter which returns if we're not interested in the change-event
and calls the wrapped function if we are.
- We assume the function passed doesn't take any parameters.
+ We assume the function passed doesn't take any parameters. However, it
+ could take a "self" argument, so we can't cleary express this in the
+ type above.
Args:
func: The function to be decorated.
@@ -173,6 +178,8 @@ class KeyConfig:
result = results[0]
if result.cmd.name != "set-cmd-text":
return cmdline
+ if not result.args:
+ return None # doesn't look like this sets a command
*flags, cmd = result.args
if "-a" in flags or "--append" in flags or not cmd.startswith(":"):
return None # doesn't look like this sets a command
@@ -307,7 +314,7 @@ class Config(QObject):
def _init_values(self) -> None:
"""Populate the self._values dict."""
- self._values: Mapping = {}
+ self._values: Mapping[str, configutils.Values] = {}
for name, opt in configdata.DATA.items():
self._values[name] = configutils.Values(opt)
diff --git a/qutebrowser/config/configcommands.py b/qutebrowser/config/configcommands.py
index 2084556da..143b02fca 100644
--- a/qutebrowser/config/configcommands.py
+++ b/qutebrowser/config/configcommands.py
@@ -21,7 +21,7 @@
import os.path
import contextlib
-from typing import TYPE_CHECKING, Iterator, List, Optional
+from typing import TYPE_CHECKING, Iterator, List, Optional, Any, Tuple
from PyQt5.QtCore import QUrl
@@ -475,7 +475,7 @@ class ConfigCommands:
raise cmdutils.CommandError("{} already exists - use --force to "
"overwrite!".format(filename))
- options: List = []
+ options: List[Tuple[Optional[urlmatch.UrlPattern], configdata.Option, Any]] = []
if defaults:
options = [(None, opt, opt.default)
for _name, opt in sorted(configdata.DATA.items())]
diff --git a/qutebrowser/config/configdata.yml b/qutebrowser/config/configdata.yml
index 6cb277e5c..80732d43d 100644
--- a/qutebrowser/config/configdata.yml
+++ b/qutebrowser/config/configdata.yml
@@ -545,6 +545,7 @@ content.site_specific_quirks.skip:
- ua-whatsapp
- ua-google
- ua-slack
+ - ua-googledocs
- js-whatsapp-web
- js-discord
- js-string-replaceall
@@ -3269,6 +3270,7 @@ fonts.tabs.unselected:
fonts.web.family.standard:
default: ''
+ supports_pattern: true
type:
name: FontFamily
none_ok: true
@@ -3276,6 +3278,7 @@ fonts.web.family.standard:
fonts.web.family.fixed:
default: ''
+ supports_pattern: true
type:
name: FontFamily
none_ok: true
@@ -3283,6 +3286,7 @@ fonts.web.family.fixed:
fonts.web.family.serif:
default: ''
+ supports_pattern: true
type:
name: FontFamily
none_ok: true
@@ -3290,6 +3294,7 @@ fonts.web.family.serif:
fonts.web.family.sans_serif:
default: ''
+ supports_pattern: true
type:
name: FontFamily
none_ok: true
@@ -3297,6 +3302,7 @@ fonts.web.family.sans_serif:
fonts.web.family.cursive:
default: ''
+ supports_pattern: true
type:
name: FontFamily
none_ok: true
@@ -3304,6 +3310,7 @@ fonts.web.family.cursive:
fonts.web.family.fantasy:
default: ''
+ supports_pattern: true
type:
name: FontFamily
none_ok: true
@@ -3316,6 +3323,7 @@ fonts.web.family.fantasy:
fonts.web.size.default:
default: 16
+ supports_pattern: true
type:
name: Int
minval: 1
@@ -3324,6 +3332,7 @@ fonts.web.size.default:
fonts.web.size.default_fixed:
default: 13
+ supports_pattern: true
type:
name: Int
minval: 1
@@ -3332,6 +3341,7 @@ fonts.web.size.default_fixed:
fonts.web.size.minimum:
default: 0
+ supports_pattern: true
type:
name: Int
minval: 0
@@ -3342,6 +3352,7 @@ fonts.web.size.minimum_logical:
# This is 0 as default on QtWebKit, and 6 on QtWebEngine - so let's
# just go for 6 here.
default: 6
+ supports_pattern: true
type:
name: Int
minval: 0
diff --git a/qutebrowser/config/configfiles.py b/qutebrowser/config/configfiles.py
index f8566e2d0..6f0d0b13c 100644
--- a/qutebrowser/config/configfiles.py
+++ b/qutebrowser/config/configfiles.py
@@ -30,7 +30,7 @@ import configparser
import contextlib
import re
from typing import (TYPE_CHECKING, Any, Dict, Iterable, Iterator, List, Mapping,
- MutableMapping, Optional, cast)
+ MutableMapping, Optional, Tuple, cast)
import yaml
from PyQt5.QtCore import pyqtSignal, pyqtSlot, QObject, QSettings, qVersion
@@ -39,7 +39,7 @@ import qutebrowser
from qutebrowser.config import (configexc, config, configdata, configutils,
configtypes)
from qutebrowser.keyinput import keyutils
-from qutebrowser.utils import standarddir, utils, qtutils, log, urlmatch
+from qutebrowser.utils import standarddir, utils, qtutils, log, urlmatch, version
if TYPE_CHECKING:
from qutebrowser.misc import savemanager
@@ -89,6 +89,7 @@ class StateConfig(configparser.ConfigParser):
self.read(self._filename, encoding='utf-8')
self.qt_version_changed = False
+ self.qtwe_version_changed = False
self.qutebrowser_version_changed = VersionChange.unknown
self._set_changed_attributes()
@@ -108,8 +109,20 @@ class StateConfig(configparser.ConfigParser):
self[sect].pop(key, None)
self['general']['qt_version'] = qVersion()
+ self['general']['qtwe_version'] = self._qtwe_version_str()
self['general']['version'] = qutebrowser.__version__
+ def _qtwe_version_str(self) -> str:
+ """Get the QtWebEngine version string.
+
+ Note that it's too early to use objects.backend here...
+ """
+ try:
+ import PyQt5.QtWebEngineWidgets # pylint: disable=unused-import
+ except ImportError:
+ return 'no'
+ return str(version.qtwebengine_versions(avoid_init=True).webengine)
+
def _set_changed_attributes(self) -> None:
"""Set qt_version_changed/qutebrowser_version_changed attributes.
@@ -123,6 +136,9 @@ class StateConfig(configparser.ConfigParser):
old_qt_version = self['general'].get('qt_version', None)
self.qt_version_changed = old_qt_version != qVersion()
+ old_qtwe_version = self['general'].get('qtwe_version', None)
+ self.qtwe_version_changed = old_qtwe_version != self._qtwe_version_str()
+
old_qutebrowser_version = self['general'].get('version', None)
if old_qutebrowser_version is None:
# https://github.com/python/typeshed/issues/2093
@@ -286,18 +302,18 @@ class YamlConfig(QObject):
self._validate_names(settings)
self._build_values(settings)
- def _load_settings_object(self, yaml_data: Any) -> '_SettingsType':
+ def _load_settings_object(self, yaml_data: Any) -> _SettingsType:
"""Load the settings from the settings: key."""
return self._pop_object(yaml_data, 'settings', dict)
- def _load_legacy_settings_object(self, yaml_data: Any) -> '_SettingsType':
+ def _load_legacy_settings_object(self, yaml_data: Any) -> _SettingsType:
data = self._pop_object(yaml_data, 'global', dict)
settings = {}
for name, value in data.items():
settings[name] = {'global': value}
return settings
- def _build_values(self, settings: Mapping) -> None:
+ def _build_values(self, settings: Mapping[str, Any]) -> None:
"""Build up self._values from the values in the given dict."""
errors = []
for name, yaml_values in settings.items():
@@ -724,9 +740,17 @@ class ConfigPyWriter:
def __init__(
self,
- options: List,
+ options: List[
+ Tuple[
+ Optional[urlmatch.UrlPattern],
+ configdata.Option,
+ Any
+ ]
+ ],
bindings: MutableMapping[str, Mapping[str, Optional[str]]],
- *, commented: bool) -> None:
+ *,
+ commented: bool,
+ ) -> None:
self._options = options
self._bindings = bindings
self._commented = commented
diff --git a/qutebrowser/config/websettings.py b/qutebrowser/config/websettings.py
index 1b07baab7..7556d2b6d 100644
--- a/qutebrowser/config/websettings.py
+++ b/qutebrowser/config/websettings.py
@@ -23,7 +23,7 @@ import re
import argparse
import functools
import dataclasses
-from typing import Any, Callable, Dict, Optional
+from typing import Any, Callable, Dict, Optional, Union
from PyQt5.QtCore import QUrl, pyqtSlot, qVersion
from PyQt5.QtGui import QFont
@@ -85,7 +85,11 @@ class AttributeInfo:
"""Info about a settings attribute."""
- def __init__(self, *attributes: Any, converter: Callable = None) -> None:
+ def __init__(
+ self,
+ *attributes: Any,
+ converter: Callable[[Any], bool] = None,
+ ) -> None:
self.attributes = attributes
if converter is None:
self.converter = lambda val: val
@@ -105,9 +109,6 @@ class AbstractSettings:
def __init__(self, settings: Any) -> None:
self._settings = settings
- def _assert_not_unset(self, value: Any) -> None:
- assert value is not usertypes.UNSET
-
def set_attribute(self, name: str, value: Any) -> None:
"""Set the given QWebSettings/QWebEngineSettings attribute.
@@ -129,30 +130,38 @@ class AbstractSettings:
info = self._ATTRIBUTES[name]
return self._settings.testAttribute(info.attributes[0])
- def set_font_size(self, name: str, value: int) -> None:
+ def set_font_size(self, name: str, value: Union[int, usertypes.Unset]) -> None:
"""Set the given QWebSettings/QWebEngineSettings font size."""
- self._assert_not_unset(value)
family = self._FONT_SIZES[name]
- self._settings.setFontSize(family, value)
+ if value is usertypes.UNSET:
+ self._settings.resetFontSize(family)
+ else:
+ self._settings.setFontSize(family, value)
- def set_font_family(self, name: str, value: Optional[str]) -> None:
+ def set_font_family(
+ self,
+ name: str,
+ value: Union[str, None, usertypes.Unset],
+ ) -> None:
"""Set the given QWebSettings/QWebEngineSettings font family.
With None (the default), QFont is used to get the default font for the
family.
"""
- self._assert_not_unset(value)
family = self._FONT_FAMILIES[name]
- if value is None:
+ if value is usertypes.UNSET:
+ self._settings.resetFontFamily(family)
+ elif value is None:
font = QFont()
font.setStyleHint(self._FONT_TO_QFONT[family])
value = font.defaultFamily()
+ self._settings.setFontFamily(family, value)
+ else:
+ self._settings.setFontFamily(family, value)
- self._settings.setFontFamily(family, value)
-
- def set_default_text_encoding(self, encoding: str) -> None:
+ def set_default_text_encoding(self, encoding: Union[str, usertypes.Unset]) -> None:
"""Set the default text encoding to use."""
- self._assert_not_unset(encoding)
+ assert encoding is not usertypes.UNSET # unclear how to reset
self._settings.setDefaultTextEncoding(encoding)
def _update_setting(self, setting: str, value: Any) -> bool: