~bptato/chawan

TUI Web Browser

3a8ae1b Update docs

~bptato pushed to ~bptato/chawan git

a day ago

chimera lover q66f@disroot.org via chawan-devel

4 days ago

Chawan is a TUI web (and (S)FTP, Gopher, Gemini, ...) browser with CSS, inline image and JavaScript support.

It uses its own minimal browser engine developed from scratch, which can display many websites in a manner similar to major graphical browsers.

It can also be used as a terminal pager.

Screenshot of Chawan displaying its SourceHut page

#Compiling

A Unix-like operating system (Linux, *BSD, Haiku, macOS, ...) is assumed. On Windows you have to use WSL.

  1. Clone the Chawan repository:
    git clone https://git.sr.ht/~bptato/chawan && cd chawan
  2. Install the Nim compiler: https://nim-lang.org/install.html
    • Please use 2.0.0 or newer, ideally 2.2.2. (nim -v displays your Nim compiler's version.)
    • If you are using a 32-bit system, you probably need 2.2 or newer. 2.0 may still work if you export CFLAGS=-fpermissive.
  3. Install the following dependencies:
    • OpenSSL (or LibreSSL)
    • libssh2
    • brotli
    • pkg-config
    • GNU make (gmake on non-GNU systems)
    • Quick copy-paste for Debian: apt install libssh2-1-dev libssl-dev libbrotli-dev pkg-config make
  4. Run make (without arguments).
  5. Install using make install (e.g. sudo make install).

Then, try:

$ cha -V # open in visual mode for a list of default keybindings
$ cha example.org # open your favorite website directly from the shell
$ mancha cha # read the cha(1) man page using `mancha'

#Packages

You can also install Chawan from packages maintained by volunteers:

#Features

Currently implemented features are:

  • multi-processing, incremental loading of documents
  • HTML5 support with various encodings (UTF-8, Shift_JIS, GBK, ...), forms, cookies
  • CSS-based layout engine: supports flow layout, table layout, flexbox layout, double-width characters (CJK)
  • user-programmable keybindings (defaults are vi(m)-like), mouse support
  • JavaScript support in documents (disabled by default)
  • inline image support with Sixel or Kitty protocol (disabled by default; see doc/image.md on how to enable)
  • supports several network protocols: HTTP(S), (S)FTP, Gopher, Gemini, Finger, Spartan
  • markdown viewer (cha file.md), man page viewer (mancha)
  • user-defined protocols and file formats
  • syscall filter based sandboxing on FreeBSD, OpenBSD and Linux (through capsicum, pledge and seccomp-bpf)
  • bookmarks, history

...with a lot more planned.

#Bugs, technical issues, etc.

First, read the troubleshooting document. If it doesn't help, open a ticket.

When using the ticket tracker, please make sure your tickets are valid markdown, or they become unreadable on the web interface.

If you want to send plain text e-mails not formatted as markdown, use the mailing list instead. This is also where you can send patches.

#Documentation index

Chawan's documentation is available as man pages (man cha) and as Markdown files.

If you're interested in modifying the code:

#Relatives

w3m has been the main inspiration for Chawan; although the two do not share code, the UI and feature set is similar.

Ferus is a separate graphical browser engine written in Nim, which uses Chawan's HTML parser.

#License

Chawan is dedicated to the public domain. See the UNLICENSE file for details.

Chawan also includes and depends on several permissively licensed libraries. For further details, check the about:license page in Chawan, or read the same document here.