2017-09-15 22:16:25 +02:00
|
|
|
Configuring qutebrowser
|
|
|
|
=======================
|
|
|
|
|
|
|
|
IMPORTANT: qutebrowser's configuration system was completely rewritten in
|
|
|
|
September 2017. This information is not applicable to older releases, and older
|
|
|
|
information elsewhere might be outdated. **If you had an old configuration
|
|
|
|
around and upgraded, this page will automatically open once**. To view it at a
|
|
|
|
later time, use the `:help` command.
|
|
|
|
|
|
|
|
Migrating older configurations
|
|
|
|
------------------------------
|
|
|
|
|
|
|
|
qutebrowser does no automatic migration for the new configuration. However,
|
2017-09-17 11:17:59 +02:00
|
|
|
there's a special link:qute://configdiff[] page in qutebrowser, which will show
|
|
|
|
you the changes you did in your old configuration, compared to the old defaults.
|
2017-09-15 22:16:25 +02:00
|
|
|
|
2017-09-16 22:18:44 +02:00
|
|
|
Other changes in default settings:
|
|
|
|
|
|
|
|
- `<Up>` and `<Down>` in the completion now navigate through command history
|
|
|
|
instead of selecting completion items. You can get back the old behavior by
|
|
|
|
doing:
|
|
|
|
+
|
|
|
|
----
|
|
|
|
:bind -f -m command <Up> completion-item-focus prev
|
|
|
|
:bind -f -m command <Down> completion-item-focus next
|
|
|
|
----
|
|
|
|
|
|
|
|
- The default for `completion.web_history_max_items` is now set to `-1`, showing
|
|
|
|
an unlimited number of items in the completion for `:open` as the new
|
|
|
|
sqlite-based completion is much faster. If the `:open` completion is too slow
|
|
|
|
on your machine, set an appropriate limit again.
|
|
|
|
|
2017-09-15 22:16:25 +02:00
|
|
|
Configuring qutebrowser via the user interface
|
|
|
|
----------------------------------------------
|
|
|
|
|
|
|
|
The easy (but less flexible) way to configure qutebrowser is using its user
|
|
|
|
interface or command line. Changes you make this way are immediately active
|
|
|
|
(with the exception of a few settings, where this is pointed out in the
|
2017-09-16 15:22:53 +02:00
|
|
|
documentation) and are persisted in an `autoconfig.yml` file.
|
2017-09-15 22:16:25 +02:00
|
|
|
|
2017-09-17 11:17:59 +02:00
|
|
|
The `autoconfig.yml` file is located in the "config" folder listed on the
|
|
|
|
link:qute://version[] page. On macOS, the "auto config" folder is used, which is
|
|
|
|
different from where hand-written config files are kept.
|
2017-09-15 22:16:25 +02:00
|
|
|
|
2017-09-17 11:17:59 +02:00
|
|
|
However, **do not** edit `autoconfig.yml` by hand. Instead, see the next
|
|
|
|
section.
|
2017-09-15 22:16:25 +02:00
|
|
|
|
|
|
|
If you want to customize many settings, you can open the link:qute://settings[]
|
|
|
|
page by running `:set` without any arguments, where all settings are listed and
|
|
|
|
customizable.
|
|
|
|
|
2017-09-17 11:17:59 +02:00
|
|
|
Using the link:commands.html#set[`:set`] command and command completion, you
|
|
|
|
can quickly set settings interactively, for example `:set tabs.position left`.
|
|
|
|
|
|
|
|
To get more help about a setting, use e.g. `:help tabs.position`.
|
|
|
|
|
2017-09-15 22:16:25 +02:00
|
|
|
To bind and unbind keys, you can use the link:commands.html#bind[`:bind`] and
|
|
|
|
link:commands.html#unbind[`:unbind`] commands:
|
|
|
|
|
2017-09-17 12:35:29 +02:00
|
|
|
- Binding the key chain "`,`, `v`" to the `:spawn mpv {url}` command:
|
|
|
|
`:bind ,v spawn mpv {url}`
|
2017-09-17 11:17:59 +02:00
|
|
|
- Unbinding the same key chain: `:unbind ,v`
|
|
|
|
- Changing an existing binding: `bind --force ,v message-info foo`. Without
|
|
|
|
`--force`, qutebrowser will show an error because `,v` is already bound.
|
2017-09-15 22:16:25 +02:00
|
|
|
|
2017-09-16 15:22:53 +02:00
|
|
|
Key chains starting with a comma are ideal for custom bindings, as the comma key
|
|
|
|
will never be used in a default keybinding.
|
|
|
|
|
2017-09-19 13:56:29 +02:00
|
|
|
See the help pages linked above (or `:help :bind`, `:help :unbind`) for more
|
|
|
|
information.
|
|
|
|
|
2017-09-15 22:16:25 +02:00
|
|
|
Configuring qutebrowser via config.py
|
|
|
|
-------------------------------------
|
|
|
|
|
2017-09-16 15:22:53 +02:00
|
|
|
For more powerful configuration possibilities, you can create a `config.py`
|
|
|
|
file. Since it's a Python file, you have much more flexibility for
|
|
|
|
configuration. Note that qutebrowser will never touch this file - this means
|
|
|
|
you'll be responsible for updating it when upgrading to a newer qutebrowser
|
|
|
|
version.
|
2017-09-15 22:16:25 +02:00
|
|
|
|
|
|
|
The file should be located in the "config" location listed on
|
|
|
|
link:qute://version[], which is typically `~/.config/qutebrowser/config.py` on
|
|
|
|
Linux, `~/.qutebrowser/config.py` on macOS, and
|
|
|
|
`%APPDATA%/qutebrowser/config.py` on Windows.
|
|
|
|
|
2017-09-17 11:17:59 +02:00
|
|
|
Two global objects are pre-defined when running `config.py`: `c` and `config`.
|
2017-09-15 22:16:25 +02:00
|
|
|
|
2017-09-16 15:22:53 +02:00
|
|
|
Changing settings
|
|
|
|
~~~~~~~~~~~~~~~~~
|
2017-09-15 22:16:25 +02:00
|
|
|
|
|
|
|
`c` is a shorthand object to easily set settings like this:
|
|
|
|
|
2017-09-17 11:17:59 +02:00
|
|
|
.config.py:
|
2017-09-15 22:16:25 +02:00
|
|
|
[source,python]
|
|
|
|
----
|
|
|
|
c.tabs.position = "left"
|
|
|
|
c.completion.shrink = True
|
|
|
|
----
|
|
|
|
|
2017-09-17 12:35:29 +02:00
|
|
|
Note that qutebrowser does some Python magic so it's able to warn you about
|
|
|
|
mistyped config settings. As an example, if you do `c.tabs.possition = "left"`,
|
|
|
|
you'll get an error when starting.
|
|
|
|
|
2017-09-15 22:16:25 +02:00
|
|
|
See the link:settings.html[settings help page] for all available settings. The
|
|
|
|
accepted values depend on the type of the option. Commonly used are:
|
|
|
|
|
|
|
|
- Strings: `c.tabs.position = "left"`
|
|
|
|
- Booleans: `c.completion.shrink = True`
|
|
|
|
- Integers: `c.messages.timeout = 5000`
|
|
|
|
- Dictionaries:
|
2017-09-18 06:25:39 +02:00
|
|
|
* `c.headers.custom = {'X-Hello': 'World', 'X-Awesome': 'yes'}` to override
|
|
|
|
any other values in the dictionary.
|
2017-09-15 22:16:25 +02:00
|
|
|
* `c.aliases['foo'] = ':message-info foo'` to add a single value.
|
|
|
|
- Lists:
|
|
|
|
* `c.url.start_pages = ["https://www.qutebrowser.org/"]` to override any
|
|
|
|
previous elements.
|
|
|
|
* `c.url.start_pages.append("https://www.python.org/")` to add a new value.
|
|
|
|
|
2017-09-17 11:17:59 +02:00
|
|
|
Any other config types (e.g. a color) are specified as a string. The only
|
|
|
|
exception is the `Regex` type, which can take either a string (with an `r`
|
|
|
|
prefix to preserve backslashes) or a Python regex object:
|
2017-09-15 22:16:25 +02:00
|
|
|
|
|
|
|
- `c.hints.next_regexes.append(r'\bvor\b')`
|
|
|
|
- `c.hints.prev_regexes.append(re.compile(r'\bzurück\b'))`
|
|
|
|
|
|
|
|
If you want to read a setting, you can use the `c` object to do so as well:
|
|
|
|
`c.colors.tabs.even.bg = c.colors.tabs.odd.bg`.
|
|
|
|
|
|
|
|
|
|
|
|
Using strings for setting names
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
If you want to set settings based on their name as a string, use the
|
|
|
|
`config.set` method:
|
|
|
|
|
2017-09-17 11:17:59 +02:00
|
|
|
.config.py:
|
2017-09-15 22:16:25 +02:00
|
|
|
[source,python]
|
|
|
|
----
|
|
|
|
config.set('content.javascript.enabled', False)
|
|
|
|
----
|
|
|
|
|
|
|
|
To read a setting, use the `config.get` method:
|
|
|
|
|
|
|
|
[source,python]
|
|
|
|
----
|
|
|
|
color = config.get('colors.completion.fg')
|
|
|
|
----
|
|
|
|
|
|
|
|
Binding keys
|
|
|
|
~~~~~~~~~~~~
|
|
|
|
|
|
|
|
While it's possible to change the `bindings.commands` setting to bind keys, it's
|
|
|
|
preferred to use the `config.bind` command. Doing so ensures the commands are
|
|
|
|
valid and normalizes different expressions which map to the same key.
|
|
|
|
|
|
|
|
For details on how to specify keys and the available modes, see the
|
|
|
|
link:settings.html#bindings.commands[documentation] for the `bindings.commands`
|
|
|
|
setting.
|
|
|
|
|
|
|
|
To bind a key:
|
|
|
|
|
2017-09-17 11:17:59 +02:00
|
|
|
.config.py:
|
2017-09-15 22:16:25 +02:00
|
|
|
[source,python]
|
|
|
|
----
|
2017-09-19 13:56:29 +02:00
|
|
|
config.bind('<Ctrl-v>', 'spawn mpv {url}')
|
2017-09-15 22:16:25 +02:00
|
|
|
----
|
|
|
|
|
2017-09-19 13:56:29 +02:00
|
|
|
To bind a key in a mode other than `'normal'`, add a `mode` argument:
|
|
|
|
|
|
|
|
[source,python]
|
|
|
|
----
|
|
|
|
config.bind('<Ctrl-y>', 'prompt-yes', mode='prompt')
|
|
|
|
----
|
2017-09-19 13:14:41 +02:00
|
|
|
|
2017-09-15 22:16:25 +02:00
|
|
|
If the key is already bound, `force=True` needs to be given to rebind it:
|
|
|
|
|
|
|
|
[source,python]
|
|
|
|
----
|
2017-09-19 13:56:29 +02:00
|
|
|
config.bind('<Ctrl-v>', 'message-info foo', force=True)
|
2017-09-15 22:16:25 +02:00
|
|
|
----
|
|
|
|
|
|
|
|
To unbind a key (either a key which has been bound before, or a default binding):
|
|
|
|
|
|
|
|
[source,python]
|
|
|
|
----
|
2017-09-19 13:56:29 +02:00
|
|
|
config.unbind('<Ctrl-v>', mode='normal')
|
2017-09-15 22:16:25 +02:00
|
|
|
----
|
|
|
|
|
2017-09-19 13:56:29 +02:00
|
|
|
To bind keys without modifiers, specify a key chain to bind as a string. Key
|
|
|
|
chains starting with a comma are ideal for custom bindings, as the comma key
|
2017-09-16 15:22:53 +02:00
|
|
|
will never be used in a default keybinding.
|
|
|
|
|
2017-09-19 13:56:29 +02:00
|
|
|
[source,python]
|
|
|
|
----
|
|
|
|
config.bind(',v', 'spawn mpv {url}')
|
|
|
|
----
|
|
|
|
|
2017-09-17 09:50:10 +02:00
|
|
|
To suppress loading of any default keybindings, you can set
|
|
|
|
`c.bindings.default = {}`.
|
2017-09-15 22:16:25 +02:00
|
|
|
|
|
|
|
Prevent loading `autoconfig.yml`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
If you want all customization done via `:set`, `:bind` and `:unbind` to be
|
|
|
|
temporary, you can suppress loading `autoconfig.yml` in your `config.py` by
|
|
|
|
doing:
|
|
|
|
|
2017-09-17 11:17:59 +02:00
|
|
|
.config.py:
|
2017-09-15 22:16:25 +02:00
|
|
|
[source,python]
|
|
|
|
----
|
|
|
|
config.load_autoconfig = False
|
|
|
|
----
|
|
|
|
|
|
|
|
Handling errors
|
|
|
|
~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
If there are errors in your `config.py`, qutebrowser will try to apply as much
|
|
|
|
of it as possible, and show an error dialog before starting.
|
|
|
|
|
|
|
|
qutebrowser tries to display errors which are easy to understand even for people
|
|
|
|
who are not used to writing Python. If you see a config error which you find
|
|
|
|
confusing or you think qutebrowser could handle better, please
|
|
|
|
https://github.com/qutebrowser/qutebrowser/issues[open an issue]!
|