2014-07-23 21:32:41 +02:00
|
|
|
// If you are reading this in plaintext or on PyPi:
|
|
|
|
//
|
|
|
|
// A rendered version is available at:
|
|
|
|
// https://github.com/The-Compiler/qutebrowser/blob/master/README.asciidoc
|
|
|
|
|
2014-06-26 20:11:10 +02:00
|
|
|
qutebrowser
|
|
|
|
===========
|
2014-06-17 18:01:15 +02:00
|
|
|
|
2014-06-26 20:11:10 +02:00
|
|
|
_A keyboard-driven, vim-like browser based on PyQt5 and QtWebKit._
|
2014-06-17 18:01:15 +02:00
|
|
|
|
2014-06-26 20:11:10 +02:00
|
|
|
qutebrowser is a keyboard-focused browser with with a minimal GUI. It's based
|
|
|
|
on Python, PyQt5 and QtWebKit and free software, licensed under the GPL.
|
2014-04-28 23:20:18 +02:00
|
|
|
|
|
|
|
It was inspired by other browsers/addons like dwb and Vimperator/Pentadactyl.
|
2014-06-16 11:36:14 +02:00
|
|
|
|
2014-10-05 18:47:41 +02:00
|
|
|
Screenshots
|
|
|
|
-----------
|
|
|
|
|
2014-10-05 18:52:00 +02:00
|
|
|
image:doc/img/main.png[width=300,link="doc/img/main.png"]
|
|
|
|
image:doc/img/downloads.png[width=300,link="doc/img/downloads.png"]
|
|
|
|
image:doc/img/completion.png[width=300,link="doc/img/completion.png"]
|
|
|
|
image:doc/img/hints.png[width=300,link="doc/img/hints.png"]
|
2014-10-05 18:47:41 +02:00
|
|
|
|
2014-07-23 20:17:08 +02:00
|
|
|
Documentation
|
|
|
|
-------------
|
|
|
|
|
2014-10-03 08:32:37 +02:00
|
|
|
In addition to the topics mentioned in this README, the following documents are
|
2014-07-23 20:17:08 +02:00
|
|
|
available:
|
|
|
|
|
2014-10-03 08:32:37 +02:00
|
|
|
* link:doc/quickstart.asciidoc[Quick start guide]
|
2014-07-17 07:41:46 +02:00
|
|
|
* link:doc/FAQ.asciidoc[Frequently asked questions]
|
2014-07-23 20:17:08 +02:00
|
|
|
* link:doc/HACKING.asciidoc[HACKING]
|
2014-10-05 17:55:17 +02:00
|
|
|
* link:doc/readme.asciidoc[Reporting segfaults]
|
2014-07-17 07:41:46 +02:00
|
|
|
|
2014-06-26 17:27:41 +02:00
|
|
|
Getting help
|
|
|
|
------------
|
|
|
|
|
2014-07-23 20:17:08 +02:00
|
|
|
You can get help in the IRC channel
|
|
|
|
irc://irc.freenode.org/#qutebrowser[`#qutebrowser`] on
|
|
|
|
http://freenode.net/[Freenode]
|
|
|
|
(https://webchat.freenode.net/?channels=#qutebrowser[webchat]), or by writing a
|
2014-06-26 17:27:41 +02:00
|
|
|
message to the
|
|
|
|
https://lists.schokokeks.org/mailman/listinfo.cgi/qutebrowser[mailinglist] at
|
|
|
|
mailto:qutebrowser@lists.qutebrowser.org[].
|
|
|
|
|
2014-06-26 20:11:10 +02:00
|
|
|
Running qutebrowser
|
|
|
|
-------------------
|
|
|
|
|
2014-07-23 20:17:08 +02:00
|
|
|
After installing the <<requirements,requirements>>, you have these options:
|
2014-06-26 20:11:10 +02:00
|
|
|
|
2014-07-31 21:14:37 +02:00
|
|
|
* Run qutebrowser directly via `./qutebrowser.py` in the toplevel directory.
|
2014-06-26 20:11:10 +02:00
|
|
|
* Run `python3 setup.py install` to install qutebrowser, then call
|
|
|
|
`qutebrowser`.
|
|
|
|
|
2014-09-22 18:32:33 +02:00
|
|
|
NOTE: If you're running qutebrowser from the git repository rather than a
|
|
|
|
released version, you should run `scripts/asciidoc2html.py` to generate the
|
|
|
|
documentation.
|
|
|
|
|
2014-06-26 20:11:10 +02:00
|
|
|
Contributions / Bugs
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
You want to contribute to qutebrowser? Awesome! Please read
|
|
|
|
link:doc/HACKING.asciidoc[HACKING] for details and useful hints.
|
|
|
|
|
|
|
|
If you found a bug or have a feature request, you can report it in several
|
|
|
|
ways:
|
2014-06-26 17:27:41 +02:00
|
|
|
|
2014-06-26 20:11:10 +02:00
|
|
|
* Use the built-in `:report` command or the automatic crash dialog.
|
|
|
|
* Open an issue in the Github issue tracker.
|
|
|
|
* Write a mail to the
|
|
|
|
https://lists.schokokeks.org/mailman/listinfo.cgi/qutebrowser[mailinglist] at
|
|
|
|
mailto:qutebrowser@lists.qutebrowser.org[].
|
|
|
|
|
2014-10-03 07:58:36 +02:00
|
|
|
For security bugs, please contact me directly at mail@qutebrowser.org, GPG ID
|
|
|
|
http://www.the-compiler.org/pubkey.asc[0xFD55A072].
|
|
|
|
|
2014-06-26 20:11:10 +02:00
|
|
|
[[requirements]]
|
2014-06-16 11:36:14 +02:00
|
|
|
Requirements
|
|
|
|
------------
|
|
|
|
|
|
|
|
The following software and libraries are required to run qutebrowser:
|
|
|
|
|
2014-07-28 20:41:42 +02:00
|
|
|
* http://www.python.org/[Python] 3.4
|
2014-09-14 21:23:40 +02:00
|
|
|
* http://qt-project.org/[Qt] 5.2.0 or newer (5.3.2 recommended)
|
2014-06-16 11:36:14 +02:00
|
|
|
* QtWebKit
|
2014-09-14 21:23:40 +02:00
|
|
|
* http://www.riverbankcomputing.com/software/pyqt/intro[PyQt] 5.2.0 or newer
|
2014-09-18 06:40:42 +02:00
|
|
|
(5.3.2 recommended) for Python 3
|
2014-06-17 18:01:15 +02:00
|
|
|
* https://pypi.python.org/pypi/setuptools/[pkg_resources/setuptools]
|
2014-08-14 13:37:27 +02:00
|
|
|
* http://fdik.org/pyPEG/[pyPEG2]
|
2014-08-28 17:45:55 +02:00
|
|
|
* http://jinja.pocoo.org/[jinja2]
|
2014-09-15 17:59:33 +02:00
|
|
|
* http://pygments.org/[pygments]
|
2014-06-16 11:36:14 +02:00
|
|
|
|
2014-09-30 16:24:41 +02:00
|
|
|
To generate the documentation for the `:help` command, when using the git
|
|
|
|
repository (rather than a release), http://asciidoc.org/[asciidoc] is needed.
|
|
|
|
|
2014-07-23 20:17:08 +02:00
|
|
|
The following libraries are optional and provide colored logging in the
|
|
|
|
console:
|
2014-06-16 11:36:14 +02:00
|
|
|
|
2014-06-17 18:01:15 +02:00
|
|
|
* https://pypi.python.org/pypi/colorlog/[colorlog]
|
|
|
|
* On Windows: https://pypi.python.org/pypi/colorama/[colorama]
|
2014-06-16 11:36:14 +02:00
|
|
|
|
2014-06-26 20:11:10 +02:00
|
|
|
On Debian
|
|
|
|
~~~~~~~~~
|
2014-06-16 11:36:14 +02:00
|
|
|
|
2014-06-26 20:11:10 +02:00
|
|
|
----
|
2014-08-28 17:45:55 +02:00
|
|
|
# apt-get install python3-pyqt5 python3-pyqt5.qtwebkit python3-pkg-resources
|
2014-09-15 17:59:33 +02:00
|
|
|
python3-pip python3-jinja2 python3-pygments
|
2014-08-14 13:37:27 +02:00
|
|
|
# pip3 install pypeg2 --allow-external pypeg2 --allow-unverified pypeg2
|
2014-06-26 20:11:10 +02:00
|
|
|
----
|
2014-06-16 11:36:14 +02:00
|
|
|
|
2014-09-30 16:24:41 +02:00
|
|
|
To generate the documentation for the `:help` command, when using the git
|
|
|
|
repository (rather than a release):
|
|
|
|
|
|
|
|
----
|
|
|
|
# apt-get install asciidoc
|
|
|
|
----
|
|
|
|
|
2014-06-26 20:11:10 +02:00
|
|
|
On Archlinux
|
|
|
|
~~~~~~~~~~~~
|
2014-06-16 11:36:14 +02:00
|
|
|
|
2014-07-17 07:41:46 +02:00
|
|
|
There's an Archlinux package available in `pkg/`. You can install it (and the
|
2014-08-14 13:37:27 +02:00
|
|
|
python-pypeg2 dependency) like this:
|
2014-07-17 07:41:46 +02:00
|
|
|
|
|
|
|
----
|
2014-08-14 13:37:27 +02:00
|
|
|
$ wget https://aur.archlinux.org/packages/py/python-pypeg2/python-pypeg2.tar.gz <1>
|
|
|
|
$ tar xzvf python-pypeg2.tar.gz
|
|
|
|
$ cd python-pypeg2
|
2014-07-17 07:41:46 +02:00
|
|
|
$ makepkg -si
|
|
|
|
$ cd ..
|
|
|
|
|
|
|
|
$ mkdir qutebrowser
|
|
|
|
$ cd qutebrowser
|
|
|
|
$ wget http://git.the-compiler.org/qutebrowser/plain/pkg/PKGBUILD.qutebrowser-git -O PKGBUILD
|
|
|
|
$ makepkg -si
|
|
|
|
$ cd ..
|
2014-08-14 13:37:27 +02:00
|
|
|
$ rm -rf python-pypeg2.tar.gz python-pypeg2 qutebrowser
|
2014-07-17 07:41:46 +02:00
|
|
|
----
|
|
|
|
<1> Instead of the first block of commands you could also use an AUR helper,
|
2014-08-14 13:37:27 +02:00
|
|
|
e.g. +yaourt -S python-pypeg2+.
|
2014-07-17 07:41:46 +02:00
|
|
|
|
|
|
|
As soon as v0.1 is out, there will be a package in the AUR, so this will get
|
|
|
|
easier.
|
|
|
|
|
|
|
|
// Install https://aur.archlinux.org/packages/qutebrowser-git/[qutebrowser-git]
|
|
|
|
// from the AUR.
|
2014-06-16 11:36:14 +02:00
|
|
|
|
2014-09-19 00:42:06 +02:00
|
|
|
On Gentoo
|
|
|
|
~~~~~~~~~
|
|
|
|
|
|
|
|
Running qutebrowser on Gentoo is unfortunately rather hard because Qt5 and
|
|
|
|
PyQt5 are not packaged officially. https://github.com/posativ[@posativ] has
|
|
|
|
written https://gist.github.com/posativ/30668ee3472c6d0649e8[a howto] with
|
|
|
|
steps to get it running.
|
|
|
|
|
2014-06-26 20:11:10 +02:00
|
|
|
On Windows
|
|
|
|
~~~~~~~~~~
|
2014-06-16 11:36:14 +02:00
|
|
|
|
2014-07-23 21:23:46 +02:00
|
|
|
* Use the installer from http://www.python.org/downloads[python.org] to get Python 3
|
|
|
|
* Use the installer from
|
2014-06-16 11:36:14 +02:00
|
|
|
http://www.riverbankcomputing.com/software/pyqt/download5[Riverbank computing]
|
2014-07-23 21:23:46 +02:00
|
|
|
to get Qt and PyQt5.
|
|
|
|
* Run `scripts/ez_setup.py` to get setuptools.
|
|
|
|
* Get pip as described http://stackoverflow.com/a/12476379[on Stack Overflow].
|
2014-08-14 13:37:27 +02:00
|
|
|
* Run +pip install --allow-external pypeg2 --allow-unverified pypeg2 pypeg2+ to
|
|
|
|
install pypeg2.
|
2014-09-16 05:23:32 +02:00
|
|
|
* Run +pip install jinja2+ to install jinja2, or install it from
|
|
|
|
http://www.lfd.uci.edu/~gohlke/pythonlibs/#jinja2.
|
|
|
|
* Run +pip install pygments+ to install pygments, or install it from
|
|
|
|
http://www.lfd.uci.edu/~gohlke/pythonlibs/#pygments.
|
2014-06-16 11:36:14 +02:00
|
|
|
|
2014-07-17 07:41:46 +02:00
|
|
|
As soon as v0.1 is out, a standalone .exe (built with
|
|
|
|
http://cx-freeze.sourceforge.net/[cx_Freeze]) will be provided. In the
|
|
|
|
meantime, you can simply ask in IRC if you need one.
|
2014-06-26 20:11:10 +02:00
|
|
|
|
2014-10-06 18:29:59 +02:00
|
|
|
On OS X
|
|
|
|
~~~~~~~
|
|
|
|
|
|
|
|
Running qutebrowser on OS X requires compiling PyQt5 by hand. These steps have
|
|
|
|
been tested on OS X Mavericks:
|
|
|
|
|
|
|
|
* Install XCode from the Appstore
|
|
|
|
* Open a Terminal
|
|
|
|
* Run `xcode-select --install`
|
|
|
|
* Install the XCode commandline tools
|
|
|
|
* Run `sudo /usr/bin/xcodebuild` and accept the license.
|
|
|
|
* http://www.qt.io/download-open-source/[Download] and run the Qt5 installer.
|
|
|
|
If you want, you can deselect Android/iOS when selecting the components to be
|
|
|
|
installed.
|
|
|
|
* Run +sed -i -e 's/macosx10\.8/macosx10\.9/' ~/Qt/5.3/clang_64/mkspecs/qdevice.pri+
|
|
|
|
* http://www.python.org/downloads/[Download] and install the Python 3
|
|
|
|
installer. After opening the `.dmg`, right-click on 'Python.mpkg' and click
|
|
|
|
'Open' to run it -- double-clicking won't work.
|
|
|
|
* Download SIP and PyQt5 from Riverbank Coputing
|
|
|
|
* Open a Terminal and use `cd ~/Downloads` to get to the download directory.
|
|
|
|
* Use `tar xzvf sip-*.tar` to extract SIP and `cd sip-*` to change into the
|
|
|
|
SIP directory
|
|
|
|
* Run `python3 configure.py`, `make` and `sudo make install`.
|
|
|
|
* Use `cd ~/Downloads` to get back to the download directory.
|
|
|
|
* Use `tar xvf PyQt-*.tar` to extract PyQt and `cd PyQt-*` to change into the
|
|
|
|
PyQt directory.
|
|
|
|
* Run +sed -i -e "s/qmake_QT=\['webkit', 'network'\]/qmake_QT=['webkit',
|
|
|
|
'network', 'printsupport']/" configure.py+
|
|
|
|
* Run +sed -i -e "s/qmake_QT=\['webkitwidgets'\]/qmake_QT=['webkitwidgets',
|
|
|
|
'printsupport']/" configure.py+
|
|
|
|
* Run +python3 configure.py --qmake ~/Qt/5.3/clang_64/bin/qmake --sip
|
|
|
|
/Library/Frameworks/Python.framework/Versions/3.4/bin/sip+ and accept
|
|
|
|
the license.
|
|
|
|
* Run `make` and `sudo make install`.
|
|
|
|
* Run `python3 setup.py install` to install all other dependencies
|
|
|
|
|
|
|
|
|
2014-10-03 08:32:37 +02:00
|
|
|
Donating
|
|
|
|
--------
|
|
|
|
|
|
|
|
Working on qutebrowser is a very rewarding hobby, but like (nearly) all hobbies
|
|
|
|
it also costs some money. Namely I have to pay for the server and domain, and
|
|
|
|
do occasional hardware upgrades footnote:[It turned out a 160 GB SSD is rather
|
|
|
|
small - the VMs and custom Qt builds I use for testing/developing qutebrowser
|
|
|
|
need about 100 GB of space].
|
|
|
|
|
|
|
|
If you want to give me a beer or a pizza back, I'm trying to make it as easy as
|
|
|
|
possible for you to do so. If some other way would be easier for you, please
|
|
|
|
get in touch!
|
|
|
|
|
|
|
|
* PayPal: me@the-compiler.org
|
|
|
|
* Bitcoin: link:bitcoin:1PMzbcetAHfpxoXww8Bj5XqquHtVvMjJtE[1PMzbcetAHfpxoXww8Bj5XqquHtVvMjJtE]
|
|
|
|
|
2014-06-26 20:11:10 +02:00
|
|
|
Authors
|
|
|
|
-------
|
|
|
|
|
2014-07-16 22:26:00 +02:00
|
|
|
Contributors, sorted by the number of commits in descending order:
|
|
|
|
|
|
|
|
// QUTE_AUTHORS_START
|
|
|
|
* Florian Bruhin
|
2014-08-27 13:21:45 +02:00
|
|
|
* Claude
|
2014-10-26 17:07:25 +01:00
|
|
|
* Peter Vilim
|
2014-07-16 22:26:00 +02:00
|
|
|
// QUTE_AUTHORS_END
|
2014-06-26 20:11:10 +02:00
|
|
|
|
|
|
|
Thanks / Similiar projects
|
|
|
|
--------------------------
|
|
|
|
|
|
|
|
Many projects with a similiar goal as qutebrowser exist:
|
|
|
|
|
2014-10-01 11:34:25 +02:00
|
|
|
* http://portix.bitbucket.org/dwb/[dwb] (C, GTK+ with WebKit1, currently
|
|
|
|
http://www.reddit.com/r/linux/comments/2huqbc/dwb_abandoned/[unmaintained] -
|
|
|
|
main inspiration for qutebrowser)
|
|
|
|
* https://github.com/fanglingsu/vimb[vimb] (C, GTK+ with WebKit1, active)
|
|
|
|
* http://sourceforge.net/p/vimprobable/wiki/Home/[vimprobable] (C, GTK+ with
|
|
|
|
WebKit1, active)
|
|
|
|
* http://surf.suckless.org/[surf] (C, GTK+ with WebKit1, active)
|
|
|
|
* https://mason-larobina.github.io/luakit/[luakit] (C/Lua, GTK+ with
|
|
|
|
WebKit1, not very active)
|
|
|
|
* http://pwmt.org/projects/jumanji/[jumanji] (C, GTK+ with WebKit1, not very
|
|
|
|
active)
|
|
|
|
* http://www.uzbl.org/[uzbl] (C, GTK+ with WebKit1/WebKit2, active)
|
|
|
|
* http://conkeror.org/[conkeror] (Javascript, Emacs-like, XULRunner/Gecko,
|
|
|
|
active)
|
|
|
|
* https://github.com/AeroNotix/lispkit[lispkit] (quite new, lisp, GTK+ with
|
|
|
|
WebKit, active)
|
2014-06-26 20:11:10 +02:00
|
|
|
* http://www.vimperator.org/[Vimperator] (Firefox addon)
|
|
|
|
* http://5digits.org/pentadactyl/[Pentadactyl] (Firefox addon)
|
|
|
|
* https://github.com/akhodakivskiy/VimFx[VimFx] (Firefox addon)
|
|
|
|
* http://vimium.github.io/[vimium] (Chrome/Chromium addon)
|
|
|
|
|
|
|
|
Most of them were inspirations for qutebrowser in some way, thanks for that!
|
|
|
|
|
|
|
|
Thanks as well to the following projects and people for helping me with
|
|
|
|
problems and helpful hints:
|
|
|
|
|
|
|
|
* http://eric-ide.python-projects.org/[eric5] / Detlev Offenbach
|
|
|
|
* https://code.google.com/p/devicenzo/[devicenzo]
|
|
|
|
* portix
|
|
|
|
* seir
|
|
|
|
* nitroxleecher
|
|
|
|
|
|
|
|
Also, thanks to:
|
|
|
|
|
|
|
|
* Everyone who had the patience to test qutebrowser before v0.1.
|
|
|
|
* Everyone triaging/fixing my bugs in the
|
|
|
|
https://bugreports.qt-project.org/secure/Dashboard.jspa[Qt bugtracker]
|
|
|
|
* Everyone answering my questions on http://stackoverflow.com/[Stack Overflow]
|
|
|
|
and in IRC.
|
|
|
|
* All the projects which were a great help while developing qutebrowser.
|
|
|
|
|
|
|
|
License
|
|
|
|
-------
|
|
|
|
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|