Track which settings changed for a URL

This is currently only used so only changed settings are logged, but will used
for more in the next commit.
This commit is contained in:
Florian Bruhin 2018-02-23 18:11:33 +01:00
parent 75b65e2f11
commit 2c96446bb9
2 changed files with 77 additions and 16 deletions

View File

@ -47,7 +47,10 @@ global_settings = None
class _SettingsWrapper:
"""Expose a QWebEngineSettings interface which acts on all profiles."""
"""Expose a QWebEngineSettings interface which acts on all profiles.
For read operations, the default profile value is always used.
"""
def __init__(self):
self._settings = [default_profile.settings(),
@ -69,6 +72,18 @@ class _SettingsWrapper:
for settings in self._settings:
settings.setDefaultTextEncoding(*args, **kwargs)
def testAttribute(self, *args, **kwargs):
return self._settings[0].testAttribute(*args, **kwargs)
def fontSize(self, *args, **kwargs):
return self._settings[0].fontSize(*args, **kwargs)
def fontFamily(self, *args, **kwargs):
return self._settings[0].fontFamily(*args, **kwargs)
def defaultTextEncoding(self, *args, **kwargs):
return self._settings[0].defaultTextEncoding(*args, **kwargs)
class WebEngineSettings(websettings.AbstractSettings):

View File

@ -44,54 +44,91 @@ class AbstractSettings:
"""Set the given QWebSettings/QWebEngineSettings attribute.
If the value is configutils.UNSET, the value is reset instead.
Return:
True if there was a change, False otherwise.
"""
old_value = self.test_attribute(name)
for attribute in self._ATTRIBUTES[name]:
if value is configutils.UNSET:
self._settings.resetAttribute(attribute)
new_value = self.test_attribute(name)
else:
self._settings.setAttribute(attribute, value)
new_value = value
return old_value != new_value
def test_attribute(self, name):
"""Get the value for the given attribute."""
return self._settings.testAttribute(self._ATTRIBUTES[name])
"""Get the value for the given attribute.
If the setting resolves to a list of attributes, only the first
attribute is tested.
"""
return self._settings.testAttribute(self._ATTRIBUTES[name][0])
def set_font_size(self, name, value):
"""Set the given QWebSettings/QWebEngineSettings font size."""
"""Set the given QWebSettings/QWebEngineSettings font size.
Return:
True if there was a change, False otherwise.
"""
assert value is not configutils.UNSET
self._settings.setFontSize(self._FONT_SIZES[name], value)
family = self._FONT_SIZES[name]
old_value = self._settings.fontSize(family)
self._settings.setFontSize(family, value)
return old_value != value
def set_font_family(self, name, value):
"""Set the given QWebSettings/QWebEngineSettings font family.
With None (the default), QFont is used to get the default font for the
family.
Return:
True if there was a change, False otherwise.
"""
assert value is not configutils.UNSET
family = self._FONT_FAMILIES[name]
if value is None:
font = QFont()
font.setStyleHint(self._FONT_TO_QFONT[self._FONT_FAMILIES[name]])
font.setStyleHint(self._FONT_TO_QFONT[family])
value = font.defaultFamily()
self._settings.setFontFamily(self._FONT_FAMILIES[name], value)
old_value = self._settings.fontFamily(family)
self._settings.setFontFamily(family, value)
return value != old_value
def set_default_text_encoding(self, encoding):
"""Set the default text encoding to use."""
"""Set the default text encoding to use.
Return:
True if there was a change, False otherwise.
"""
assert encoding is not configutils.UNSET
old_value = self._settings.defaultTextEncoding()
self._settings.setDefaultTextEncoding(encoding)
return old_value != encoding
def _update_setting(self, setting, value):
"""Update the given setting/value.
Unknown settings are ignored.
Return:
True if there was a change, False otherwise.
"""
if setting in self._ATTRIBUTES:
self.set_attribute(setting, value)
return self.set_attribute(setting, value)
elif setting in self._FONT_SIZES:
self.set_font_size(setting, value)
return self.set_font_size(setting, value)
elif setting in self._FONT_FAMILIES:
self.set_font_family(setting, value)
return self.set_font_family(setting, value)
elif setting == 'content.default_encoding':
self.set_default_text_encoding(value)
return self.set_default_text_encoding(value)
return False
def update_setting(self, setting):
"""Update the given setting."""
@ -99,16 +136,25 @@ class AbstractSettings:
self._update_setting(setting, value)
def update_for_url(self, url):
"""Update settings customized for the given tab."""
"""Update settings customized for the given tab.
Return:
A list of settings which actually changed.
"""
changed_settings = []
for values in config.instance:
if not values.opt.supports_pattern:
continue
value = values.get_for_url(url, fallback=False)
log.config.debug("Updating for {}: {} = {}".format(
url.toDisplayString(), values.opt.name, value))
self._update_setting(values.opt.name, value)
changed = self._update_setting(values.opt.name, value)
if changed:
log.config.debug("Changed for {}: {} = {}".format(
url.toDisplayString(), values.opt.name, value))
changed_settings.append(values.opt.name)
return changed_settings
def init_settings(self):
"""Set all supported settings correctly."""