vkdot/badwolf
2025-03-02 03:05:35 -05:00
..
bookmarks_test.fixtures/full/badwolf First. 2025-03-02 03:05:35 -05:00
icons/hicolor First. 2025-03-02 03:05:35 -05:00
LICENSES First. 2025-03-02 03:05:35 -05:00
locale First. 2025-03-02 03:05:35 -05:00
mo First. 2025-03-02 03:05:35 -05:00
po First. 2025-03-02 03:05:35 -05:00
.ninja_deps First. 2025-03-02 03:05:35 -05:00
.ninja_log First. 2025-03-02 03:05:35 -05:00
AUTHORS First. 2025-03-02 03:05:35 -05:00
badwolf.1 First. 2025-03-02 03:05:35 -05:00
badwolf.c First. 2025-03-02 03:05:35 -05:00
badwolf.de.1 First. 2025-03-02 03:05:35 -05:00
badwolf.desktop First. 2025-03-02 03:05:35 -05:00
badwolf.fr.1 First. 2025-03-02 03:05:35 -05:00
badwolf.h First. 2025-03-02 03:05:35 -05:00
badwolf.inkscape.svg First. 2025-03-02 03:05:35 -05:00
badwolf.o First. 2025-03-02 03:05:35 -05:00
badwolf.svg First. 2025-03-02 03:05:35 -05:00
badwolf.tr.1 First. 2025-03-02 03:05:35 -05:00
badwolf.vi.1 First. 2025-03-02 03:05:35 -05:00
bookmarks.c First. 2025-03-02 03:05:35 -05:00
bookmarks.h First. 2025-03-02 03:05:35 -05:00
bookmarks.o First. 2025-03-02 03:05:35 -05:00
bookmarks_test.c First. 2025-03-02 03:05:35 -05:00
build.ninja First. 2025-03-02 03:05:35 -05:00
config.h First. 2025-03-02 03:05:35 -05:00
config.ninja First. 2025-03-02 03:05:35 -05:00
configure First. 2025-03-02 03:05:35 -05:00
configure.h First. 2025-03-02 03:05:35 -05:00
COPYING First. 2025-03-02 03:05:35 -05:00
decisions.md First. 2025-03-02 03:05:35 -05:00
downloads.c First. 2025-03-02 03:05:35 -05:00
downloads.h First. 2025-03-02 03:05:35 -05:00
downloads.o First. 2025-03-02 03:05:35 -05:00
fmt.c First. 2025-03-02 03:05:35 -05:00
fmt.h First. 2025-03-02 03:05:35 -05:00
fmt.o First. 2025-03-02 03:05:35 -05:00
fmt_test.c First. 2025-03-02 03:05:35 -05:00
icons_size.sh First. 2025-03-02 03:05:35 -05:00
install First. 2025-03-02 03:05:35 -05:00
install.sh First. 2025-03-02 03:05:35 -05:00
interface.css First. 2025-03-02 03:05:35 -05:00
interface.md First. 2025-03-02 03:05:35 -05:00
keybindings.c First. 2025-03-02 03:05:35 -05:00
keybindings.h First. 2025-03-02 03:05:35 -05:00
keybindings.o First. 2025-03-02 03:05:35 -05:00
KnowledgeBase.md First. 2025-03-02 03:05:35 -05:00
README.md First. 2025-03-02 03:05:35 -05:00
uri.c First. 2025-03-02 03:05:35 -05:00
uri.h First. 2025-03-02 03:05:35 -05:00
uri.o First. 2025-03-02 03:05:35 -05:00
uri_test.c First. 2025-03-02 03:05:35 -05:00
userscripts.c First. 2025-03-02 03:05:35 -05:00
userscripts.h First. 2025-03-02 03:05:35 -05:00
userscripts.o First. 2025-03-02 03:05:35 -05:00
usr.bin.badwolf First. 2025-03-02 03:05:35 -05:00
version.sh First. 2025-03-02 03:05:35 -05:00

BadWolf

SPDX-FileCopyrightText: 2019-2022 Badwolf Authors <https://hacktivis.me/projects/badwolf>
SPDX-License-Identifier: BSD-3-Clause

Minimalist and privacy-oriented WebKitGTK+ browser.

Homepage: https://hacktivis.me/projects/badwolf

The name is a reference to BBC's Doctor Who TV series, I took it simply because I wanted to have a specie in the name, like some other web browsers do, but doesn't go into the “gentle” zone.

Differences

Comparing from other small WebKit browsers for unixes found in the wild:

  • Independent of environment, should just work if GTK and WebKitGTK does
  • Storing data should be:
    • explicit and optional (i.e. Applying preferences doesn't imply Saving to disk)
    • not queryabe by WebKit (so the web can't use it)
    • done in a standard format (like XBEL for bookmarks)
  • Static UI, no element should be added at runtime, this is to avoid potential tracking via viewport changes
  • Small codebase, should be possible to read and understand it completely over an afternoon.
  • Does not use modal editing (from vi) as that was designed for editing, not browsing
  • UTF-8 encoding by default

Motivation from other clients https://hacktivis.me/articles/www-client%20are%20broken

Contributing

Translations

You need to have gettext installed. If you want a GUI, poedit exists and Weblate is a good web platform that I might consider hosting at some point.

  • Syncing POT file with the source code: ninja po/messages.pot
  • Syncing PO file with the POT file: ninja po/de.po
  • Initialising a new PO file (example for German, de_DE): msginit -l de_DE -i po/messages.pot -o po/de.po

Contacts / Discussions

Repositories

git

release assets

Manual Installation

Dependencies

  • POSIX-compatible Shell (i.e. mrsh, dash, lksh)
  • ninja or samurai
  • A pkg-config implementation (pkgconf is recommended)
  • C11 Compiler (such as clang or gcc)
  • WebKitGTK, only the latest stable(2.32.0+) is supported
  • libxml-2.0, no known version limitation
  • (optional, translating) po4a to modify manpage translations
  • (optional, translating) gettext implementation (such as GNU Gettext)
  • (optional, translating) ed(1), the standard editor
  • (optional, lint) mandoc (the command) for linting the manpage
  • (optional, lint) shellcheck for linting the ./configure script
  • (optional, lint) flawfinder for examining C source code for flaws
  • (optional, lint) reuse for checking REUSE compliance

Note: Packagers can safely ignore the lint dependencies.

Compiling

./configure && ninja

Note: configure is a simple shell script (so not autotools) which supports variables like PREFIX.

Installing

ninja install
# DESTDIR is supported

Debian users will probably want to use checkinstall instead.

An example AppArmor profile is provided at usr.bin.badwolf, please do some long runtime checks before shipping it or a modified version, help can be provided but with no support.

If you modify the icons, you'll need inkscape (command line only), to regenerate the bitmap versions. It isn't needed for a normal installation as the bitmap icons are bundled.

Notes

Most of the privacy/security stuff will be done with patches against WebKit as quite a lot isn't into WebKitSettings and with generic WebKit extensions that should be reusable.