Skip to content

sourcehut-mirrors/chawan

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

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

It uses its own small browser engine developed from scratch, which can nevertheless 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.4. (nim -v displays your Nim compiler's version.)
      The 1.6 branch from 1.6.14 upwards may still work, but it isn't recommended unless you have no other choice.
    • 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. Known stable packages are:

Unstable packages (tip of the master branch):

Each release also comes with static binaries. However, their dependencies can quickly get out of date, so installing a package or compiling Chawan yourself is preferable.

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 README.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.

If you're having troubles accessing SourceHut, you can also use the Codeberg mirror.

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.