# Configuration Chawan supports configuration of various options like keybindings, user stylesheets, site preferences, etc. The configuration format is very similar to toml, with the following exceptions: * Inline tables may span across multiple lines. * Table arrays can be cleared by setting a variable by the same to the empty array. This allows users to disable default table array rules. Example: ``` omnirule = [] # note: this must be placed at the beginning of the file. [[omnirule]] # this is legal. all default omni-rules are now disabled. ``` Chawan will look for a config file in the ~/.config/chawan/ directory called `config.toml`. See the default configuration file in the res/ folder, and bonus configuration files in the bonus/ folder for further examples. **Table of contents** * [Start](#start) * [External](#external) * [Network](#network) * [Display](#display) * [Omnirule](#omnirule) * [Siteconf](#siteconf) * [Stylesheets](#stylesheets) * [Keybindings](#keybindings) * [Pager actions](#pager-actions) * [Line-editing actions](#line-editing-actions) ## Start Start-up options are to be placed in the `[start]` section. Following is a list of start-up options:
**Name** | **Value** | **Function** |
---|---|---|
visual-home | url | Page opened when Chawan is called with the -V option (and no other pages are passed as arguments.) |
run-script | JavaScript code | Script Chawan runs on start. Pages will not be loaded until this function exits. (setTimeout & friends do not block loading, though.) |
headless | boolean | Whether Chawan should always start in headless mode. Enabled when Chawan is called with -r. |
**Name** | **Value** | **Function** |
---|---|---|
tmpdir | path | Directory used to save temporary files. |
editor | shell command | External editor command. %s is substituted for the file name, %d for the line number. |
**Name** | **Value** | **Function** |
---|---|---|
max-redirect | number | Maximum number of redirections to follow. |
prepend-https | boolean | Whether or not Chawan should attempt loading "raw" URLs without a scheme as https (e.g. wikipedia.org as https://wikipedia.org.) |
**Name** | **Value** | **Function** |
---|---|---|
color-mode | "monochrome"/"ansi"/"8bit"/"24bit"/"auto" | Set the color mode. "auto" for automatic detection, "monochrome" for black on white, "ansi" for ansi colors, "24bit" for true colors. "8bit" is currently unimplemented (and falls back to ansi). |
format-mode | "auto"/["bold", "italic", "underline", "reverse", "strike", "overline", "blink"] | Specifies output formatting modes. Accepts the string "auto" or an array of specific attributes. An empty array (`[]`) disables formatting completely. |
no-format-mode | ["bold", "italic", "underline", "reverse", "strike", "overline", "blink"] | Disable specified formatting modes. |
emulate-overline | boolean | When set to true and the overline formatting attribute is not enabled, overlines are substituted by underlines on the previous line. |
alt-screen | "auto"/boolean | Enable/disable the alternative screen. |
highlight-color | color | Set the highlight color. Both hex values and CSS color names are accepted. |
double-width-ambiguous | boolean | Assume the terminal displays characters in the East Asian Ambiguous category as double-width characters. Useful when e.g. ○ occupies two cells. |
minimum-contrast | number | Specify the minimum difference between the luminance (Y) of the background and the foreground. -1 disables this function (i.e. allows black letters on black background, etc). |
force-clear | boolean | Force the screen to be completely cleared every time it is redrawn. |
**Name** | **Value** | **Function** |
---|---|---|
match | regex | Regular expression used to match the input string. Note that websites passed as arguments are matched as well. |
substitute | JavaScript function | A JavaScript function Chawan will pass the input string to. If a new string is returned, it will be parsed instead of the old one. |
**Name** | **Value** | **Function** |
---|---|---|
url | regex | Regular expression used to match the URL. Either this or the `host` option must be specified. |
host | regex | Regular expression used to match the host part of the URL (i.e. domain name/ip address.) Either this or the `url` option must be specified. |
rewrite-url | JavaScript function | A JavaScript function Chawan will pass the URL to. If a new URL is returned, it will replace the old one. |
cookie | boolean | Whether loading cookies should be allowed for this URL. By default, this is false for all websites. |
third-party-cookie | regex/array of regexes | Domains for which third-party cookies are allowed on this domain. Note: this only works for buffers which share the same cookie jar. |
share-cookie-jar | host | Cookie jar to use for this domain. Useful for e.g. sharing cookies with subdomains. |
referer-from | boolean | Whether or not we should send a Referer header when opening requests originating from this domain. Simplified example: if you click a link on a.com that refers to b.com, and referer-from is true, b.com is sent "a.com" as the Referer header. Defaults to false. |
**Name** | **Function** |
---|---|
`pager.quit()` | Exit the browser. |
`pager.cursorUp()` | Move the cursor to the previous line. |
`pager.cursorDown()` | Move cursor to the next line. |
`pager.cursorLeft()` | Move the cursor to the previous cell. |
`pager.cursorRight()` | Move the cursor to the next cell. |
`pager.cursorLineBegin()` | Move the cursor to the first cell of the line. |
`pager.cursorLineEnd()` | Move the cursor to the last cell of the line. |
`pager.cursorNextWord()` | Move the cursor to the beginning of the next word. |
`pager.cursorPrevWord()` | Move the cursor to the end of the previous word. |
`pager.cursorNextLink()` | Move the cursor to the beginning of the next clickable element. |
`pager.cursorPrevLink()` | Move the cursor to the beginning of the previous clickable element. |
`pager.pageDown()` | Scroll down by one page. |
`pager.pageUp()` | Scroll up by one page. |
`pager.pageLeft()` | Scroll to the left by one page. |
`pager.pageRight()` | Scroll to the right by one page. |
`pager.halfPageDown()` | Scroll forwards by half a page. |
`pager.halfPageUp()` | Scroll backwards by half a page. |
`pager.scrollDown()` | Scroll forwards by one line. |
`pager.scrollUp()` | Scroll backwards by one line. |
`pager.scrollLeft()` | Scroll to the left by one column. |
`pager.scrollRight()` | Scroll to the right by one column. |
`pager.click()` | Click the HTML element currently under the cursor. |
`pager.load(url)` | Go to the specified URL. Opens a prompt with the current URL when no parameters are specified; otherwise, the string passed is displayed in the prompt. If this string ends with a newline (e.g. `pager.load("about:chawan\n")`), the URL is loaded directly. |
`pager.dupeBuffer()` | Duplicate the current buffer by loading its source to a new buffer. |
`pager.discardBuffer()` | Discard the current buffer, and move back to its previous sibling buffer, or if that doesn't exist, to its parent. If the current buffer is a root buffer (i.e. it has no parent), move to the next sibling buffer instead. |
`pager.discardTree()` | Discard all child buffers of the current buffer. |
`pager.reload()` | Open a new buffer with the current buffer's URL, replacing the current buffer. |
`pager.reshape()` | Reshape the current buffer (=render the current page anew.) |
`pager.redraw()` | Redraw screen contents. Useful if something messed up the display. |
`pager.toggleSource()` | If viewing a HTML buffer, open a new buffer with its source. Otherwise, open the current buffer's contents as HTML. |
`pager.cursorFirstLine()` | Move to the beginning in the buffer. |
`pager.cursorLastLine()` | Move to the last line in the buffer. |
`pager.cursorTop()` | Move to the first line on the screen. (Equivalent to H in vi.) |
`pager.cursorMiddle()` | Move to the line in the middle of the screen. (Equivalent to M in vi.) |
`pager.cursorBottom()` | Move to the last line on the screen. (Equivalent to L in vi.) |
`pager.centerLine()` | Center screen around the current line. |
`pager.cursorLeftEdge()` | Move to the first column on the screen. |
`pager.cursorMiddleColumn()` | Move to the column in the middle of the screen. |
`pager.cursorRightEdge()` | Move to the last column on the screen. |
`pager.centerColumn()` | Center screen around the current column. |
`pager.lineInfo()` | Display information about the current line. |
`pager.searchForward()` | Search for a string in the current buffer. |
`pager.searchBackward()` | Search for a string, backwards. |
`pager.isearchForward()` | Incremental-search for a string, highlighting the first result. |
`pager.isearchBackward()` | Incremental-search and highlight the first result, backwards. |
`pager.searchNext()` | Jump to the next search result. |
`pager.searchPrev()` | Jump to the previous search result. |
`pager.peek()` | Display an alert message of the current URL. |
`pager.peekCursor()` | Display an alert message of the URL or title under the cursor. Multiple calls allow cycling through the two. (i.e. by default, press u once -> title, press again -> URL) |
`pager.ask(prompt)` | Ask the user for confirmation. Useful for e.g. an exit prompt: ``` q = 'pager.ask("Do you want to exit Chawan?").then(x => x ? pager.quit() : void(0))' ``` |
**Name** | **Function** |
---|---|
`line.submit()` | Submit line |
`line.cancel()` | Cancel operation |
`line.backspace()` | Delete character before cursor |
`line.delete()` | Delete character after cursor |
`line.clear()` | Clear text before cursor |
`line.kill()` | Clear text after cursor |
`line.clearWord(bounds)` | Delete word before cursor |
`line.killWord(bounds)` | Delete word after cursor |
`line.backward()` | Move cursor back by one character |
`line.forward()` | Move cursor forward by one character |
`line.prevWord(bounds)` | Move cursor to the previous word by one character |
`line.nextWord(bounds)` | Move cursor to the previous word by one character |
`line.begin()` | Move cursor to the previous word by one character |
`line.end()` | Move cursor to the previous word by one character |
`line.escape()` | Ignore keybindings for next character |
`line.prevHist()` | Jump to the previous history entry |
`line.nextHist()` | Jump to the next history entry |