]> git.rmz.io Git - dotfiles.git/blobdiff - qutebrowser/config.py
qutebrowser: add bindings for qute-pass
[dotfiles.git] / qutebrowser / config.py
index ff281da3133ce1f5b1124b9bf90d87c80c1a2394..a3bf1223191fb9cab7dbf64033040216208627fc 100644 (file)
 c.aliases = {'w':    'session-save',
              'quit': 'close',
              'q':    'close',
 c.aliases = {'w':    'session-save',
              'quit': 'close',
              'q':    'close',
+             'qa':   'quit',
              'wq':   'quit --save',
              'wq':   'quit --save',
+             'wqa':  'quit --save',
              'mpv':  'spawn --userscript ~/src/qutebrowser/misc/userscripts/view_in_mpv'
              }
 
              'mpv':  'spawn --userscript ~/src/qutebrowser/misc/userscripts/view_in_mpv'
              }
 
-## How often (in milliseconds) to auto-save config/cookies/etc.
+## Time interval (in milliseconds) between auto-saves of
+## config/cookies/etc.
 ## Type: Int
 # c.auto_save.interval = 15000
 
 ## Type: Int
 # c.auto_save.interval = 15000
 
@@ -25,18 +28,18 @@ c.aliases = {'w':    'session-save',
 ## Type: Bool
 c.auto_save.session = True
 
 ## Type: Bool
 c.auto_save.session = True
 
-## The backend to use to display websites. qutebrowser supports two
-## different web rendering engines / backends, QtWebKit and QtWebEngine.
-## QtWebKit was discontinued by the Qt project with Qt 5.6, but picked up
-## as a well maintained fork: https://github.com/annulen/webkit/wiki -
+## Backend to use to display websites. qutebrowser supports two different
+## web rendering engines / backends, QtWebKit and QtWebEngine. QtWebKit
+## was discontinued by the Qt project with Qt 5.6, but picked up as a
+## well maintained fork: https://github.com/annulen/webkit/wiki -
 ## qutebrowser only supports the fork. QtWebEngine is Qt's official
 ## qutebrowser only supports the fork. QtWebEngine is Qt's official
-## successor to QtWebKit. It's slightly more resource hungry that
+## successor to QtWebKit. It's slightly more resource hungry than
 ## QtWebKit and has a couple of missing features in qutebrowser, but is
 ## QtWebKit and has a couple of missing features in qutebrowser, but is
-## generally the preferred choice. This setting requires a restart.
+## generally the preferred choice.
 ## Type: String
 ## Valid values:
 ## Type: String
 ## Valid values:
-##   - webengine: Use QtWebEngine (based on Chromium)
-##   - webkit: Use QtWebKit (based on WebKit, similar to Safari)
+##   - webengine: Use QtWebEngine (based on Chromium).
+##   - webkit: Use QtWebKit (based on WebKit, similar to Safari).
 # c.backend = 'webengine'
 
 ## This setting can be used to map keys to other keys. When the key used
 # c.backend = 'webengine'
 
 ## This setting can be used to map keys to other keys. When the key used
@@ -46,7 +49,7 @@ c.auto_save.session = True
 ## when a key is bound (via `bindings.default` or `bindings.commands`),
 ## the mapping is ignored.
 ## Type: Dict
 ## when a key is bound (via `bindings.default` or `bindings.commands`),
 ## the mapping is ignored.
 ## Type: Dict
-# c.bindings.key_mappings = {'<Ctrl-6>': '<Ctrl-^>', '<Ctrl-[>': '<Escape>', '<Shift-Return>': '<Return>', '<Enter>': '<Return>', '<Shift-Enter>': '<Return>', '<Ctrl-J>': '<Return>', '<Ctrl-Enter>': '<Ctrl-Return>', '<Ctrl-M>': '<Return>'}
+# c.bindings.key_mappings = {'<Ctrl-[>': '<Escape>', '<Ctrl-6>': '<Ctrl-^>', '<Ctrl-M>': '<Return>', '<Ctrl-J>': '<Return>', '<Shift-Return>': '<Return>', '<Enter>': '<Return>', '<Shift-Enter>': '<Return>', '<Ctrl-Enter>': '<Ctrl-Return>'}
 
 ## Background color of the completion widget category headers.
 ## Type: QssColor
 
 ## Background color of the completion widget category headers.
 ## Type: QssColor
@@ -68,9 +71,10 @@ c.auto_save.session = True
 ## Type: QssColor
 # c.colors.completion.even.bg = '#333333'
 
 ## Type: QssColor
 # c.colors.completion.even.bg = '#333333'
 
-## Text color of the completion widget.
-## Type: QtColor
-# c.colors.completion.fg = 'white'
+## Text color of the completion widget. May be a single color to use for
+## all columns or a list of three colors, one for each column.
+## Type: List of QtColor, or QtColor
+# c.colors.completion.fg = ['white', 'white', 'white']
 
 ## Background color of the selected completion item.
 ## Type: QssColor
 
 ## Background color of the selected completion item.
 ## Type: QssColor
@@ -80,7 +84,7 @@ c.auto_save.session = True
 ## Type: QssColor
 # c.colors.completion.item.selected.border.bottom = '#bbbb00'
 
 ## Type: QssColor
 # c.colors.completion.item.selected.border.bottom = '#bbbb00'
 
-## Top border color of the completion widget category headers.
+## Top border color of the selected completion item.
 ## Type: QssColor
 # c.colors.completion.item.selected.border.top = '#bbbb00'
 
 ## Type: QssColor
 # c.colors.completion.item.selected.border.top = '#bbbb00'
 
@@ -88,22 +92,46 @@ c.auto_save.session = True
 ## Type: QtColor
 # c.colors.completion.item.selected.fg = 'black'
 
 ## Type: QtColor
 # c.colors.completion.item.selected.fg = 'black'
 
+## Foreground color of the matched text in the selected completion item.
+## Type: QtColor
+# c.colors.completion.item.selected.match.fg = '#ff4444'
+
 ## Foreground color of the matched text in the completion.
 ## Foreground color of the matched text in the completion.
-## Type: QssColor
+## Type: QtColor
 # c.colors.completion.match.fg = '#ff4444'
 
 ## Background color of the completion widget for odd rows.
 ## Type: QssColor
 # c.colors.completion.odd.bg = '#444444'
 
 # c.colors.completion.match.fg = '#ff4444'
 
 ## Background color of the completion widget for odd rows.
 ## Type: QssColor
 # c.colors.completion.odd.bg = '#444444'
 
-## Color of the scrollbar in completion view
+## Color of the scrollbar in the completion view.
 ## Type: QssColor
 # c.colors.completion.scrollbar.bg = '#333333'
 
 ## Type: QssColor
 # c.colors.completion.scrollbar.bg = '#333333'
 
-## Color of the scrollbar handle in completion view.
+## Color of the scrollbar handle in the completion view.
 ## Type: QssColor
 # c.colors.completion.scrollbar.fg = 'white'
 
 ## Type: QssColor
 # c.colors.completion.scrollbar.fg = 'white'
 
+## Background color of the context menu. If set to null, the Qt default
+## is used.
+## Type: QssColor
+# c.colors.contextmenu.menu.bg = None
+
+## Foreground color of the context menu. If set to null, the Qt default
+## is used.
+## Type: QssColor
+# c.colors.contextmenu.menu.fg = None
+
+## Background color of the context menu's selected item. If set to null,
+## the Qt default is used.
+## Type: QssColor
+# c.colors.contextmenu.selected.bg = None
+
+## Foreground color of the context menu's selected item. If set to null,
+## the Qt default is used.
+## Type: QssColor
+# c.colors.contextmenu.selected.fg = None
+
 ## Background color for the download bar.
 ## Type: QssColor
 # c.colors.downloads.bar.bg = 'black'
 ## Background color for the download bar.
 ## Type: QssColor
 # c.colors.downloads.bar.bg = 'black'
@@ -160,7 +188,7 @@ c.auto_save.session = True
 # c.colors.hints.fg = 'black'
 
 ## Font color for the matched part of hints.
 # c.colors.hints.fg = 'black'
 
 ## Font color for the matched part of hints.
-## Type: QssColor
+## Type: QtColor
 # c.colors.hints.match.fg = 'green'
 
 ## Background color of the keyhint widget.
 # c.colors.hints.match.fg = 'green'
 
 ## Background color of the keyhint widget.
@@ -195,7 +223,7 @@ c.auto_save.session = True
 ## Type: QssColor
 # c.colors.messages.info.border = '#333333'
 
 ## Type: QssColor
 # c.colors.messages.info.border = '#333333'
 
-## Foreground color an info message.
+## Foreground color of an info message.
 ## Type: QssColor
 # c.colors.messages.info.fg = 'white'
 
 ## Type: QssColor
 # c.colors.messages.info.fg = 'white'
 
@@ -203,11 +231,11 @@ c.auto_save.session = True
 ## Type: QssColor
 # c.colors.messages.warning.bg = 'darkorange'
 
 ## Type: QssColor
 # c.colors.messages.warning.bg = 'darkorange'
 
-## Border color of an error message.
+## Border color of a warning message.
 ## Type: QssColor
 # c.colors.messages.warning.border = '#d47300'
 
 ## Type: QssColor
 # c.colors.messages.warning.border = '#d47300'
 
-## Foreground color a warning message.
+## Foreground color of a warning message.
 ## Type: QssColor
 # c.colors.messages.warning.fg = 'white'
 
 ## Type: QssColor
 # c.colors.messages.warning.fg = 'white'
 
@@ -253,7 +281,7 @@ c.colors.prompts.bg = '#333333'
 
 ## Background color of the statusbar in private browsing + command mode.
 ## Type: QssColor
 
 ## Background color of the statusbar in private browsing + command mode.
 ## Type: QssColor
-# c.colors.statusbar.command.private.bg = 'grey'
+# c.colors.statusbar.command.private.bg = 'darkslategray'
 
 ## Foreground color of the statusbar in private browsing + command mode.
 ## Type: QssColor
 
 ## Foreground color of the statusbar in private browsing + command mode.
 ## Type: QssColor
@@ -275,6 +303,14 @@ c.colors.prompts.bg = '#333333'
 ## Type: QssColor
 # c.colors.statusbar.normal.fg = 'white'
 
 ## Type: QssColor
 # c.colors.statusbar.normal.fg = 'white'
 
+## Background color of the statusbar in passthrough mode.
+## Type: QssColor
+# c.colors.statusbar.passthrough.bg = 'darkblue'
+
+## Foreground color of the statusbar in passthrough mode.
+## Type: QssColor
+# c.colors.statusbar.passthrough.fg = 'white'
+
 ## Background color of the statusbar in private browsing mode.
 ## Type: QssColor
 # c.colors.statusbar.private.bg = '#666666'
 ## Background color of the statusbar in private browsing mode.
 ## Type: QssColor
 # c.colors.statusbar.private.bg = '#666666'
@@ -314,7 +350,7 @@ c.colors.prompts.bg = '#333333'
 # c.colors.statusbar.url.warn.fg = 'yellow'
 
 ## Background color of the tab bar.
 # c.colors.statusbar.url.warn.fg = 'yellow'
 
 ## Background color of the tab bar.
-## Type: QtColor
+## Type: QssColor
 # c.colors.tabs.bar.bg = '#555555'
 
 ## Background color of unselected even tabs.
 # c.colors.tabs.bar.bg = '#555555'
 
 ## Background color of unselected even tabs.
@@ -354,6 +390,38 @@ c.colors.prompts.bg = '#333333'
 ## Type: QtColor
 # c.colors.tabs.odd.fg = 'white'
 
 ## Type: QtColor
 # c.colors.tabs.odd.fg = 'white'
 
+## Background color of pinned unselected even tabs.
+## Type: QtColor
+# c.colors.tabs.pinned.even.bg = 'darkseagreen'
+
+## Foreground color of pinned unselected even tabs.
+## Type: QtColor
+# c.colors.tabs.pinned.even.fg = 'white'
+
+## Background color of pinned unselected odd tabs.
+## Type: QtColor
+# c.colors.tabs.pinned.odd.bg = 'seagreen'
+
+## Foreground color of pinned unselected odd tabs.
+## Type: QtColor
+# c.colors.tabs.pinned.odd.fg = 'white'
+
+## Background color of pinned selected even tabs.
+## Type: QtColor
+# c.colors.tabs.pinned.selected.even.bg = 'black'
+
+## Foreground color of pinned selected even tabs.
+## Type: QtColor
+# c.colors.tabs.pinned.selected.even.fg = 'white'
+
+## Background color of pinned selected odd tabs.
+## Type: QtColor
+# c.colors.tabs.pinned.selected.odd.bg = 'black'
+
+## Foreground color of pinned selected odd tabs.
+## Type: QtColor
+# c.colors.tabs.pinned.selected.odd.fg = 'white'
+
 ## Background color of selected even tabs.
 ## Type: QtColor
 # c.colors.tabs.selected.even.bg = 'black'
 ## Background color of selected even tabs.
 ## Type: QtColor
 # c.colors.tabs.selected.even.bg = 'black'
@@ -371,29 +439,51 @@ c.colors.prompts.bg = '#333333'
 # c.colors.tabs.selected.odd.fg = 'white'
 
 ## Background color for webpages if unset (or empty to use the theme's
 # c.colors.tabs.selected.odd.fg = 'white'
 
 ## Background color for webpages if unset (or empty to use the theme's
-## color)
+## color).
 ## Type: QtColor
 # c.colors.webpage.bg = 'white'
 
 ## Type: QtColor
 # c.colors.webpage.bg = 'white'
 
-## How many commands to save in the command history. 0: no history / -1:
+## Force `prefers-color-scheme: dark` colors for websites.
+## Type: Bool
+c.colors.webpage.prefers_color_scheme_dark = True
+
+## Number of commands to save in the command history. 0: no history / -1:
 ## unlimited
 ## Type: Int
 # c.completion.cmd_history_max_items = 100
 
 ## unlimited
 ## Type: Int
 # c.completion.cmd_history_max_items = 100
 
-## The height of the completion, in px or as percentage of the window.
+## Delay (in milliseconds) before updating completions after typing a
+## character.
+## Type: Int
+# c.completion.delay = 0
+
+## Height (in pixels or as percentage of the window) of the completion.
 ## Type: PercOrInt
 c.completion.height = 150
 
 ## Type: PercOrInt
 c.completion.height = 150
 
+## Minimum amount of characters needed to update completions.
+## Type: Int
+# c.completion.min_chars = 1
+
+## Which categories to show (in which order) in the :open completion.
+## Type: FlagList
+## Valid values:
+##   - searchengines
+##   - quickmarks
+##   - bookmarks
+##   - history
+# c.completion.open_categories = ['searchengines', 'quickmarks', 'bookmarks', 'history']
+
 ## Move on to the next part when there's only one possible completion
 ## left.
 ## Type: Bool
 c.completion.quick = False
 
 ## Move on to the next part when there's only one possible completion
 ## left.
 ## Type: Bool
 c.completion.quick = False
 
-## Padding of scrollbar handle in the completion window (in px).
+## Padding (in pixels) of the scrollbar handle in the completion window.
 ## Type: Int
 # c.completion.scrollbar.padding = 2
 
 ## Type: Int
 # c.completion.scrollbar.padding = 2
 
-## Width of the scrollbar in the completion window (in px).
+## Width (in pixels) of the scrollbar in the completion window.
 ## Type: Int
 # c.completion.scrollbar.width = 12
 
 ## Type: Int
 # c.completion.scrollbar.width = 12
 
@@ -410,16 +500,29 @@ c.completion.quick = False
 ## Type: Bool
 c.completion.shrink = True
 
 ## Type: Bool
 c.completion.shrink = True
 
-## How to format timestamps (e.g. for the history completion).
-## Type: TimestampTemplate
+## Format of timestamps (e.g. for the history completion). See
+## https://sqlite.org/lang_datefunc.html for allowed substitutions.
+## Type: String
 # c.completion.timestamp_format = '%Y-%m-%d'
 
 # c.completion.timestamp_format = '%Y-%m-%d'
 
-## How many URLs to show in the web history. 0: no history / -1:
+## Execute the best-matching command on a partial match.
+## Type: Bool
+# c.completion.use_best_match = False
+
+## A list of patterns which should not be shown in the history. This only
+## affects the completion. Matching URLs are still saved in the history
+## (and visible on the qute://history page), but hidden in the
+## completion. Changing this setting will cause the completion history to
+## be regenerated on the next start, which will take a short while.
+## Type: List of UrlPattern
+# c.completion.web_history.exclude = []
+
+## Number of URLs to show in the web history. 0: no history / -1:
 ## unlimited
 ## Type: Int
 ## unlimited
 ## Type: Int
-# c.completion.web_history_max_items = -1
+# c.completion.web_history.max_items = -1
 
 
-## Whether quitting the application requires a confirmation.
+## Require a confirmation before quitting the application.
 ## Type: ConfirmQuit
 ## Valid values:
 ##   - always: Always show a confirmation.
 ## Type: ConfirmQuit
 ## Valid values:
 ##   - always: Always show a confirmation.
@@ -428,35 +531,61 @@ c.completion.shrink = True
 ##   - never: Never show a confirmation.
 c.confirm_quit = ['downloads']
 
 ##   - never: Never show a confirmation.
 c.confirm_quit = ['downloads']
 
-## Whether support for the HTML 5 web application cache feature is
-## enabled. An application cache acts like an HTTP cache in some sense.
-## For documents that use the application cache via JavaScript, the
-## loader engine will first ask the application cache for the contents,
-## before hitting the network.
+## Automatically start playing `<video>` elements. Note: On Qt < 5.11,
+## this option needs a restart and does not support URL patterns.
+## Type: Bool
+# c.content.autoplay = True
+
+## Enable support for the HTML 5 web application cache feature. An
+## application cache acts like an HTTP cache in some sense. For documents
+## that use the application cache via JavaScript, the loader engine will
+## first ask the application cache for the contents, before hitting the
+## network.
 ## Type: Bool
 # c.content.cache.appcache = True
 
 ## Type: Bool
 # c.content.cache.appcache = True
 
-## The maximum number of pages to hold in the global memory page cache.
-## The Page Cache allows for a nicer user experience when navigating
-## forth or back to pages in the forward/back history, by pausing and
-## resuming up to _n_ pages. For more information about the feature,
-## please refer to: http://webkit.org/blog/427/webkit-page-cache-i-the-
-## basics/
+## Maximum number of pages to hold in the global memory page cache. The
+## page cache allows for a nicer user experience when navigating forth or
+## back to pages in the forward/back history, by pausing and resuming up
+## to _n_ pages. For more information about the feature, please refer to:
+## http://webkit.org/blog/427/webkit-page-cache-i-the-basics/
 ## Type: Int
 # c.content.cache.maximum_pages = 0
 
 ## Type: Int
 # c.content.cache.maximum_pages = 0
 
-## Size of the HTTP network cache. Null to use the default value.
+## Size (in bytes) of the HTTP network cache. Null to use the default
+## value. With QtWebEngine, the maximum supported value is 2147483647 (~2
+## GB).
 ## Type: Int
 # c.content.cache.size = None
 
 ## Type: Int
 # c.content.cache.size = None
 
-## Control which cookies to accept.
+## Allow websites to read canvas elements. Note this is needed for some
+## websites to work properly.
+## Type: Bool
+# c.content.canvas_reading = True
+
+## Which cookies to accept. Note that with QtWebKit, only `all` and
+## `never` are supported as per-domain values. Setting `no-3rdparty` or
+## `no-unknown-3rdparty` per-domain on QtWebKit will have the same effect
+## as `all`.
 ## Type: String
 ## Valid values:
 ##   - all: Accept all cookies.
 ## Type: String
 ## Valid values:
 ##   - all: Accept all cookies.
-##   - no-3rdparty: Accept cookies from the same origin only.
-##   - no-unknown-3rdparty: Accept cookies from the same origin only, unless a cookie is already set for the domain.
+##   - no-3rdparty: Accept cookies from the same origin only. This is known to break some sites, such as GMail.
+##   - no-unknown-3rdparty: Accept cookies from the same origin only, unless a cookie is already set for the domain. On QtWebEngine, this is the same as no-3rdparty.
 ##   - never: Don't accept cookies at all.
 ##   - never: Don't accept cookies at all.
-# c.content.cookies.accept = 'no-3rdparty'
+c.content.cookies.accept = 'never'
+
+config.set('content.cookies.accept', 'no-3rdparty', '*://*.amazon.co.uk/*')
+config.set('content.cookies.accept', 'no-3rdparty', '*://*.amazon.de/*')
+config.set('content.cookies.accept', 'no-3rdparty', '*://*.duckduckgo.com/*')
+config.set('content.cookies.accept', 'no-3rdparty', '*://*.freedesktop.org/*')
+config.set('content.cookies.accept', 'no-3rdparty', '*://*.github.com/*')
+config.set('content.cookies.accept', 'no-3rdparty', '*://*.gitlab.com/*')
+config.set('content.cookies.accept', 'no-3rdparty', '*://*.google.com/*')
+config.set('content.cookies.accept', 'no-3rdparty', '*://*.humblebundle.com/*')
+config.set('content.cookies.accept', 'no-3rdparty', '*://*.mailfence.com/*')
+config.set('content.cookies.accept', 'no-3rdparty', '*://*.reddit.com/*')
+config.set('content.cookies.accept', 'no-3rdparty', '*://*.steampowered.com/*')
 
 ## Store cookies. Note this option needs a restart with QtWebEngine on Qt
 ## < 5.9.
 
 ## Store cookies. Note this option needs a restart with QtWebEngine on Qt
 ## < 5.9.
@@ -468,22 +597,34 @@ c.confirm_quit = ['downloads']
 ## Type: String
 # c.content.default_encoding = 'iso-8859-1'
 
 ## Type: String
 # c.content.default_encoding = 'iso-8859-1'
 
-## Enable extra tools for Web developers. This needs to be enabled for
-## `:inspector` to work and also adds an _Inspect_ entry to the context
-## menu. For QtWebEngine, see `--enable-webengine-inspector` in
-## `qutebrowser --help` instead.
-## Type: Bool
-# c.content.developer_extras = False
+## Allow websites to share screen content. On Qt < 5.10, a dialog box is
+## always displayed, even if this is set to "true".
+## Type: BoolAsk
+## Valid values:
+##   - true
+##   - false
+##   - ask
+# c.content.desktop_capture = 'ask'
 
 ## Try to pre-fetch DNS entries to speed up browsing.
 ## Type: Bool
 
 ## Try to pre-fetch DNS entries to speed up browsing.
 ## Type: Bool
-c.content.dns_prefetch = True
+c.content.dns_prefetch = True
 
 ## Expand each subframe to its contents. This will flatten all the frames
 ## to become one scrollable page.
 ## Type: Bool
 # c.content.frame_flattening = False
 
 
 ## Expand each subframe to its contents. This will flatten all the frames
 ## to become one scrollable page.
 ## Type: Bool
 # c.content.frame_flattening = False
 
+## Set fullscreen notification overlay timeout in milliseconds. If set to
+## 0, no overlay will be displayed.
+## Type: Int
+# c.content.fullscreen.overlay_timeout = 3000
+
+## Limit fullscreen to the browser window (does not expand to fill the
+## screen).
+## Type: Bool
+# c.content.fullscreen.window = False
+
 ## Allow websites to request geolocations.
 ## Type: BoolAsk
 ## Valid values:
 ## Allow websites to request geolocations.
 ## Type: BoolAsk
 ## Valid values:
@@ -492,11 +633,12 @@ c.confirm_quit = ['downloads']
 ##   - ask
 # c.content.geolocation = 'ask'
 
 ##   - ask
 # c.content.geolocation = 'ask'
 
-## Value to send in the `Accept-Language` header.
+## Value to send in the `Accept-Language` header. Note that the value
+## read from JavaScript is always the global value.
 ## Type: String
 ## Type: String
-c.content.headers.accept_language = 'en-US,en,de,fr'
+c.content.headers.accept_language = 'en-UK;q=1.0, en;q=0.9, de;q=0.7, fr;q=0.7, *;q=0.5'
 
 
-## Set custom headers for qutebrowser HTTP requests.
+## Custom headers for qutebrowser HTTP requests.
 ## Type: Dict
 # c.content.headers.custom = {}
 
 ## Type: Dict
 # c.content.headers.custom = {}
 
@@ -506,42 +648,60 @@ c.content.headers.accept_language = 'en-US,en,de,fr'
 ## Type: Bool
 # c.content.headers.do_not_track = True
 
 ## Type: Bool
 # c.content.headers.do_not_track = True
 
-## Send the Referer header. The Referer header tells websites from which
-## website you were coming from when visting them.
+## When to send the Referer header. The Referer header tells websites
+## from which website you were coming from when visiting them. No restart
+## is needed with QtWebKit.
 ## Type: String
 ## Valid values:
 ##   - always: Always send the Referer.
 ##   - never: Never send the Referer. This is not recommended, as some sites may break.
 ## Type: String
 ## Valid values:
 ##   - always: Always send the Referer.
 ##   - never: Never send the Referer. This is not recommended, as some sites may break.
-##   - same-domain: Only send the Referer for the same domain. This will still protect your privacy, but shouldn't break any sites.
+##   - same-domain: Only send the Referer for the same domain. This will still protect your privacy, but shouldn't break any sites. With QtWebEngine, the referer will still be sent for other domains, but with stripped path information.
 # c.content.headers.referer = 'same-domain'
 
 # c.content.headers.referer = 'same-domain'
 
-## User agent to send. Unset to send the default.
-## Type: String
-# c.content.headers.user_agent = None
+## User agent to send.  The following placeholders are defined:  *
+## `{os_info}`: Something like "X11; Linux x86_64". * `{webkit_version}`:
+## The underlying WebKit version (set to a fixed value   with
+## QtWebEngine). * `{qt_key}`: "Qt" for QtWebKit, "QtWebEngine" for
+## QtWebEngine. * `{qt_version}`: The underlying Qt version. *
+## `{upstream_browser_key}`: "Version" for QtWebKit, "Chrome" for
+## QtWebEngine. * `{upstream_browser_version}`: The corresponding
+## Safari/Chrome version. * `{qutebrowser_version}`: The currently
+## running qutebrowser version.  The default value is equal to the
+## unchanged user agent of QtWebKit/QtWebEngine.  Note that the value
+## read from JavaScript is always the global value.
+## Type: FormatString
+# c.content.headers.user_agent = 'Mozilla/5.0 ({os_info}) AppleWebKit/{webkit_version} (KHTML, like Gecko) {qt_key}/{qt_version} {upstream_browser_key}/{upstream_browser_version} Safari/{webkit_version}'
 
 
-## Whether host blocking is enabled.
+## Enable host blocking.
 ## Type: Bool
 # c.content.host_blocking.enabled = True
 
 ## List of URLs of lists which contain hosts to block.  The file can be
 ## in one of the following formats:  - An `/etc/hosts`-like file - One
 ## host per line - A zip-file of any of the above, with either only one
 ## Type: Bool
 # c.content.host_blocking.enabled = True
 
 ## List of URLs of lists which contain hosts to block.  The file can be
 ## in one of the following formats:  - An `/etc/hosts`-like file - One
 ## host per line - A zip-file of any of the above, with either only one
-## file, or a file named   `hosts` (with any extension).
+## file, or a file   named `hosts` (with any extension).  It's also
+## possible to add a local file or directory via a `file://` URL. In case
+## of a directory, all files in the directory are read as adblock lists.
+## The file `~/.config/qutebrowser/blocked-hosts` is always read if it
+## exists.
 ## Type: List of Url
 ## Type: List of Url
-# c.content.host_blocking.lists = ['https://www.malwaredomainlist.com/hostslist/hosts.txt', 'http://someonewhocares.org/hosts/hosts', 'http://winhelp2002.mvps.org/hosts.zip', 'http://malwaredomains.lehigh.edu/files/justdomains.zip', 'https://pgl.yoyo.org/adservers/serverlist.php?hostformat=hosts&mimetype=plaintext']
-
-## List of domains that should always be loaded, despite being ad-
-## blocked. Domains may contain * and ? wildcards and are otherwise
-## required to exactly match the requested domain. Local domains are
-## always exempt from hostblocking.
-## Type: List of String
-# c.content.host_blocking.whitelist = ['piwik.org']
-
-## Enable or disable hyperlink auditing (`<a ping>`).
+# c.content.host_blocking.lists = ['https://raw.githubusercontent.com/StevenBlack/hosts/master/hosts']
+
+## A list of patterns that should always be loaded, despite being ad-
+## blocked. Note this whitelists blocked hosts, not first-party URLs. As
+## an example, if `example.org` loads an ad from `ads.example.org`, the
+## whitelisted host should be `ads.example.org`. If you want to disable
+## the adblocker on a given page, use the `content.host_blocking.enabled`
+## setting with a URL pattern instead. Local domains are always exempt
+## from hostblocking.
+## Type: List of UrlPattern
+# c.content.host_blocking.whitelist = []
+
+## Enable hyperlink auditing (`<a ping>`).
 ## Type: Bool
 # c.content.hyperlink_auditing = False
 
 ## Type: Bool
 # c.content.hyperlink_auditing = False
 
-## Whether images are automatically loaded in web pages.
+## Load images automatically in web pages.
 ## Type: Bool
 # c.content.images = True
 
 ## Type: Bool
 # c.content.images = True
 
@@ -549,32 +709,35 @@ c.content.headers.accept_language = 'en-US,en,de,fr'
 ## Type: Bool
 # c.content.javascript.alert = True
 
 ## Type: Bool
 # c.content.javascript.alert = True
 
-## Whether JavaScript can read from or write to the clipboard. With
+## Allow JavaScript to read from or write to the clipboard. With
 ## QtWebEngine, writing the clipboard as response to a user interaction
 ## is always allowed.
 ## Type: Bool
 # c.content.javascript.can_access_clipboard = False
 
 ## QtWebEngine, writing the clipboard as response to a user interaction
 ## is always allowed.
 ## Type: Bool
 # c.content.javascript.can_access_clipboard = False
 
-## Whether JavaScript can close tabs.
+## Allow JavaScript to close tabs.
 ## Type: Bool
 # c.content.javascript.can_close_tabs = False
 
 ## Type: Bool
 # c.content.javascript.can_close_tabs = False
 
-## Whether JavaScript can open new tabs without user interaction.
+## Allow JavaScript to open new tabs without user interaction.
 ## Type: Bool
 # c.content.javascript.can_open_tabs_automatically = False
 
 ## Type: Bool
 # c.content.javascript.can_open_tabs_automatically = False
 
-## Enables or disables JavaScript.
+## Enable JavaScript.
 ## Type: Bool
 # c.content.javascript.enabled = True
 
 ## Log levels to use for JavaScript console logging messages. When a
 ## JavaScript message with the level given in the dictionary key is
 ## logged, the corresponding dictionary value selects the qutebrowser
 ## Type: Bool
 # c.content.javascript.enabled = True
 
 ## Log levels to use for JavaScript console logging messages. When a
 ## JavaScript message with the level given in the dictionary key is
 ## logged, the corresponding dictionary value selects the qutebrowser
-## logger to use. On QtWebKit, the "unknown" setting is always used.
+## logger to use. On QtWebKit, the "unknown" setting is always used. The
+## following levels are valid: `none`, `debug`, `info`, `warning`,
+## `error`.
 ## Type: Dict
 ## Type: Dict
-# c.content.javascript.log = {'info': 'debug', 'warning': 'debug', 'error': 'debug', 'unknown': 'debug'}
+# c.content.javascript.log = {'unknown': 'debug', 'info': 'debug', 'warning': 'debug', 'error': 'debug'}
 
 
-## Use the standard JavaScript modal dialog for `alert()` and `confirm()`
+## Use the standard JavaScript modal dialog for `alert()` and
+## `confirm()`.
 ## Type: Bool
 # c.content.javascript.modal_dialog = False
 
 ## Type: Bool
 # c.content.javascript.modal_dialog = False
 
@@ -582,16 +745,15 @@ c.content.headers.accept_language = 'en-US,en,de,fr'
 ## Type: Bool
 # c.content.javascript.prompt = True
 
 ## Type: Bool
 # c.content.javascript.prompt = True
 
-## Whether locally loaded documents are allowed to access other local
-## urls.
+## Allow locally loaded documents to access other local URLs.
 ## Type: Bool
 # c.content.local_content_can_access_file_urls = True
 
 ## Type: Bool
 # c.content.local_content_can_access_file_urls = True
 
-## Whether locally loaded documents are allowed to access remote urls.
+## Allow locally loaded documents to access remote URLs.
 ## Type: Bool
 # c.content.local_content_can_access_remote_urls = False
 
 ## Type: Bool
 # c.content.local_content_can_access_remote_urls = False
 
-## Whether support for HTML 5 local storage and Web SQL is enabled.
+## Enable support for HTML 5 local storage and Web SQL.
 ## Type: Bool
 # c.content.local_storage = True
 
 ## Type: Bool
 # c.content.local_storage = True
 
@@ -603,8 +765,21 @@ c.content.headers.accept_language = 'en-US,en,de,fr'
 ##   - ask
 # c.content.media_capture = 'ask'
 
 ##   - ask
 # c.content.media_capture = 'ask'
 
-## Location of a netrc-file for HTTP authentication. If unset, `~/.netrc`
-## is used.
+## Allow websites to lock your mouse pointer.
+## Type: BoolAsk
+## Valid values:
+##   - true
+##   - false
+##   - ask
+# c.content.mouse_lock = 'ask'
+
+## Automatically mute tabs. Note that if the `:tab-mute` command is used,
+## the mute status for the affected tab is now controlled manually, and
+## this setting doesn't have any effect.
+## Type: Bool
+# c.content.mute = False
+
+## Netrc-file for HTTP authentication. If unset, `~/.netrc` is used.
 ## Type: File
 # c.content.netrc_file = None
 
 ## Type: File
 # c.content.netrc_file = None
 
@@ -614,20 +789,30 @@ c.content.headers.accept_language = 'en-US,en,de,fr'
 ##   - true
 ##   - false
 ##   - ask
 ##   - true
 ##   - false
 ##   - ask
-# c.content.notifications = 'ask'
+c.content.notifications = 'ask'
+config.set('content.notifications', True, '*://*.gitlab.com/*')
+config.set('content.notifications', True, '*://*.google.com/*')
 
 
-## Enable pdf.js to view PDF files in the browser. Note that the files
-## can still be downloaded by clicking the download button in the pdf.js
+## Allow pdf.js to view PDF files in the browser. Note that the files can
+## still be downloaded by clicking the download button in the pdf.js
 ## viewer.
 ## Type: Bool
 # c.content.pdfjs = False
 
 ## viewer.
 ## Type: Bool
 # c.content.pdfjs = False
 
-## Enables or disables plugins in Web pages.
+## Allow websites to request persistent storage quota via
+## `navigator.webkitPersistentStorage.requestQuota`.
+## Type: BoolAsk
+## Valid values:
+##   - true
+##   - false
+##   - ask
+# c.content.persistent_storage = 'ask'
+
+## Enable plugins in Web pages.
 ## Type: Bool
 # c.content.plugins = False
 
 ## Type: Bool
 # c.content.plugins = False
 
-## Whether the background color and images are also drawn when the page
-## is printed.
+## Draw the background color and images also when the page is printed.
 ## Type: Bool
 # c.content.print_element_backgrounds = True
 
 ## Type: Bool
 # c.content.print_element_backgrounds = True
 
@@ -636,7 +821,7 @@ c.content.headers.accept_language = 'en-US,en,de,fr'
 ## Type: Bool
 # c.content.private_browsing = False
 
 ## Type: Bool
 # c.content.private_browsing = False
 
-## The proxy to use. In addition to the listed values, you can use a
+## Proxy to use. In addition to the listed values, you can use a
 ## `socks://...` or `http://...` URL.
 ## Type: Proxy
 ## Valid values:
 ## `socks://...` or `http://...` URL.
 ## Type: Proxy
 ## Valid values:
@@ -648,6 +833,24 @@ c.content.headers.accept_language = 'en-US,en,de,fr'
 ## Type: Bool
 # c.content.proxy_dns_requests = True
 
 ## Type: Bool
 # c.content.proxy_dns_requests = True
 
+## Allow websites to register protocol handlers via
+## `navigator.registerProtocolHandler`.
+## Type: BoolAsk
+## Valid values:
+##   - true
+##   - false
+##   - ask
+# c.content.register_protocol_handler = 'ask'
+with config.pattern('*://mail.google.com/*') as p:
+    p.content.register_protocol_handler = False
+with config.pattern('*://calendar.google.com/*') as p:
+    p.content.register_protocol_handler = False
+
+## Enable quirks (such as faked user agent headers) needed to get
+## specific sites to work properly.
+## Type: Bool
+# c.content.site_specific_quirks = True
+
 ## Validate SSL handshakes.
 ## Type: BoolAsk
 ## Valid values:
 ## Validate SSL handshakes.
 ## Type: BoolAsk
 ## Valid values:
@@ -656,22 +859,41 @@ c.content.headers.accept_language = 'en-US,en,de,fr'
 ##   - ask
 # c.content.ssl_strict = 'ask'
 
 ##   - ask
 # c.content.ssl_strict = 'ask'
 
-## A list of user stylesheet filenames to use.
+## How navigation requests to URLs with unknown schemes are handled.
+## Type: String
+## Valid values:
+##   - disallow: Disallows all navigation requests to URLs with unknown schemes.
+##   - allow-from-user-interaction: Allows navigation requests to URLs with unknown schemes that are issued from user-interaction (like a mouse-click), whereas other navigation requests (for example from JavaScript) are suppressed.
+##   - allow-all: Allows all navigation requests to URLs with unknown schemes.
+# c.content.unknown_url_scheme_policy = 'allow-from-user-interaction'
+
+## List of user stylesheet filenames to use.
 ## Type: List of File, or File
 ## Type: List of File, or File
-# c.content.user_stylesheets = None
+# c.content.user_stylesheets = []
 
 
-## Enables or disables WebGL.
+## Enable WebGL.
 ## Type: Bool
 # c.content.webgl = True
 
 ## Type: Bool
 # c.content.webgl = True
 
-## Whether load requests should be monitored for cross-site scripting
-## attempts. Suspicious scripts will be blocked and reported in the
-## inspector's JavaScript console. Enabling this feature might have an
-## impact on performance.
+## Which interfaces to expose via WebRTC. On Qt 5.10, this option doesn't
+## work because of a Qt bug.
+## Type: String
+## Valid values:
+##   - all-interfaces: WebRTC has the right to enumerate all interfaces and bind them to discover public interfaces.
+##   - default-public-and-private-interfaces: WebRTC should only use the default route used by http. This also exposes the associated default private address. Default route is the route chosen by the OS on a multi-homed endpoint.
+##   - default-public-interface-only: WebRTC should only use the default route used by http. This doesn't expose any local addresses.
+##   - disable-non-proxied-udp: WebRTC should only use TCP to contact peers or servers unless the proxy server supports UDP. This doesn't expose any local addresses either.
+# c.content.webrtc_ip_handling_policy = 'all-interfaces'
+
+## Monitor load requests for cross-site scripting attempts. Suspicious
+## scripts will be blocked and reported in the inspector's JavaScript
+## console. Note that bypasses for the XSS auditor are widely known and
+## it can be abused for cross-site info leaks in some scenarios, see:
+## https://www.chromium.org/developers/design-documents/xss-auditor
 ## Type: Bool
 # c.content.xss_auditing = False
 
 ## Type: Bool
 # c.content.xss_auditing = False
 
-## The directory to save downloads to. If unset, a sensible os-specific
+## Directory to save downloads to. If unset, a sensible OS-specific
 ## default is used.
 ## Type: Directory
 c.downloads.location.directory = "~/downloads"
 ## default is used.
 ## Type: Directory
 c.downloads.location.directory = "~/downloads"
@@ -693,9 +915,9 @@ c.downloads.location.directory = "~/downloads"
 ##   - both: Show download path and filename.
 # c.downloads.location.suggestion = 'path'
 
 ##   - both: Show download path and filename.
 # c.downloads.location.suggestion = 'path'
 
-## The default program used to open downloads. If null, the default
-## internal handler is used. Any `{}` in the string will be expanded to
-## the filename, else the filename will be appended.
+## Default program used to open downloads. If null, the default internal
+## handler is used. Any `{}` in the string will be expanded to the
+## filename, else the filename will be appended.
 ## Type: String
 c.downloads.open_dispatcher = "rifle"
 
 ## Type: String
 c.downloads.open_dispatcher = "rifle"
 
@@ -706,15 +928,19 @@ c.downloads.open_dispatcher = "rifle"
 ##   - bottom
 # c.downloads.position = 'top'
 
 ##   - bottom
 # c.downloads.position = 'top'
 
-## Number of milliseconds to wait before removing finished downloads. If
-## set to -1, downloads are never removed.
+## Duration (in milliseconds) to wait before removing finished downloads.
+## If set to -1, downloads are never removed.
 ## Type: Int
 # c.downloads.remove_finished = -1
 
 ## Type: Int
 # c.downloads.remove_finished = -1
 
-## The editor (and arguments) to use for the `open-editor` command. `{}`
-## gets replaced by the filename of the file to be edited.
+## Editor (and arguments) to use for the `open-editor` command. The
+## following placeholders are defined:  * `{file}`: Filename of the file
+## to be edited. * `{line}`: Line in which the caret is found in the
+## text. * `{column}`: Column in which the caret is found in the text. *
+## `{line0}`: Same as `{line}`, but starting from index 0. * `{column0}`:
+## Same as `{column}`, but starting from index 0.
 ## Type: ShellCommand
 ## Type: ShellCommand
-c.editor.command = ['urxvtc', '-e', 'vim', '{}']
+c.editor.command = ['urxvtc', '-e', 'vim', '{file}', '-c', 'normal {line}G{column0}l']
 
 ## Encoding to use for the editor.
 ## Type: Encoding
 
 ## Encoding to use for the editor.
 ## Type: Encoding
@@ -722,56 +948,69 @@ c.editor.command = ['urxvtc', '-e', 'vim', '{}']
 
 ## Font used in the completion categories.
 ## Type: Font
 
 ## Font used in the completion categories.
 ## Type: Font
-# c.fonts.completion.category = 'bold 8pt monospace'
+# c.fonts.completion.category = 'bold default_size default_family'
 
 ## Font used in the completion widget.
 ## Type: Font
 
 ## Font used in the completion widget.
 ## Type: Font
-# c.fonts.completion.entry = '8pt monospace'
+# c.fonts.completion.entry = 'default_size default_family'
+
+## Font used for the context menu. If set to null, the Qt default is
+## used.
+## Type: Font
+# c.fonts.contextmenu = None
 
 ## Font used for the debugging console.
 ## Type: QtFont
 
 ## Font used for the debugging console.
 ## Type: QtFont
-# c.fonts.debug_console = '8pt monospace'
+# c.fonts.debug_console = 'default_size default_family'
+
+## Default font families to use. Whenever "default_family" is used in a
+## font setting, it's replaced with the fonts listed here. If set to an
+## empty value, a system-specific monospace default is used.
+## Type: List of Font, or Font
+c.fonts.default_family = ["Hack"]
+
+## Default font size to use. Whenever "default_size" is used in a font
+## setting, it's replaced with the size listed here. Valid values are
+## either a float value with a "pt" suffix, or an integer value with a
+## "px" suffix.
+## Type: String
+# c.fonts.default_size = '10pt'
 
 ## Font used for the downloadbar.
 ## Type: Font
 
 ## Font used for the downloadbar.
 ## Type: Font
-# c.fonts.downloads = '8pt monospace'
+# c.fonts.downloads = 'default_size default_family'
 
 ## Font used for the hints.
 ## Type: Font
 
 ## Font used for the hints.
 ## Type: Font
-# c.fonts.hints = 'bold 10pt monospace'
+# c.fonts.hints = 'bold default_size default_family'
 
 ## Font used in the keyhint widget.
 ## Type: Font
 
 ## Font used in the keyhint widget.
 ## Type: Font
-# c.fonts.keyhint = '8pt monospace'
+# c.fonts.keyhint = 'default_size default_family'
 
 ## Font used for error messages.
 ## Type: Font
 
 ## Font used for error messages.
 ## Type: Font
-# c.fonts.messages.error = '8pt monospace'
+# c.fonts.messages.error = 'default_size default_family'
 
 ## Font used for info messages.
 ## Type: Font
 
 ## Font used for info messages.
 ## Type: Font
-# c.fonts.messages.info = '8pt monospace'
+# c.fonts.messages.info = 'default_size default_family'
 
 ## Font used for warning messages.
 ## Type: Font
 
 ## Font used for warning messages.
 ## Type: Font
-# c.fonts.messages.warning = '8pt monospace'
-
-## Default monospace fonts. Whenever "monospace" is used in a font
-## setting, it's replaced with the fonts listed here.
-## Type: Font
-c.fonts.monospace = 'Hack, "xos4 Terminus", Terminus, Monospace, "DejaVu Sans Mono", Monaco, "Bitstream Vera Sans Mono", "Andale Mono", "Courier New", Courier, "Liberation Mono", monospace, Fixed, Consolas, Terminal'
+# c.fonts.messages.warning = 'default_size default_family'
 
 ## Font used for prompts.
 ## Type: Font
 
 ## Font used for prompts.
 ## Type: Font
-# c.fonts.prompts = '8pt sans-serif'
+# c.fonts.prompts = 'default_size sans-serif'
 
 ## Font used in the statusbar.
 ## Type: Font
 
 ## Font used in the statusbar.
 ## Type: Font
-# c.fonts.statusbar = '8pt monospace'
+# c.fonts.statusbar = 'default_size default_family'
 
 ## Font used in the tab bar.
 ## Type: QtFont
 
 ## Font used in the tab bar.
 ## Type: QtFont
-# c.fonts.tabs = '8pt monospace'
+# c.fonts.tabs = 'default_size default_family'
 
 ## Font family for cursive fonts.
 ## Type: FontFamily
 
 ## Font family for cursive fonts.
 ## Type: FontFamily
@@ -797,30 +1036,24 @@ c.fonts.monospace = 'Hack, "xos4 Terminus", Terminus, Monospace, "DejaVu Sans Mo
 ## Type: FontFamily
 # c.fonts.web.family.standard = ''
 
 ## Type: FontFamily
 # c.fonts.web.family.standard = ''
 
-## The default font size for regular text.
+## Default font size (in pixels) for regular text.
 ## Type: Int
 # c.fonts.web.size.default = 16
 
 ## Type: Int
 # c.fonts.web.size.default = 16
 
-## The default font size for fixed-pitch text.
+## Default font size (in pixels) for fixed-pitch text.
 ## Type: Int
 # c.fonts.web.size.default_fixed = 13
 
 ## Type: Int
 # c.fonts.web.size.default_fixed = 13
 
-## The hard minimum font size.
+## Hard minimum font size (in pixels).
 ## Type: Int
 # c.fonts.web.size.minimum = 0
 
 ## Type: Int
 # c.fonts.web.size.minimum = 0
 
-## The minimum logical font size that is applied when zooming out.
+## Minimum logical font size (in pixels) that is applied when zooming
+## out.
 ## Type: Int
 # c.fonts.web.size.minimum_logical = 6
 
 ## Type: Int
 # c.fonts.web.size.minimum_logical = 6
 
-## Force software rendering for QtWebEngine. This is needed for
-## QtWebEngine to work with Nouveau drivers. This setting requires a
-## restart.
-## Type: Bool
-# c.force_software_rendering = False
-
-## Controls when a hint can be automatically followed without pressing
-## Enter.
+## When a hint can be automatically followed without pressing Enter.
 ## Type: String
 ## Valid values:
 ##   - always: Auto-follow whenever there is only a single hint on a page.
 ## Type: String
 ## Valid values:
 ##   - always: Auto-follow whenever there is only a single hint on a page.
@@ -829,7 +1062,7 @@ c.fonts.monospace = 'Hack, "xos4 Terminus", Terminus, Monospace, "DejaVu Sans Mo
 ##   - never: The user will always need to press Enter to follow a hint.
 # c.hints.auto_follow = 'unique-match'
 
 ##   - never: The user will always need to press Enter to follow a hint.
 # c.hints.auto_follow = 'unique-match'
 
-## A timeout (in milliseconds) to ignore normal-mode key bindings after a
+## Duration (in milliseconds) to ignore normal-mode key bindings after a
 ## successful auto-follow.
 ## Type: Int
 # c.hints.auto_follow_timeout = 0
 ## successful auto-follow.
 ## Type: Int
 # c.hints.auto_follow_timeout = 0
@@ -838,11 +1071,11 @@ c.fonts.monospace = 'Hack, "xos4 Terminus", Terminus, Monospace, "DejaVu Sans Mo
 ## Type: String
 # c.hints.border = '1px solid #E3BE23'
 
 ## Type: String
 # c.hints.border = '1px solid #E3BE23'
 
-## Chars used for hint strings.
+## Characters used for hint strings.
 ## Type: UniqueCharString
 c.hints.chars = 'aoeuidhtns'
 
 ## Type: UniqueCharString
 c.hints.chars = 'aoeuidhtns'
 
-## The dictionary file to be used by the word hints.
+## Dictionary file to be used by the word hints.
 ## Type: File
 # c.hints.dictionary = '/usr/share/dict/words'
 
 ## Type: File
 # c.hints.dictionary = '/usr/share/dict/words'
 
@@ -857,51 +1090,64 @@ c.hints.chars = 'aoeuidhtns'
 ## Type: Bool
 # c.hints.hide_unmatched_rapid_hints = True
 
 ## Type: Bool
 # c.hints.hide_unmatched_rapid_hints = True
 
-## Minimum number of chars used for hint strings.
+## Leave hint mode when starting a new page load.
+## Type: Bool
+# c.hints.leave_on_load = True
+
+## Minimum number of characters used for hint strings.
 ## Type: Int
 ## Type: Int
-c.hints.min_chars = 2
+c.hints.min_chars = 2
 
 ## Mode to use for hints.
 ## Type: String
 ## Valid values:
 ##   - number: Use numeric hints. (In this mode you can also type letters from the hinted element to filter and reduce the number of elements that are hinted.)
 
 ## Mode to use for hints.
 ## Type: String
 ## Valid values:
 ##   - number: Use numeric hints. (In this mode you can also type letters from the hinted element to filter and reduce the number of elements that are hinted.)
-##   - letter: Use the chars in the `hints.chars` setting.
+##   - letter: Use the characters in the `hints.chars` setting.
 ##   - word: Use hints words based on the html elements and the extra words.
 # c.hints.mode = 'letter'
 
 ##   - word: Use hints words based on the html elements and the extra words.
 # c.hints.mode = 'letter'
 
-## A comma-separated list of regexes to use for 'next' links.
+## Comma-separated list of regular expressions to use for 'next' links.
 ## Type: List of Regex
 # c.hints.next_regexes = ['\\bnext\\b', '\\bmore\\b', '\\bnewer\\b', '\\b[>→≫]\\b', '\\b(>>|»)\\b', '\\bcontinue\\b']
 
 ## Type: List of Regex
 # c.hints.next_regexes = ['\\bnext\\b', '\\bmore\\b', '\\bnewer\\b', '\\b[>→≫]\\b', '\\b(>>|»)\\b', '\\bcontinue\\b']
 
-## A comma-separated list of regexes to use for 'prev' links.
+## Padding (in pixels) for hints.
+## Type: Padding
+# c.hints.padding = {'top': 0, 'bottom': 0, 'left': 3, 'right': 3}
+
+## Comma-separated list of regular expressions to use for 'prev' links.
 ## Type: List of Regex
 # c.hints.prev_regexes = ['\\bprev(ious)?\\b', '\\bback\\b', '\\bolder\\b', '\\b[<←≪]\\b', '\\b(<<|«)\\b']
 
 ## Type: List of Regex
 # c.hints.prev_regexes = ['\\bprev(ious)?\\b', '\\bback\\b', '\\bolder\\b', '\\b[<←≪]\\b', '\\b(<<|«)\\b']
 
+## Rounding radius (in pixels) for the edges of hints.
+## Type: Int
+# c.hints.radius = 3
+
 ## Scatter hint key chains (like Vimium) or not (like dwb). Ignored for
 ## number hints.
 ## Type: Bool
 c.hints.scatter = False
 
 ## Scatter hint key chains (like Vimium) or not (like dwb). Ignored for
 ## number hints.
 ## Type: Bool
 c.hints.scatter = False
 
-## Make chars in hint strings uppercase.
+## CSS selectors used to determine which elements on a page should have
+## hints.
+## Type: Dict
+# c.hints.selectors = {'all': ['a', 'area', 'textarea', 'select', 'input:not([type="hidden"])', 'button', 'frame', 'iframe', 'img', 'link', 'summary', '[onclick]', '[onmousedown]', '[role="link"]', '[role="option"]', '[role="button"]', '[ng-click]', '[ngClick]', '[data-ng-click]', '[x-ng-click]', '[tabindex]'], 'links': ['a[href]', 'area[href]', 'link[href]', '[role="link"][href]'], 'images': ['img'], 'media': ['audio', 'img', 'video'], 'url': ['[src]', '[href]'], 'inputs': ['input[type="text"]', 'input[type="date"]', 'input[type="datetime-local"]', 'input[type="email"]', 'input[type="month"]', 'input[type="number"]', 'input[type="password"]', 'input[type="search"]', 'input[type="tel"]', 'input[type="time"]', 'input[type="url"]', 'input[type="week"]', 'input:not([type])', 'textarea']}
+
+## Make characters in hint strings uppercase.
 ## Type: Bool
 # c.hints.uppercase = False
 
 ## Type: Bool
 # c.hints.uppercase = False
 
-## The maximum time in minutes between two history items for them to be
+## Maximum time (in minutes) between two history items for them to be
 ## considered being from the same browsing session. Items with less time
 ## between them are grouped when being displayed in `:history`. Use -1 to
 ## disable separation.
 ## Type: Int
 # c.history_gap_interval = 30
 
 ## considered being from the same browsing session. Items with less time
 ## between them are grouped when being displayed in `:history`. Use -1 to
 ## disable separation.
 ## Type: Int
 # c.history_gap_interval = 30
 
-## Find text on a page case-insensitively.
-## Type: String
-## Valid values:
-##   - always: Search case-insensitively
-##   - never: Search case-sensitively
-##   - smart: Search case-sensitively if there are capital chars
-# c.ignore_case = 'smart'
+## Allow Escape to quit the crash reporter.
+## Type: Bool
+# c.input.escape_quits_reporter = True
 
 
-## Forward unbound keys to the webview in normal mode.
+## Which unbound keys to forward to the webview in normal mode.
 ## Type: String
 ## Valid values:
 ##   - all: Forward all unbound keys.
 ## Type: String
 ## Valid values:
 ##   - all: Forward all unbound keys.
@@ -909,6 +1155,10 @@ c.hints.scatter = False
 ##   - none: Don't forward any keys.
 # c.input.forward_unbound_keys = 'auto'
 
 ##   - none: Don't forward any keys.
 # c.input.forward_unbound_keys = 'auto'
 
+## Enter insert mode if an editable element is clicked.
+## Type: Bool
+# c.input.insert_mode.auto_enter = True
+
 ## Leave insert mode if a non-editable element is clicked.
 ## Type: Bool
 # c.input.insert_mode.auto_leave = True
 ## Leave insert mode if a non-editable element is clicked.
 ## Type: Bool
 # c.input.insert_mode.auto_leave = True
@@ -918,6 +1168,12 @@ c.hints.scatter = False
 ## Type: Bool
 # c.input.insert_mode.auto_load = False
 
 ## Type: Bool
 # c.input.insert_mode.auto_load = False
 
+## Leave insert mode when starting a new page load. Patterns may be
+## unreliable on this setting, and they may match the url you are
+## navigating to, or the URL you are navigating from.
+## Type: Bool
+# c.input.insert_mode.leave_on_load = True
+
 ## Switch to insert mode when clicking flash and other plugins.
 ## Type: Bool
 # c.input.insert_mode.plugins = False
 ## Switch to insert mode when clicking flash and other plugins.
 ## Type: Bool
 # c.input.insert_mode.plugins = False
@@ -937,10 +1193,10 @@ c.hints.scatter = False
 ## Type: Bool
 # c.input.rocker_gestures = False
 
 ## Type: Bool
 # c.input.rocker_gestures = False
 
-## Enable Spatial Navigation. Spatial navigation consists in the ability
+## Enable spatial navigation. Spatial navigation consists in the ability
 ## to navigate between focusable elements in a Web page, such as
 ## hyperlinks and form controls, by using Left, Right, Up and Down arrow
 ## to navigate between focusable elements in a Web page, such as
 ## hyperlinks and form controls, by using Left, Right, Up and Down arrow
-## keys. For example, if a user presses the Right key, heuristics
+## keys. For example, if the user presses the Right key, heuristics
 ## determine whether there is an element he might be trying to reach
 ## towards the right and which element he probably wants.
 ## Type: Bool
 ## determine whether there is an element he might be trying to reach
 ## towards the right and which element he probably wants.
 ## Type: Bool
@@ -952,18 +1208,19 @@ c.hints.scatter = False
 ## Type: List of String
 # c.keyhint.blacklist = []
 
 ## Type: List of String
 # c.keyhint.blacklist = []
 
-## Time from pressing a key to seeing the keyhint dialog (ms).
+## Time (in milliseconds) from pressing a key to seeing the keyhint
+## dialog.
 ## Type: Int
 # c.keyhint.delay = 500
 
 ## Type: Int
 # c.keyhint.delay = 500
 
-## Time (in ms) to show messages in the statusbar for. Set to 0 to never
-## clear messages.
+## Rounding radius (in pixels) for the edges of the keyhint dialog.
 ## Type: Int
 ## Type: Int
-# c.messages.timeout = 2000
+# c.keyhint.radius = 6
 
 
-## Show messages in unfocused windows.
-## Type: Bool
-# c.messages.unfocused = False
+## Duration (in milliseconds) to show messages in the statusbar for. Set
+## to 0 to never clear messages.
+## Type: Int
+# c.messages.timeout = 2000
 
 ## How to open links in an existing instance if a new one is launched.
 ## This happens when e.g. opening a link from a terminal. See
 
 ## How to open links in an existing instance if a new one is launched.
 ## This happens when e.g. opening a link from a terminal. See
@@ -979,7 +1236,7 @@ c.hints.scatter = False
 # c.new_instance_open_target = 'tab'
 
 ## Which window to choose when opening links as new tabs. When
 # c.new_instance_open_target = 'tab'
 
 ## Which window to choose when opening links as new tabs. When
-## `new_instance_open_target` is not set to `window`, this is ignored.
+## `new_instance_open_target` is set to `window`, this is ignored.
 ## Type: String
 ## Valid values:
 ##   - first-opened: Open new tabs in the first (oldest) opened window.
 ## Type: String
 ## Valid values:
 ##   - first-opened: Open new tabs in the first (oldest) opened window.
@@ -988,55 +1245,196 @@ c.hints.scatter = False
 ##   - last-visible: Open new tabs in the most recently visible window.
 # c.new_instance_open_target_window = 'last-focused'
 
 ##   - last-visible: Open new tabs in the most recently visible window.
 # c.new_instance_open_target_window = 'last-focused'
 
-## Show a filebrowser in upload/download prompts.
+## Show a filebrowser in download prompts.
 ## Type: Bool
 # c.prompt.filebrowser = True
 
 ## Type: Bool
 # c.prompt.filebrowser = True
 
-## The rounding radius for the edges of prompts.
+## Rounding radius (in pixels) for the edges of prompts.
 ## Type: Int
 # c.prompt.radius = 8
 
 ## Additional arguments to pass to Qt, without leading `--`. With
 ## QtWebEngine, some Chromium arguments (see
 ## https://peter.sh/experiments/chromium-command-line-switches/ for a
 ## Type: Int
 # c.prompt.radius = 8
 
 ## Additional arguments to pass to Qt, without leading `--`. With
 ## QtWebEngine, some Chromium arguments (see
 ## https://peter.sh/experiments/chromium-command-line-switches/ for a
-## list) will work. This setting requires a restart.
+## list) will work.
 ## Type: List of String
 ## Type: List of String
-# c.qt_args = []
+# c.qt.args = []
+
+## Force a Qt platform to use. This sets the `QT_QPA_PLATFORM`
+## environment variable and is useful to force using the XCB plugin when
+## running QtWebEngine on Wayland.
+## Type: String
+# c.qt.force_platform = None
 
 
-## Show a scrollbar.
+## Force a Qt platformtheme to use. This sets the `QT_QPA_PLATFORMTHEME`
+## environment variable which controls dialogs like the filepicker. By
+## default, Qt determines the platform theme based on the desktop
+## environment.
+## Type: String
+# c.qt.force_platformtheme = None
+
+## Force software rendering for QtWebEngine. This is needed for
+## QtWebEngine to work with Nouveau drivers and can be useful in other
+## scenarios related to graphic issues.
+## Type: String
+## Valid values:
+##   - software-opengl: Tell LibGL to use a software implementation of GL (`LIBGL_ALWAYS_SOFTWARE` / `QT_XCB_FORCE_SOFTWARE_OPENGL`)
+##   - qt-quick: Tell Qt Quick to use a software renderer instead of OpenGL. (`QT_QUICK_BACKEND=software`)
+##   - chromium: Tell Chromium to disable GPU support and use Skia software rendering instead. (`--disable-gpu`)
+##   - none: Don't force software rendering.
+# c.qt.force_software_rendering = 'none'
+
+## Turn on Qt HighDPI scaling. This is equivalent to setting
+## QT_AUTO_SCREEN_SCALE_FACTOR=1 or QT_ENABLE_HIGHDPI_SCALING=1 (Qt >=
+## 5.14) in the environment. It's off by default as it can cause issues
+## with some bitmap fonts. As an alternative to this, it's possible to
+## set font sizes and the `zoom.default` setting.
 ## Type: Bool
 ## Type: Bool
-# c.scrolling.bar = False
+# c.qt.highdpi = False
+
+## When to use Chromium's low-end device mode. This improves the RAM
+## usage of renderer processes, at the expense of performance.
+## Type: String
+## Valid values:
+##   - always: Always use low-end device mode.
+##   - auto: Decide automatically (uses low-end mode with < 1 GB available RAM).
+##   - never: Never use low-end device mode.
+# c.qt.low_end_device_mode = 'auto'
+
+## Which Chromium process model to use. Alternative process models use
+## less resources, but decrease security and robustness. See the
+## following pages for more details:    -
+## https://www.chromium.org/developers/design-documents/process-models
+## - https://doc.qt.io/qt-5/qtwebengine-features.html#process-models
+## Type: String
+## Valid values:
+##   - process-per-site-instance: Pages from separate sites are put into separate processes and separate visits to the same site are also isolated.
+##   - process-per-site: Pages from separate sites are put into separate processes. Unlike Process per Site Instance, all visits to the same site will share an OS process. The benefit of this model is reduced memory consumption, because more web pages will share processes. The drawbacks include reduced security, robustness, and responsiveness.
+##   - single-process: Run all tabs in a single process. This should be used for debugging purposes only, and it disables `:open --private`.
+# c.qt.process_model = 'process-per-site-instance'
+
+## When to show the scrollbar.
+## Type: String
+## Valid values:
+##   - always: Always show the scrollbar.
+##   - never: Never show the scrollbar.
+##   - when-searching: Show the scrollbar when searching for text in the webpage. With the QtWebKit backend, this is equal to `never`.
+c.scrolling.bar = 'when-searching'
 
 ## Enable smooth scrolling for web pages. Note smooth scrolling does not
 ## work with the `:scroll-px` command.
 ## Type: Bool
 # c.scrolling.smooth = False
 
 
 ## Enable smooth scrolling for web pages. Note smooth scrolling does not
 ## work with the `:scroll-px` command.
 ## Type: Bool
 # c.scrolling.smooth = False
 
-## The name of the session to save by default. If this is set to null,
-## the session which was last loaded is saved.
+## When to find text on a page case-insensitively.
+## Type: IgnoreCase
+## Valid values:
+##   - always: Search case-insensitively.
+##   - never: Search case-sensitively.
+##   - smart: Search case-sensitively if there are capital characters.
+# c.search.ignore_case = 'smart'
+
+## Find text on a page incrementally, renewing the search for each typed
+## character.
+## Type: Bool
+# c.search.incremental = True
+
+## Wrap around at the top and bottom of the page when advancing through
+## text matches using `:search-next` and `:search-prev`.
+## Type: Bool
+# c.search.wrap = True
+
+## Name of the session to save by default. If this is set to null, the
+## session which was last loaded is saved.
 ## Type: SessionName
 ## Type: SessionName
-# c.session_default_name = None
+# c.session.default_name = None
+
+## Load a restored tab as soon as it takes focus.
+## Type: Bool
+c.session.lazy_restore = True
+
+## Languages to use for spell checking. You can check for available
+## languages and install dictionaries using scripts/dictcli.py. Run the
+## script with -h/--help for instructions.
+## Type: List of String
+## Valid values:
+##   - af-ZA: Afrikaans (South Africa)
+##   - bg-BG: Bulgarian (Bulgaria)
+##   - ca-ES: Catalan (Spain)
+##   - cs-CZ: Czech (Czech Republic)
+##   - da-DK: Danish (Denmark)
+##   - de-DE: German (Germany)
+##   - el-GR: Greek (Greece)
+##   - en-AU: English (Australia)
+##   - en-CA: English (Canada)
+##   - en-GB: English (United Kingdom)
+##   - en-US: English (United States)
+##   - es-ES: Spanish (Spain)
+##   - et-EE: Estonian (Estonia)
+##   - fa-IR: Farsi (Iran)
+##   - fo-FO: Faroese (Faroe Islands)
+##   - fr-FR: French (France)
+##   - he-IL: Hebrew (Israel)
+##   - hi-IN: Hindi (India)
+##   - hr-HR: Croatian (Croatia)
+##   - hu-HU: Hungarian (Hungary)
+##   - id-ID: Indonesian (Indonesia)
+##   - it-IT: Italian (Italy)
+##   - ko: Korean
+##   - lt-LT: Lithuanian (Lithuania)
+##   - lv-LV: Latvian (Latvia)
+##   - nb-NO: Norwegian (Norway)
+##   - nl-NL: Dutch (Netherlands)
+##   - pl-PL: Polish (Poland)
+##   - pt-BR: Portuguese (Brazil)
+##   - pt-PT: Portuguese (Portugal)
+##   - ro-RO: Romanian (Romania)
+##   - ru-RU: Russian (Russia)
+##   - sh: Serbo-Croatian
+##   - sk-SK: Slovak (Slovakia)
+##   - sl-SI: Slovenian (Slovenia)
+##   - sq: Albanian
+##   - sr: Serbian
+##   - sv-SE: Swedish (Sweden)
+##   - ta-IN: Tamil (India)
+##   - tg-TG: Tajik (Tajikistan)
+##   - tr-TR: Turkish (Turkey)
+##   - uk-UA: Ukrainian (Ukraine)
+##   - vi-VN: Vietnamese (Viet Nam)
+c.spellcheck.languages = ['en-GB']
 
 ## Hide the statusbar unless a message is shown.
 ## Type: Bool
 # c.statusbar.hide = False
 
 
 ## Hide the statusbar unless a message is shown.
 ## Type: Bool
 # c.statusbar.hide = False
 
-## Padding for the statusbar.
+## Padding (in pixels) for the statusbar.
 ## Type: Padding
 ## Type: Padding
-# c.statusbar.padding = {'left': 0, 'right': 0, 'top': 1, 'bottom': 1}
+# c.statusbar.padding = {'top': 1, 'bottom': 1, 'left': 0, 'right': 0}
 
 
-## The position of the status bar.
+## Position of the status bar.
 ## Type: VerticalPosition
 ## Valid values:
 ##   - top
 ##   - bottom
 # c.statusbar.position = 'bottom'
 
 ## Type: VerticalPosition
 ## Valid values:
 ##   - top
 ##   - bottom
 # c.statusbar.position = 'bottom'
 
+## List of widgets displayed in the statusbar.
+## Type: List of String
+## Valid values:
+##   - url: Current page URL.
+##   - scroll: Percentage of the current page position like `10%`.
+##   - scroll_raw: Raw percentage of the current page position like `10`.
+##   - history: Display an arrow when possible to go back/forward in history.
+##   - tabs: Current active tab, e.g. `2`.
+##   - keypress: Display pressed keys when composing a vi command.
+##   - progress: Progress bar for the current page loading.
+# c.statusbar.widgets = ['keypress', 'url', 'scroll', 'history', 'tabs', 'progress']
+
 ## Open new tabs (middleclick/ctrl+click) in the background.
 ## Type: Bool
 # c.tabs.background = False
 
 ## Open new tabs (middleclick/ctrl+click) in the background.
 ## Type: Bool
 # c.tabs.background = False
 
-## On which mouse button to close tabs.
+## Mouse button with which to close tabs.
 ## Type: String
 ## Valid values:
 ##   - right: Close tabs on right-click.
 ## Type: String
 ## Valid values:
 ##   - right: Close tabs on right-click.
@@ -1044,20 +1442,41 @@ c.hints.scatter = False
 ##   - none: Don't close tabs using the mouse.
 # c.tabs.close_mouse_button = 'middle'
 
 ##   - none: Don't close tabs using the mouse.
 # c.tabs.close_mouse_button = 'middle'
 
-## Scaling for favicons in the tab bar. The tab size is unchanged, so big
-## favicons also require extra `tabs.padding`.
+## How to behave when the close mouse button is pressed on the tab bar.
+## Type: String
+## Valid values:
+##   - new-tab: Open a new tab.
+##   - close-current: Close the current tab.
+##   - close-last: Close the last tab.
+##   - ignore: Don't do anything.
+# c.tabs.close_mouse_button_on_bar = 'new-tab'
+
+## Scaling factor for favicons in the tab bar. The tab size is unchanged,
+## so big favicons also require extra `tabs.padding`.
 ## Type: Float
 # c.tabs.favicons.scale = 1.0
 
 ## Type: Float
 # c.tabs.favicons.scale = 1.0
 
-## Show favicons in the tab bar.
-## Type: Bool
-# c.tabs.favicons.show = True
+## When to show favicons in the tab bar.
+## Type: String
+## Valid values:
+##   - always: Always show favicons.
+##   - never: Always hide favicons.
+##   - pinned: Show favicons only on pinned tabs.
+# c.tabs.favicons.show = 'always'
 
 
-## Padding for tab indicators
+## Maximum stack size to remember for tab switches (-1 for no maximum).
+## Type: Int
+# c.tabs.focus_stack_size = 10
+
+## Padding (in pixels) for tab indicators.
 ## Type: Padding
 ## Type: Padding
-# c.tabs.indicator_padding = {'left': 0, 'right': 4, 'top': 2, 'bottom': 2}
+# c.tabs.indicator.padding = {'top': 2, 'bottom': 2, 'left': 0, 'right': 4}
+
+## Width (in pixels) of the progress indicator (0 to disable).
+## Type: Int
+# c.tabs.indicator.width = 3
 
 
-## Behavior when the last tab is closed.
+## How to behave when the last tab is closed.
 ## Type: String
 ## Valid values:
 ##   - ignore: Don't do anything.
 ## Type: String
 ## Valid values:
 ##   - ignore: Don't do anything.
@@ -1067,11 +1486,35 @@ c.hints.scatter = False
 ##   - close: Close the window.
 # c.tabs.last_close = 'ignore'
 
 ##   - close: Close the window.
 # c.tabs.last_close = 'ignore'
 
+## Maximum width (in pixels) of tabs (-1 for no maximum). This setting
+## only applies when tabs are horizontal. This setting does not apply to
+## pinned tabs, unless `tabs.pinned.shrink` is False. This setting may
+## not apply properly if max_width is smaller than the minimum size of
+## tab contents, or smaller than tabs.min_width.
+## Type: Int
+# c.tabs.max_width = -1
+
+## Minimum width (in pixels) of tabs (-1 for the default minimum size
+## behavior). This setting only applies when tabs are horizontal. This
+## setting does not apply to pinned tabs, unless `tabs.pinned.shrink` is
+## False.
+## Type: Int
+# c.tabs.min_width = -1
+
+## When switching tabs, what input mode is applied.
+## Type: String
+## Valid values:
+##   - persist: Retain the current mode.
+##   - restore: Restore previously saved mode.
+##   - normal: Always revert to normal mode.
+# c.tabs.mode_on_change = 'normal'
+
 ## Switch between tabs using the mouse wheel.
 ## Type: Bool
 # c.tabs.mousewheel_switching = True
 
 ## Switch between tabs using the mouse wheel.
 ## Type: Bool
 # c.tabs.mousewheel_switching = True
 
-## How new tabs opened from another tab are positioned.
+## Position of new tabs opened from another tab. See
+## `tabs.new_position.stacking` for controlling stacking behavior.
 ## Type: NewTabPosition
 ## Valid values:
 ##   - prev: Before the current tab.
 ## Type: NewTabPosition
 ## Valid values:
 ##   - prev: Before the current tab.
@@ -1080,7 +1523,14 @@ c.hints.scatter = False
 ##   - last: At the end.
 # c.tabs.new_position.related = 'next'
 
 ##   - last: At the end.
 # c.tabs.new_position.related = 'next'
 
-## How new tabs which aren't opened from another tab are positioned.
+## Stack related tabs on top of each other when opened consecutively.
+## Only applies for `next` and `prev` values of
+## `tabs.new_position.related` and `tabs.new_position.unrelated`.
+## Type: Bool
+# c.tabs.new_position.stacking = True
+
+## Position of new tabs which are not opened from another tab. See
+## `tabs.new_position.stacking` for controlling stacking behavior.
 ## Type: NewTabPosition
 ## Valid values:
 ##   - prev: Before the current tab.
 ## Type: NewTabPosition
 ## Valid values:
 ##   - prev: Before the current tab.
@@ -1089,11 +1539,19 @@ c.hints.scatter = False
 ##   - last: At the end.
 c.tabs.new_position.unrelated = 'next'
 
 ##   - last: At the end.
 c.tabs.new_position.unrelated = 'next'
 
-## Padding around text for tabs
+## Padding (in pixels) around text for tabs.
 ## Type: Padding
 ## Type: Padding
-# c.tabs.padding = {'left': 5, 'right': 5, 'top': 0, 'bottom': 0}
+# c.tabs.padding = {'top': 0, 'bottom': 0, 'left': 5, 'right': 5}
+
+## Force pinned tabs to stay at fixed URL.
+## Type: Bool
+# c.tabs.pinned.frozen = True
 
 
-## The position of the tab bar.
+## Shrink pinned tabs down to their contents.
+## Type: Bool
+# c.tabs.pinned.shrink = True
+
+## Position of the tab bar.
 ## Type: Position
 ## Valid values:
 ##   - top
 ## Type: Position
 ## Valid values:
 ##   - top
@@ -1119,8 +1577,8 @@ c.tabs.select_on_remove = 'prev'
 ##   - switching: Show the tab bar when switching tabs.
 # c.tabs.show = 'always'
 
 ##   - switching: Show the tab bar when switching tabs.
 # c.tabs.show = 'always'
 
-## Time to show the tab bar before hiding it when tabs.show is set to
-## 'switching'.
+## Duration (in milliseconds) to show the tab bar before hiding it when
+## tabs.show is set to 'switching'.
 ## Type: Int
 # c.tabs.show_switching_delay = 800
 
 ## Type: Int
 # c.tabs.show_switching_delay = 800
 
@@ -1136,37 +1594,49 @@ c.tabs.select_on_remove = 'prev'
 ##   - center
 # c.tabs.title.alignment = 'left'
 
 ##   - center
 # c.tabs.title.alignment = 'left'
 
-## The format to use for the tab title. The following placeholders are
-## defined:  * `{perc}`: The percentage as a string like `[10%]`. *
-## `{perc_raw}`: The raw percentage, e.g. `10` * `{title}`: The title of
-## the current web page * `{title_sep}`: The string ` - ` if a title is
-## set, empty otherwise. * `{index}`: The index of this tab. * `{id}`:
-## The internal tab ID of this tab. * `{scroll_pos}`: The page scroll
-## position. * `{host}`: The host of the current web page. * `{backend}`:
-## Either ''webkit'' or ''webengine'' * `{private}` : Indicates when
-## private mode is enabled.
+## Format to use for the tab title. The following placeholders are
+## defined:
+##   * `{perc}`: Percentage as a string like `[10%]`.
+##   * `{perc_raw}`: Raw percentage, e.g. `10`.
+##   * `{current_title}`: Title of the current web page.
+##   * `{title_sep}`: The string ` - ` if a title is set, empty otherwise.
+##   * `{index}`: Index of this tab.
+##   * `{id}`: Internal tab ID of this tab.
+##   * `{scroll_pos}`: Page scroll position.
+##   * `{host}`: Host of the current web page.
+##   * `{backend}`: Either ''webkit'' or ''webengine''
+##   * `{private}`: Indicates when private mode is enabled.
+##   * `{current_url}`: URL of the current web page.
+##   * `{protocol}`: Protocol (http/https/...) of the current web page.
+##   * `{audio}`: Indicator for audio/mute status.
 ## Type: FormatString
 ## Type: FormatString
-# c.tabs.title.format = '{index}: {title}'
+# c.tabs.title.format = '{audio}{index}: {current_title}'
 
 
-## The format to use for the tab title for pinned tabs. The same
-## placeholders like for `tabs.title.format` are defined.
+## Format to use for the tab title for pinned tabs. The same placeholders
+## like for `tabs.title.format` are defined.
 ## Type: FormatString
 # c.tabs.title.format_pinned = '{index}'
 
 ## Type: FormatString
 # c.tabs.title.format_pinned = '{index}'
 
-## The width of the tab bar if it's vertical, in px or as percentage of
-## the window.
-## Type: PercOrInt
-# c.tabs.width.bar = '20%'
+## Show tooltips on tabs. Note this setting only affects windows opened
+## after it has been set.
+## Type: Bool
+# c.tabs.tooltips = True
 
 
-## Width of the progress indicator (0 to disable).
+## Number of close tab actions to remember, per window (-1 for no
+## maximum).
 ## Type: Int
 ## Type: Int
-# c.tabs.width.indicator = 3
+# c.tabs.undo_stack_size = 100
+
+## Width (in pixels or as percentage of the window) of the tab bar if
+## it's vertical.
+## Type: PercOrInt
+# c.tabs.width = '20%'
 
 
-## Whether to wrap when changing tabs.
+## Wrap when changing tabs.
 ## Type: Bool
 # c.tabs.wrap = True
 
 ## Type: Bool
 # c.tabs.wrap = True
 
-## Whether to start a search when something else than a URL is entered.
+## What search to start when something else than a URL is entered.
 ## Type: String
 ## Valid values:
 ##   - naive: Use simple/naive check.
 ## Type: String
 ## Valid values:
 ##   - naive: Use simple/naive check.
@@ -1174,75 +1644,83 @@ c.tabs.select_on_remove = 'prev'
 ##   - never: Never search automatically.
 # c.url.auto_search = 'naive'
 
 ##   - never: Never search automatically.
 # c.url.auto_search = 'naive'
 
-## The page to open if :open -t/-b/-w is used without URL. Use
-## `about:blank` for a blank page.
+## Page to open if :open -t/-b/-w is used without URL. Use `about:blank`
+## for a blank page.
 ## Type: FuzzyUrl
 c.url.default_page = 'https://duckduckgo.com/?t=chakra'
 
 ## Type: FuzzyUrl
 c.url.default_page = 'https://duckduckgo.com/?t=chakra'
 
-## The URL segments where `:navigate increment/decrement` will search for
-## number.
+## URL segments where `:navigate increment/decrement` will search for a
+## number.
 ## Type: FlagList
 ## Valid values:
 ##   - host
 ## Type: FlagList
 ## Valid values:
 ##   - host
+##   - port
 ##   - path
 ##   - query
 ##   - anchor
 # c.url.incdec_segments = ['path', 'query']
 
 ##   - path
 ##   - query
 ##   - anchor
 # c.url.incdec_segments = ['path', 'query']
 
-## Definitions of search engines which can be used via the address bar.
-## Maps a searchengine name (such as `DEFAULT`, or `ddg`) to a URL with a
-## `{}` placeholder. The placeholder will be replaced by the search term,
-## use `{{` and `}}` for literal `{`/`}` signs. The searchengine named
-## `DEFAULT` is used when `url.auto_search` is turned on and something
-## else than a URL was entered to be opened. Other search engines can be
-## used by prepending the search engine name to the search term, e.g.
-## `:open google qutebrowser`.
+## Open base URL of the searchengine if a searchengine shortcut is
+## invoked without parameters.
+## Type: Bool
+# c.url.open_base_url = False
+
+## Search engines which can be used via the address bar.  Maps a search
+## engine name (such as `DEFAULT`, or `ddg`) to a URL with a `{}`
+## placeholder. The placeholder will be replaced by the search term, use
+## `{{` and `}}` for literal `{`/`}` braces.  The following further
+## placeholds are defined to configure how special characters in the
+## search terms are replaced by safe characters (called 'quoting'):
+##  * `{}` and `{semiquoted}` quote everything except slashes; this is the
+##    most sensible choice for almost all search engines (for the search
+##    term `slash/and&amp` this placeholder expands to `slash/and%26amp`).
+##  * `{quoted}` quotes all characters (for `slash/and&amp` this
+##    placeholder   expands to `slash%2Fand%26amp`).
+##  * `{unquoted}` quotes nothing (for `slash/and&amp` this placeholder
+##    expands to `slash/and&amp`).
+## The search engine named `DEFAULT` is used when
+## `url.auto_search` is turned on and something else than a URL was
+## entered to be opened. Other search engines can be used by prepending
+## the search engine name to the search term, e.g.  `:open google
+## qutebrowser`.
 ## Type: Dict
 c.url.searchengines = {'DEFAULT': 'https://duckduckgo.com/?t=chakra&q={}',
                        'ddg':     'https://duckduckgo.com/?t=chakra&q={}',
 ## Type: Dict
 c.url.searchengines = {'DEFAULT': 'https://duckduckgo.com/?t=chakra&q={}',
                        'ddg':     'https://duckduckgo.com/?t=chakra&q={}',
-                       'slack':   'https://ultrahaptics.slack.com/messages/{}',
-                       'pcl':     'http://docs.pointclouds.org/trunk/search.php?query={}',
+                       'slack':   'https://focalpointpositioning.slack.com/messages/{}',
                        'std':     'http://en.cppreference.com/mwiki/index.php?title=Special%3ASearch&search={}',
                        'std':     'http://en.cppreference.com/mwiki/index.php?title=Special%3ASearch&search={}',
-                       'cv':      'http://docs.opencv.org/3.1.0/index.html#gsc.tab=0&gsc.ref=more%3A3.1&gsc.q={}' }
+                      }
 
 
-## The page(s) to open at the start.
+## Page(s) to open at the start.
 ## Type: List of FuzzyUrl, or FuzzyUrl
 ## Type: List of FuzzyUrl, or FuzzyUrl
-# c.url.start_pages = 'https://start.duckduckgo.com'
+# c.url.start_pages = ['https://start.duckduckgo.com']
 
 
-## The URL parameters to strip with `:yank url`.
+## URL parameters to strip with `:yank url`.
 ## Type: List of String
 # c.url.yank_ignored_parameters = ['ref', 'utm_source', 'utm_medium', 'utm_campaign', 'utm_term', 'utm_content']
 
 ## Type: List of String
 # c.url.yank_ignored_parameters = ['ref', 'utm_source', 'utm_medium', 'utm_campaign', 'utm_term', 'utm_content']
 
-## Hide the window decoration when using wayland (requires restart)
+## Hide the window decoration.  This setting requires a restart on
+## Wayland.
 ## Type: Bool
 ## Type: Bool
-# c.window.hide_wayland_decoration = False
+# c.window.hide_decoration = False
 
 
-## The format to use for the window title. The following placeholders are
-## defined:  * `{perc}`: The percentage as a string like `[10%]`. *
-## `{perc_raw}`: The raw percentage, e.g. `10` * `{title}`: The title of
-## the current web page * `{title_sep}`: The string ` - ` if a title is
-## set, empty otherwise. * `{id}`: The internal window ID of this window.
-## * `{scroll_pos}`: The page scroll position. * `{host}`: The host of
-## the current web page. * `{backend}`: Either ''webkit'' or
-## ''webengine'' * `{private}` : Indicates when private mode is enabled.
+## Format to use for the window title. The same placeholders like for
+## `tabs.title.format` are defined.
 ## Type: FormatString
 ## Type: FormatString
-# c.window.title_format = '{perc}{title}{title_sep}qutebrowser'
+# c.window.title_format = '{perc}{current_title}{title_sep}qutebrowser'
 
 
-## The default zoom level.
+## Default zoom level.
 ## Type: Perc
 # c.zoom.default = '100%'
 
 ## Type: Perc
 # c.zoom.default = '100%'
 
-## The available zoom levels.
+## Available zoom levels.
 ## Type: List of Perc
 # c.zoom.levels = ['25%', '33%', '50%', '67%', '75%', '90%', '100%', '110%', '125%', '150%', '175%', '200%', '250%', '300%', '400%', '500%']
 
 ## Type: List of Perc
 # c.zoom.levels = ['25%', '33%', '50%', '67%', '75%', '90%', '100%', '110%', '125%', '150%', '175%', '200%', '250%', '300%', '400%', '500%']
 
-## How much to divide the mouse wheel movements to translate them into
-## zoom increments.
+## Number of zoom increments to divide the mouse wheel movements to.
 ## Type: Int
 # c.zoom.mouse_divider = 512
 
 ## Type: Int
 # c.zoom.mouse_divider = 512
 
-## Whether the zoom factor on a frame applies only to the text or to all
-## content.
+## Apply the zoom factor on a frame only to the text or to all content.
 ## Type: Bool
 # c.zoom.text_only = False
 
 ## Type: Bool
 # c.zoom.text_only = False
 
@@ -1266,7 +1744,6 @@ c.url.searchengines = {'DEFAULT': 'https://duckduckgo.com/?t=chakra&q={}',
 # config.bind(';r', 'hint --rapid links tab-bg')
 # config.bind(';t', 'hint inputs')
 # config.bind(';y', 'hint links yank')
 # config.bind(';r', 'hint --rapid links tab-bg')
 # config.bind(';t', 'hint inputs')
 # config.bind(';y', 'hint links yank')
-config.bind('M', 'hint links spawn mpv {hint-url}')
 # config.bind('<Alt-1>', 'tab-focus 1')
 # config.bind('<Alt-2>', 'tab-focus 2')
 # config.bind('<Alt-3>', 'tab-focus 3')
 # config.bind('<Alt-1>', 'tab-focus 1')
 # config.bind('<Alt-2>', 'tab-focus 2')
 # config.bind('<Alt-3>', 'tab-focus 3')
@@ -1276,6 +1753,7 @@ config.bind('M', 'hint links spawn mpv {hint-url}')
 # config.bind('<Alt-7>', 'tab-focus 7')
 # config.bind('<Alt-8>', 'tab-focus 8')
 # config.bind('<Alt-9>', 'tab-focus -1')
 # config.bind('<Alt-7>', 'tab-focus 7')
 # config.bind('<Alt-8>', 'tab-focus 8')
 # config.bind('<Alt-9>', 'tab-focus -1')
+# config.bind('<Alt-m>', 'tab-mute')
 # config.bind('<Ctrl-A>', 'navigate increment')
 # config.bind('<Ctrl-Alt-p>', 'print')
 # config.bind('<Ctrl-B>', 'scroll-page 0 -1')
 # config.bind('<Ctrl-A>', 'navigate increment')
 # config.bind('<Ctrl-Alt-p>', 'print')
 # config.bind('<Ctrl-B>', 'scroll-page 0 -1')
@@ -1289,6 +1767,7 @@ config.bind('M', 'hint links spawn mpv {hint-url}')
 # config.bind('<Ctrl-Return>', 'follow-selected -t')
 # config.bind('<Ctrl-Shift-N>', 'open -p')
 # config.bind('<Ctrl-Shift-T>', 'undo')
 # config.bind('<Ctrl-Return>', 'follow-selected -t')
 # config.bind('<Ctrl-Shift-N>', 'open -p')
 # config.bind('<Ctrl-Shift-T>', 'undo')
+# config.bind('<Ctrl-Shift-Tab>', 'nop')
 # config.bind('<Ctrl-Shift-W>', 'close')
 # config.bind('<Ctrl-T>', 'open -t')
 # config.bind('<Ctrl-Tab>', 'tab-focus last')
 # config.bind('<Ctrl-Shift-W>', 'close')
 # config.bind('<Ctrl-T>', 'open -t')
 # config.bind('<Ctrl-Tab>', 'tab-focus last')
@@ -1323,6 +1802,9 @@ config.bind('J', 'tab-prev')
 # config.bind('PP', 'open -t -- {primary}')
 # config.bind('Pp', 'open -t -- {clipboard}')
 # config.bind('R', 'reload -f')
 # config.bind('PP', 'open -t -- {primary}')
 # config.bind('Pp', 'open -t -- {clipboard}')
 # config.bind('R', 'reload -f')
+# config.bind('Sb', 'open qute://bookmarks#bookmarks')
+# config.bind('Sh', 'open qute://history')
+# config.bind('Sq', 'open qute://bookmarks')
 # config.bind('Ss', 'open qute://settings')
 # config.bind('T', 'tab-focus')
 # config.bind('ZQ', 'quit')
 # config.bind('Ss', 'open qute://settings')
 # config.bind('T', 'tab-focus')
 # config.bind('ZQ', 'quit')
@@ -1334,12 +1816,14 @@ config.bind('J', 'tab-prev')
 # config.bind('b', 'set-cmd-text -s :quickmark-load')
 # config.bind('cd', 'download-clear')
 config.unbind('co')
 # config.bind('b', 'set-cmd-text -s :quickmark-load')
 # config.bind('cd', 'download-clear')
 config.unbind('co')
+config.bind('co', 'download-open')
 # config.bind('d', 'tab-close')
 # config.bind('f', 'hint')
 # config.bind('g$', 'tab-focus -1')
 # config.bind('g0', 'tab-focus 1')
 # config.bind('gB', 'set-cmd-text -s :bookmark-load -t')
 # config.bind('gC', 'tab-clone')
 # config.bind('d', 'tab-close')
 # config.bind('f', 'hint')
 # config.bind('g$', 'tab-focus -1')
 # config.bind('g0', 'tab-focus 1')
 # config.bind('gB', 'set-cmd-text -s :bookmark-load -t')
 # config.bind('gC', 'tab-clone')
+# config.bind('gD', 'tab-give')
 # config.bind('gO', 'set-cmd-text :open -t -r {url:pretty}')
 # config.bind('gU', 'navigate up -t')
 # config.bind('g^', 'tab-focus 1')
 # config.bind('gO', 'set-cmd-text :open -t -r {url:pretty}')
 # config.bind('gU', 'navigate up -t')
 # config.bind('g^', 'tab-focus 1')
@@ -1348,6 +1832,7 @@ config.unbind('co')
 # config.bind('gd', 'download')
 # config.bind('gf', 'view-source')
 # config.bind('gg', 'scroll-to-perc 0')
 # config.bind('gd', 'download')
 # config.bind('gf', 'view-source')
 # config.bind('gg', 'scroll-to-perc 0')
+# config.bind('gi', 'hint inputs --first')
 # config.bind('gl', 'tab-move -')
 # config.bind('gm', 'tab-move')
 # config.bind('go', 'set-cmd-text :open {url:pretty}')
 # config.bind('gl', 'tab-move -')
 # config.bind('gm', 'tab-move')
 # config.bind('go', 'set-cmd-text :open {url:pretty}')
@@ -1371,8 +1856,30 @@ config.bind('m', 'spawn mpv {url}')
 # config.bind('sk', 'set-cmd-text -s :bind')
 # config.bind('sl', 'set-cmd-text -s :set -t')
 # config.bind('ss', 'set-cmd-text -s :set')
 # config.bind('sk', 'set-cmd-text -s :bind')
 # config.bind('sl', 'set-cmd-text -s :set -t')
 # config.bind('ss', 'set-cmd-text -s :set')
+config.bind('tCH', 'spawn --userscript config-cycle-tld -p    content.cookies.accept no-3rdparty never;; reload')
+config.bind('tCh', 'spawn --userscript config-cycle-tld -p    content.cookies.accept no-3rdparty never;; reload')
+config.bind('tcH', 'spawn --userscript config-cycle-tld -p -t content.cookies.accept no-3rdparty never;; reload')
+config.bind('tch', 'spawn --userscript config-cycle-tld -p -t content.cookies.accept no-3rdparty never;; reload')
+# config.bind('tIH', 'config-cycle -p -u *://*.{url:host}/* content.images ;; reload')
+# config.bind('tIh', 'config-cycle -p -u *://{url:host}/* content.images ;; reload')
+# config.bind('tIu', 'config-cycle -p -u {url} content.images ;; reload')
+# config.bind('tPH', 'config-cycle -p -u *://*.{url:host}/* content.plugins ;; reload')
+# config.bind('tPh', 'config-cycle -p -u *://{url:host}/* content.plugins ;; reload')
+# config.bind('tPu', 'config-cycle -p -u {url} content.plugins ;; reload')
+# config.bind('tSH', 'config-cycle -p -u *://*.{url:host}/* content.javascript.enabled ;; reload')
+# config.bind('tSh', 'config-cycle -p -u *://{url:host}/* content.javascript.enabled ;; reload')
+# config.bind('tSu', 'config-cycle -p -u {url} content.javascript.enabled ;; reload')
 # config.bind('th', 'back -t')
 # config.bind('th', 'back -t')
+# config.bind('tiH', 'config-cycle -p -t -u *://*.{url:host}/* content.images ;; reload')
+# config.bind('tih', 'config-cycle -p -t -u *://{url:host}/* content.images ;; reload')
+# config.bind('tiu', 'config-cycle -p -t -u {url} content.images ;; reload')
 # config.bind('tl', 'forward -t')
 # config.bind('tl', 'forward -t')
+# config.bind('tpH', 'config-cycle -p -t -u *://*.{url:host}/* content.plugins ;; reload')
+# config.bind('tph', 'config-cycle -p -t -u *://{url:host}/* content.plugins ;; reload')
+# config.bind('tpu', 'config-cycle -p -t -u {url} content.plugins ;; reload')
+# config.bind('tsH', 'config-cycle -p -t -u *://*.{url:host}/* content.javascript.enabled ;; reload')
+# config.bind('tsh', 'config-cycle -p -t -u *://{url:host}/* content.javascript.enabled ;; reload')
+# config.bind('tsu', 'config-cycle -p -t -u {url} content.javascript.enabled ;; reload')
 # config.bind('u', 'undo')
 # config.bind('v', 'enter-mode caret')
 # config.bind('wB', 'set-cmd-text -s :bookmark-load -w')
 # config.bind('u', 'undo')
 # config.bind('v', 'enter-mode caret')
 # config.bind('wB', 'set-cmd-text -s :bookmark-load -w')
@@ -1388,13 +1895,18 @@ config.bind('m', 'spawn mpv {url}')
 # config.bind('xO', 'set-cmd-text :open -b -r {url:pretty}')
 # config.bind('xo', 'set-cmd-text -s :open -b')
 # config.bind('yD', 'yank domain -s')
 # config.bind('xO', 'set-cmd-text :open -b -r {url:pretty}')
 # config.bind('xo', 'set-cmd-text -s :open -b')
 # config.bind('yD', 'yank domain -s')
+# config.bind('yM', 'yank inline [{title}]({url}) -s')
 # config.bind('yP', 'yank pretty-url -s')
 # config.bind('yT', 'yank title -s')
 # config.bind('yY', 'yank -s')
 # config.bind('yd', 'yank domain')
 # config.bind('yP', 'yank pretty-url -s')
 # config.bind('yT', 'yank title -s')
 # config.bind('yY', 'yank -s')
 # config.bind('yd', 'yank domain')
+# config.bind('ym', 'yank inline [{title}]({url})')
 # config.bind('yp', 'yank pretty-url')
 # config.bind('yt', 'yank title')
 # config.bind('yy', 'yank')
 # config.bind('yp', 'yank pretty-url')
 # config.bind('yt', 'yank title')
 # config.bind('yy', 'yank')
+config.bind('zl',  'spawn --userscript qute-pass')
+config.bind('zul', 'spawn --userscript qute-pass --username-only')
+config.bind('zpl', 'spawn --userscript qute-pass --password-only')
 # config.bind('{{', 'navigate prev -t')
 # config.bind('}}', 'navigate next -t')
 
 # config.bind('{{', 'navigate prev -t')
 # config.bind('}}', 'navigate next -t')
 
@@ -1421,6 +1933,7 @@ config.bind('m', 'spawn mpv {url}')
 # config.bind('j', 'move-to-next-line', mode='caret')
 # config.bind('k', 'move-to-prev-line', mode='caret')
 # config.bind('l', 'move-to-next-char', mode='caret')
 # config.bind('j', 'move-to-next-line', mode='caret')
 # config.bind('k', 'move-to-prev-line', mode='caret')
 # config.bind('l', 'move-to-next-char', mode='caret')
+# config.bind('o', 'reverse-selection', mode='caret')
 # config.bind('v', 'toggle-selection', mode='caret')
 # config.bind('w', 'move-to-next-word', mode='caret')
 # config.bind('y', 'yank selection', mode='caret')
 # config.bind('v', 'toggle-selection', mode='caret')
 # config.bind('w', 'move-to-next-word', mode='caret')
 # config.bind('y', 'yank selection', mode='caret')
@@ -1435,6 +1948,7 @@ config.bind('m', 'spawn mpv {url}')
 # config.bind('<Ctrl-?>', 'rl-delete-char', mode='command')
 # config.bind('<Ctrl-A>', 'rl-beginning-of-line', mode='command')
 # config.bind('<Ctrl-B>', 'rl-backward-char', mode='command')
 # config.bind('<Ctrl-?>', 'rl-delete-char', mode='command')
 # config.bind('<Ctrl-A>', 'rl-beginning-of-line', mode='command')
 # config.bind('<Ctrl-B>', 'rl-backward-char', mode='command')
+# config.bind('<Ctrl-C>', 'completion-item-yank', mode='command')
 # config.bind('<Ctrl-D>', 'completion-item-del', mode='command')
 # config.bind('<Ctrl-E>', 'rl-end-of-line', mode='command')
 # config.bind('<Ctrl-F>', 'rl-forward-char', mode='command')
 # config.bind('<Ctrl-D>', 'completion-item-del', mode='command')
 # config.bind('<Ctrl-E>', 'rl-end-of-line', mode='command')
 # config.bind('<Ctrl-F>', 'rl-forward-char', mode='command')
@@ -1442,18 +1956,20 @@ config.bind('m', 'spawn mpv {url}')
 # config.bind('<Ctrl-K>', 'rl-kill-line', mode='command')
 # config.bind('<Ctrl-N>', 'command-history-next', mode='command')
 # config.bind('<Ctrl-P>', 'command-history-prev', mode='command')
 # config.bind('<Ctrl-K>', 'rl-kill-line', mode='command')
 # config.bind('<Ctrl-N>', 'command-history-next', mode='command')
 # config.bind('<Ctrl-P>', 'command-history-prev', mode='command')
+# config.bind('<Ctrl-Return>', 'command-accept --rapid', mode='command')
+# config.bind('<Ctrl-Shift-C>', 'completion-item-yank --sel', mode='command')
 # config.bind('<Ctrl-Shift-Tab>', 'completion-item-focus prev-category', mode='command')
 # config.bind('<Ctrl-Tab>', 'completion-item-focus next-category', mode='command')
 # config.bind('<Ctrl-U>', 'rl-unix-line-discard', mode='command')
 # config.bind('<Ctrl-W>', 'rl-unix-word-rubout', mode='command')
 # config.bind('<Ctrl-Y>', 'rl-yank', mode='command')
 # config.bind('<Ctrl-Shift-Tab>', 'completion-item-focus prev-category', mode='command')
 # config.bind('<Ctrl-Tab>', 'completion-item-focus next-category', mode='command')
 # config.bind('<Ctrl-U>', 'rl-unix-line-discard', mode='command')
 # config.bind('<Ctrl-W>', 'rl-unix-word-rubout', mode='command')
 # config.bind('<Ctrl-Y>', 'rl-yank', mode='command')
-# config.bind('<Down>', 'command-history-next', mode='command')
+# config.bind('<Down>', 'completion-item-focus --history next', mode='command')
 # config.bind('<Escape>', 'leave-mode', mode='command')
 # config.bind('<Return>', 'command-accept', mode='command')
 # config.bind('<Shift-Delete>', 'completion-item-del', mode='command')
 # config.bind('<Shift-Tab>', 'completion-item-focus prev', mode='command')
 # config.bind('<Tab>', 'completion-item-focus next', mode='command')
 # config.bind('<Escape>', 'leave-mode', mode='command')
 # config.bind('<Return>', 'command-accept', mode='command')
 # config.bind('<Shift-Delete>', 'completion-item-del', mode='command')
 # config.bind('<Shift-Tab>', 'completion-item-focus prev', mode='command')
 # config.bind('<Tab>', 'completion-item-focus next', mode='command')
-# config.bind('<Up>', 'command-history-prev', mode='command')
+# config.bind('<Up>', 'completion-item-focus --history prev', mode='command')
 
 ## Bindings for hint mode
 # config.bind('<Ctrl-B>', 'hint all tab-bg', mode='hint')
 
 ## Bindings for hint mode
 # config.bind('<Ctrl-B>', 'hint all tab-bg', mode='hint')
@@ -1465,16 +1981,18 @@ config.bind('m', 'spawn mpv {url}')
 ## Bindings for insert mode
 # config.bind('<Ctrl-E>', 'open-editor', mode='insert')
 # config.bind('<Escape>', 'leave-mode', mode='insert')
 ## Bindings for insert mode
 # config.bind('<Ctrl-E>', 'open-editor', mode='insert')
 # config.bind('<Escape>', 'leave-mode', mode='insert')
-# config.bind('<Shift-Ins>', 'insert-text {primary}', mode='insert')
+# config.bind('<Shift-Ins>', 'insert-text -- {primary}', mode='insert')
 
 ## Bindings for passthrough mode
 
 ## Bindings for passthrough mode
-# config.bind('<Ctrl-V>', 'leave-mode', mode='passthrough')
+# config.bind('<Shift-Escape>', 'leave-mode', mode='passthrough')
 
 ## Bindings for prompt mode
 # config.bind('<Alt-B>', 'rl-backward-word', mode='prompt')
 # config.bind('<Alt-Backspace>', 'rl-backward-kill-word', mode='prompt')
 # config.bind('<Alt-D>', 'rl-kill-word', mode='prompt')
 # config.bind('<Alt-F>', 'rl-forward-word', mode='prompt')
 
 ## Bindings for prompt mode
 # config.bind('<Alt-B>', 'rl-backward-word', mode='prompt')
 # config.bind('<Alt-Backspace>', 'rl-backward-kill-word', mode='prompt')
 # config.bind('<Alt-D>', 'rl-kill-word', mode='prompt')
 # config.bind('<Alt-F>', 'rl-forward-word', mode='prompt')
+# config.bind('<Alt-Shift-Y>', 'prompt-yank --sel', mode='prompt')
+# config.bind('<Alt-Y>', 'prompt-yank', mode='prompt')
 # config.bind('<Ctrl-?>', 'rl-delete-char', mode='prompt')
 # config.bind('<Ctrl-A>', 'rl-beginning-of-line', mode='prompt')
 # config.bind('<Ctrl-B>', 'rl-backward-char', mode='prompt')
 # config.bind('<Ctrl-?>', 'rl-delete-char', mode='prompt')
 # config.bind('<Ctrl-A>', 'rl-beginning-of-line', mode='prompt')
 # config.bind('<Ctrl-B>', 'rl-backward-char', mode='prompt')
@@ -1482,6 +2000,7 @@ config.bind('m', 'spawn mpv {url}')
 # config.bind('<Ctrl-F>', 'rl-forward-char', mode='prompt')
 # config.bind('<Ctrl-H>', 'rl-backward-delete-char', mode='prompt')
 # config.bind('<Ctrl-K>', 'rl-kill-line', mode='prompt')
 # config.bind('<Ctrl-F>', 'rl-forward-char', mode='prompt')
 # config.bind('<Ctrl-H>', 'rl-backward-delete-char', mode='prompt')
 # config.bind('<Ctrl-K>', 'rl-kill-line', mode='prompt')
+# config.bind('<Ctrl-P>', 'prompt-open-download --pdfjs', mode='prompt')
 # config.bind('<Ctrl-U>', 'rl-unix-line-discard', mode='prompt')
 # config.bind('<Ctrl-W>', 'rl-unix-word-rubout', mode='prompt')
 # config.bind('<Ctrl-X>', 'prompt-open-download', mode='prompt')
 # config.bind('<Ctrl-U>', 'rl-unix-line-discard', mode='prompt')
 # config.bind('<Ctrl-W>', 'rl-unix-word-rubout', mode='prompt')
 # config.bind('<Ctrl-X>', 'prompt-open-download', mode='prompt')
@@ -1492,8 +2011,16 @@ config.bind('m', 'spawn mpv {url}')
 # config.bind('<Shift-Tab>', 'prompt-item-focus prev', mode='prompt')
 # config.bind('<Tab>', 'prompt-item-focus next', mode='prompt')
 # config.bind('<Up>', 'prompt-item-focus prev', mode='prompt')
 # config.bind('<Shift-Tab>', 'prompt-item-focus prev', mode='prompt')
 # config.bind('<Tab>', 'prompt-item-focus next', mode='prompt')
 # config.bind('<Up>', 'prompt-item-focus prev', mode='prompt')
-# config.bind('n', 'prompt-accept no', mode='prompt')
-# config.bind('y', 'prompt-accept yes', mode='prompt')
 
 ## Bindings for register mode
 # config.bind('<Escape>', 'leave-mode', mode='register')
 
 ## Bindings for register mode
 # config.bind('<Escape>', 'leave-mode', mode='register')
+
+## Bindings for yesno mode
+# config.bind('<Alt-Shift-Y>', 'prompt-yank --sel', mode='yesno')
+# config.bind('<Alt-Y>', 'prompt-yank', mode='yesno')
+# config.bind('<Escape>', 'leave-mode', mode='yesno')
+# config.bind('<Return>', 'prompt-accept', mode='yesno')
+# config.bind('N', 'prompt-accept --save no', mode='yesno')
+# config.bind('Y', 'prompt-accept --save yes', mode='yesno')
+# config.bind('n', 'prompt-accept no', mode='yesno')
+# config.bind('y', 'prompt-accept yes', mode='yesno')