aboutsummaryrefslogtreecommitdiff
path: root/doc
diff options
context:
space:
mode:
authorRodrigo Arias Mallo <rodarima@gmail.com>2024-02-12 22:29:35 +0100
committerRodrigo Arias Mallo <rodarima@gmail.com>2024-04-01 23:18:26 +0200
commitae2ddb0518ed0028405193d866b9cb98e1351d0c (patch)
tree31c2f70044384a3dc13ca8a1c75058ffc07eeba2 /doc
parent49ccf991568f5c6220c6b70ead2dc5f0f187dc74 (diff)
Improve Dillo user manual
A lot of sections were updated and extended to cover the usage of the browser from the perspective of a new user. Other missing content was added, specially to describe the configuration files and the format they use. Fixes: https://github.com/dillo-browser/dillo/issues/73
Diffstat (limited to 'doc')
-rw-r--r--doc/user_help.html1085
1 files changed, 755 insertions, 330 deletions
diff --git a/doc/user_help.html b/doc/user_help.html
index dd32b107..40250623 100644
--- a/doc/user_help.html
+++ b/doc/user_help.html
@@ -1,366 +1,791 @@
-<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
+<!DOCTYPE html>
<html>
-
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
- <title> Dillo Web Browser ::
+ <title>Dillo User Manual</title>
+ <style type="text/css">
+body {
+ background: white;
+ color: black;
+ line-height: 1.5;
+ margin: 3em;
+ font-family: sans-serif;
+ font-size: 16px;
+}
+.main {
+ margin: 0 auto; /* won't work on Dillo, yet */
+ max-width: 40em;
+ min-width: 20em;
+}
+ul.toc {
+ font-size: 14px;
+ padding: 1em;
+}
+ul.toc li {
+ padding: 0px;
+}
+h1 {
+ margin-top: 0.25em;
+ margin-bottom: 0.25em
+}
+h2 {
+ padding: 0.5em;
+ margin-top: 1em;
+ text-align: center;
+}
+h3 {
+ border-top: 1px solid #eee;
+ padding-top: 1em;
+}
+pre {
+ border-left: 4px solid #ccc;
+ padding: 0.5em;
+ background-color: #f8f8f8;
+ font-size: 14px;
+}
+ul {
+ margin-left: 0px;
+ padding-left: 1.5em;
+}
+li {
+ padding: 0.2em;
+}
+table {
+ width: 100%;
+ border-collapse: collapse;
+}
+th,td {
+ padding: 0.25em;
+ border-spacing: 0px;
+ border-top: solid 1px #ccc;
+ border-bottom: solid 1px #ccc;
+}
+th {
+ background-color: #eee;
+}
+footer {
+ color: #777;
+ margin: 2em;
+ font-size: 14px;
+ text-align: center;
+}
+ </style>
+</head>
- Help for New Users
+<body>
+<div class="main">
+<h1>Dillo User Manual</h1>
-</title>
-</head>
+<p>Welcome to the user manual of the Dillo browser. The manual is divided into
+<em>sections</em> but is written in a <em>single page</em> to allow search by
+keywords.</p>
-<body text="#0f0f0f" link="#2020e0" vlink="#403090" bgcolor="#607cf8">
+<details><!-- Not supported in Dillo, but decays ok -->
+<summary class="toc">Table of contents:</summary>
+<ul class="toc">
+ <li><a href="#introduction">Introduction</a></li>
+ <li><a href="#reading">Reading</a>
+ <ul>
+ <li><a href="#basics">Basics</a></li>
+ <li><a href="#scrolling">Scrolling</a></li>
+ <li><a href="#find-text">Find text</a></li>
+ <li><a href="#copy-and-paste">Copy and paste</a></li>
+ </ul>
+ </li>
+ <li><a href="#navigation">Navigation</a>
+ <ul>
+ <li><a href="#hyperlinks">Hyperlinks</a></li>
+ <li><a href="#history">History</a></li>
+ <li><a href="#location-bar">Location bar</a></li>
+ <li><a href="#web-search">Web search</a></li>
+ <li><a href="#tabs">Tabs</a></li>
+ <li><a href="#bookmarks">Bookmarks</a></li>
+ </ul>
+ </li>
+ <li><a href="#privacy-and-network">Privacy and Network</a>
+ <ul>
+ <li><a href="#https">HTTPS</a></li>
+ <li><a href="#cookies">Cookies</a></li>
+ <li><a href="#proxy">Proxy</a></li>
+ <li><a href="#ad-blocking">Ad-blocking</a></li>
+ <li><a href="#downloads">Downloads</a></li>
+ <li><a href="#images-off-mode">Images-off mode</a></li>
+ </ul>
+ <li><a href="#configuration">Configuration</a>
+ <ul>
+ <li><a href="#dillorc">Dillorc</a></li>
+ <li><a href="#cookiesrc">Cookiesrc</a></li>
+ <li><a href="#domainrc">Domainrc</a></li>
+ <li><a href="#style-css">Style.css</a></li>
+ <li><a href="#dpidrc">Dpidrc</a></li>
+ <li><a href="#bm-txt">bm.txt</a></li>
+ <li><a href="#keysrc">Keysrc</a></li>
+ </ul>
+ </li>
+ <li><a href="#advanced-usage">Advanced usage</a>
+ <ul>
+ <li><a href="#plugins">Plugins</a></li>
+ <li><a href="#bug-meter">Bug meter</a></li>
+ <li><a href="#keyboard-shortcuts">Keyboard shortcuts</a></li>
+ </ul>
+ </li>
+</ul>
+</details>
+
+<h2 id="introduction">Introduction</h2>
+<p>Dillo is a web browser designed to be fast, use few resources and support
+slow and unreliable Internet connections on resource-constrained machines. It
+can load local and remote files via HTTP, HTTPS and FTP. Other protocols like
+Gemini, Gopher, IPFS and others are available as
+<a href="#plugins">plugins</a>.</p>
+
+<p>Dillo supports a subset of HTML 4.01 and CSS 2.1 but it <b>doesn't support
+JavaScript</b> and only implements some elements of HTML 5 and CSS 3. It also
+renders plain text documents and images in PNG, JPG and GIF formats.</p>
+
+<h2 id="reading">Reading</h2>
+<p>In this section we cover the basics to read a web page, scrolling and finding
+or copying text.</p>
+<h3 id="basics">Basics</h3>
+<p>
+The graphical interface is designed to be used with a mouse or pointing
+device. In the top of the browser window you have the location bar and the main
+buttons to control the browser. You can leave the mouse for a brief moment over
+any part of the menu to show a tooltip with more information.
+<p>
+Dillo has <em>context sensitive menus</em>, which are opened with the right mouse
+button, available on pages, links, images, forms, the Back and Forward buttons,
+and the bug meter. They show different actions to be performed specific to the
+element. For example, to save a page you can right-click on the page and select
+"Save page as...". Or to copy a link URL you can right-click on a link and
+select "Copy link location".
+<p>
+Dillo can hide the pannels and use the whole window area to display the page. To
+switch between modes use the ESC key. You can also choose the control panel size
+by going to the Tools button and selecting a different one under "Panel size".
+<p>
+If you need to access this manual again press the top right "?" button to open
+it. It doesn't require a network connection.
- <table width="100%" bgcolor="#8080f0" cellspacing="4" cellpadding="5"
- border="0o">
- <tr><td><big><font color="#302080">Welcome to Dillo 3</font></big>
- </table>
- <p>
+<h3 id="scrolling">Scrolling</h3>
- <table WIDTH="100%" BORDER=1 CELLSPACING=0 CELLPADDING=3>
- <tr ALIGN=LEFT VALIGN=TOP><td bgcolor="wheat">
- <h4><font color="green">Basics:</font></h4>
- </td></tr>
+<p>There are several methods to move or scroll the view of the current page.</p>
- <tr><td WIDTH="100%" bgcolor="#70a0c0">
+<ul>
+ <li>Using the <em>keyboard</em>:
+ <ul>
+ <li>Use the <code>Home</code> or <code>End</code> keys to jump to the top
+ or to the end of a page.</li>
+ <li>Use <code>PgUp</code> or <code>PgDn</code> to advance a whole
+ <em>page</em> (window size).</li>
+ <li>Use the arrow keys to move the view a <em>step</em> in that
+ direction.</li>
+ <li>You can also use the <code>Space</code> key as <code>PgDn</code> and
+ <code>b</code> as PgUp.</li>
+ </ul>
+ </li>
+ <li>Using the <em>mouse</em> or <em>pointing device</em>:
<ul>
- <li>You can tell a link from plain content by the hand-shaped cursor.
+ <li>Rotate the mouse wheel to move one <em>step</em> in that direction.
+ <li>Keep the middle button (or mouse wheel button) pressed while
+ dragging to scroll the page precisely.
+ </ul>
+ </li>
+ <li>Using the <em>scrollbar</em>:
+ <ul>
+ <li>Drag the thumb in the scrollbar on the side up or down to scroll the
+ page.
+ <li>Left-click or right-click on the scrollbar above or below the thumb to
+ move one <em>page</em> in that direction.
+ <li>Middle-click on the scrollbar above or below the thumb to jump to that
+ specific position of the page.
+ <li>Click the scrollbar arrows to move the view one <em>step</em> in
+ that direction.
+ </ul>
+ </li>
+</ul>
- <li> Besides browsing the web, Dillo also has basic file browsing
- capabilities included. So, entering <code>file:</code> in your
- Dillo URL window will give you the contents of your current
- working directory, and <code>file:~</code> entered in the
- same place will point your Dillo browser right to your home
- directory...
+<p>You can control the <b>size of a <em>step</em></b> by setting the
+<code>scroll_step</code> option in the <a href="#dillorc">dillorc</a>
+configuration file. By default it will scroll 100 pixels per step.</p>
- <li> Dillo, at this stage of development, is not ready
- to render pages that use <b><font color="#5040a0">frames</font></b>.
- Nevertheless, it comes with a tiny handler (lynx/w3m-like) that will
- let you choose which frame to visit, one by one.
+<h3 id="find-text">Find text</h3>
+<p>
+To find text in a document right-click to open the <em>Page menu</em> and select
+<em>Find text</em>. It is also available by the default shortcut
+<code>Ctrl+F</code>. Then type the substring that you want to find and click
+Next (or the <code>Enter</code> key).
+</p>
+Dillo will scroll the page and highlight found text starting from the top. To
+find a word (not a substring) use spaces around it to limit the search to
+matching words only.
+<p>
+To close the find bar you can click on the red X on the bottom right or press
+ESC.
- <li> Dillo has <b><font color="#5040a0">context
- sensitive menus</font></b> using the right mouse button
- (available on pages, links, images, forms, the Back
- and Forward buttons, and the bug meter).
+<h3 id="copy-and-paste">Copy and paste</h3>
+<p>
+To copy some text just hold down the left mouse button and move to select the
+area to copy. To paste, go to the target application and press the middle mouse
+button.
+<p>
+If you want to select more than one screen, hold the mouse button down and
+scroll with PgUp, PgDn or the arrow keys.
+<P>
+If you want to paste an URL into Dillo, do it on the "clear-URL"
+button (the "X" next to the <a href="#location-bar">location bar</a>).
+<p>
- <li> Some of the functions in Dillo are handled by independent
- processes. For instance, downloads come through
- <em><a href="http://www.gnu.org/software/wget/">wget</a></em>.
- If Dillo exits, the downloads continue (more details
- below).
+<h2 id="navigation">Navigation</h2>
+This section focuses on how to navigate to other pages by following hyperlinks,
+using bookmarks, typing or pasting a new URL or using the history.
+<h3 id="hyperlinks">Hyperlinks</h3>
- </ul>
- </td></tr>
- </table>
+<p>Hyperlinks to other pages change the cursor to a hand to indicate that
+an element can be clicked with the left button:
+<p style="text-align: center">
+<img
+ style="border: solid 1px #ddd;"
+ src="">
+<p>
+Links to other pages usually appear in
+<span style="color:blue; text-decoration: underline">blue and underlined</span>
+by default and once they are visited they change to
+<span style="color:purple; text-decoration: underline">purple</span>.
+However, this is not always the case, so using the mouse cursor shape is the
+best indicator of a
+<em><a style="color:black; text-decoration: none" href="#">link</a></em>.
+<p>
+When you follow a link by clicking on it, the previous pages will be remembered
+in case you want to go back to them. Use the Back and Forw buttons on the top
+bar to navigate among history pages.
+<p>
- <table WIDTH="100%" BORDER=1 CELLSPACING=0 CELLPADDING=3>
- <tr ALIGN=LEFT VALIGN=TOP><td bgcolor="wheat">
- <h4><font color="green">Usage:</font></h4>
- </td></tr>
+<h3 id="history">History</h3>
+<p>
+When you follow several links across different web pages, they are remembered in
+case you can to go back. Use the "Back" and "Forward" buttons of the panel to go
+to the previous or next page.
+<p>
+You can also right-click on the Back or Forward buttons to open a menu with the
+list of previous or next pages available, so you can jump directly to them. Use
+the left button to open them in the current tab or the middle button to open
+them in a new tab.
+<p>
+The <code>,</code> (comma) and <code>.</code> (dot) keys can be used to jump
+backwards or forward (mnemonic: those keys are usually labeled "&lt;" and
+"&gt;").
- <tr><td BGCOLOR="#70a0c0">
- <ul>
- <li> You can scroll around your Dillo main window using
- {PgUp|PgDn|Home|End} or using the mouse middle button
- or mouse wheel. If nothing happens when keys are pressed, try
- <b> <font color="#5040a0">focusing</font></b> your Dillo main
- window first by clicking it (not on any link!:)).
+<h3 id="location-bar">Location bar</h3>
+<p>
+The location bar on the top displays the URL of the current page loaded and can
+be used to access other pages by typing the new URL or by pasting it and
+pressing Enter.
+<p>
+The red <b style="color: darkred">x</b>
+on the left clears the location bar content when left clicked. Then you can type
+or paste a new address from the clipboard by middle clicking on the location
+bar.
+As these two actions are usually performed together, you can simply middle-click
+on the
+<b style="color: darkred">x</b>
+button to go to the URL in the clipboard.
+<p>
+You can also select the location bar content from the keyboard by pressing
+<code>Ctrl+L</code>.
- <li>You can use the space key as PgDn, and {'b' | 'B'} as PgUp.</li>
+<h3 id="web-search">Web search</h3>
+<p>
+Several search engines are available by pressing the magnifying glass icon next
+to the location bar or by pressing <code>Ctrl+s</code>. The search engines are
+configured in <a href="#dillorc">Dillorc</a> with the option
+<code>search_url</code>. Use it multiple times to define multiple search
+engines.
+<p>
+The location bar can also be used to search the web by using an special prefix
+for each search engine. For example, the following line:<br>
+<pre>
+search_url="dd DuckDuckGo http://duckduckgo.com/lite/?kp=-1&amp;kd=-1&amp;q=%s"
+</pre>
+<p>
+Defines the "DuckDuckGo" search engine with the prefix "<code>dd</code>", so you
+can type in the location bar "<code>dd dillo browser</code>" to search with
+DuckDuckGo for the keywords "dillo browser".
- <li> Similarly, you can use "<b>,</b>" and "<b>.</b>" as shortcuts for
- forward and backward buttons (mnemonic: those
- keys are usually labeled "<" and ">").
+<h3 id="tabs">Tabs</h3>
+<p>
+Dillo can open different web pages into tabs. To open a link in a new tab click
+the middle button instead of the left button. The same applies to buttons to
+submit a form.
+<p>
+By default the new tab will be automatically focused. If you want to change
+this behaviour, adjust the following options in the
+<a href="#dillorc">dillorc</a> configuration file:
+<pre>
+middle_click_opens_new_tab
+focus_new_tab
+</pre>
+<p>
+Press <code>Shift</code> to temporarily reverse the focusing behaviour while
+middle-clicking on a link.
+<p>
+To close a tab press the X button on the top right (only visible with multiple
+tabs). You can also close the tab by clicking with the right button on the tab
+label. The middle button can be used instead setting the option:
+<pre>
+right_click_closes_tab=NO
+</pre>
+
+<h3 id="bookmarks">Bookmarks</h3>
+<p>
+Dillo can save URLs of web pages as bookmarks so you can open them later. To
+bookmark the current page, open the page menu by left-clicking on the page
+and select "Bookmark this page" (it also works over a link).
+<p>
+To see or edit the bookmarks, click on the Bookmarks button on the pannel or
+press <code>Ctrl+B</code>.
+<p>
+Bookmarks are handled by a builtin Dillo plugin named <code>bm</code> (read more
+about plugins in the <a href="#plugins">Plugins section</a>) and are
+synchronized across all instances of the browser. The list of bookmarks can also
+be shown by opening the URL <a href="dpi:/bm/"><code>dpi:/bm/</code></a>.
+<p>
+The bookmarks are stored in a simple plain text file named <code>bm.txt</code>
+(see the details of this file in the <a href="#bm-txt">bm.txt section</a>). You
+can edit the file directly to change the bookmarks.
+
+<h2 id="privacy-and-network">Privacy and network</h2>
- <li> <b>Configuration:</b> If you want to change Dillo's
- appearance or behaviour, look at the options in your
- <b><font color="#5040a0">dillorc</font></b>
- file (if you don't have a copy in your ~/.dillo/ directory, get it
- <a href='https://raw.githubusercontent.com/dillo-browser/dillo/master/dillorc'>here</a>).
+<p>The default privacy policy in Dillo attempts to keep the user safe from
+tracking, <em>even if this policy breaks a lot of website functionality</em>. In
+this section you can add exceptions or relax the configuration at your own risk.
- <li> Clicking the "Reload" button always requests an end-to-end reload
- of the page currently viewed, but it will *not* reload embedded
- images during this process.
+<h3 id="https">HTTPS</h3>
- <li> Dialogs can be closed with the ESC key.
- (ESC also hides the findbar and control panels)
+<p>Dillo has support for HTTPS, allowing it to connect securely to remote
+websites. Use the protocol "<code>https:</code>" to specify the use of HTTPS.
+When a problem is encountered with the remote certificate, a warning dialog
+explains the details and allows you to choose what to do: continue loading the
+website or cancel.
+<p>
+By default Dillo looks for a TLS library at build time, which can be OpenSSL or
+mbedTLS. You can see which library is being used by looking at the messages of
+Dillo when it starts:
+<pre>
+$ dillo
+dillo_dns_init: Here we go! (threaded)
+TLS library: <b>OpenSSL 3.2.1 30 Jan 2024</b>
+...
+</pre>
+
+<h3 id="cookies">Cookies</h3>
+<p>
+Due to privacy concerns, <b>cookies are disabled by default</b> unless
+explicitly enabled in the configuration.
+<p>
+Support for cookies is implemented using a plugin that shares them
+between several instances of Dillo and follows the
+<a href="http://tools.ietf.org/html/rfc6265">RFC 6265</a>
+specification. Current cookie limits are 20 per domain and
+1200 in total.
+
+<p>Cookies are configured by the <code>cookiesrc</code> configuration file. See
+the <a href="#cookiesrc">Cookiesrc section</a> to see how to enable cookies for
+some domains or accept them by default.</p>
+
+<h3 id="proxy">Proxy</h3>
+<p>Dillo can use a HTTP proxy by setting the environment variable
+<code>http_proxy</code> or the
+<a href="#dillorc">configuration option</a> with the same name. All HTTP and
+HTTPS traffic will be sent through the proxy.
+
+<p><b>Note</b>: Plugins may not implement proxy support.
+</p>
+
+<h3 id="ad-blocking">Ad blocking</h3>
+<p>Dillo has the ability to block content when loading a page based on the domain
+the embeded content is being loaded from. You can control how Dillo handles
+automatic requests for resources (like images and style sheets) that aren't at
+the same domain as the original page.</p>
+
+<p>See the <a href="#domainrc">domainrc</a> configuration file to find out how to
+specify which domains are blocked or allowed.</p>
+
+<h3 id="downloads">Downloads</h3>
+<p>Downloads are made using
+<a href="http://www.gnu.org/software/wget/">wget</a>
+with a <a href="http://www.fltk.org">FLTK</a>-based GUI wrapper, through
+the <a href="#plugins">Dillo plugin (dpi) framework</a>.
+If you close the browser window, downloads will continue.</p>
+
+<h3 id="images-off-mode">Images-off mode</h3>
+<p>
+You can browse without images now:
+<ul>
+<li>There is an option in the Tools menu to disable automatic image loading.
+An image's alt text (or <code>[IMG]</code> placeholder) will appear in the
+page.
+<li>If you want to load an individual image, left click on its text.
+<li>You can set "no images" as the default mode in dillorc.
+</ul>
+
+<h2 id="configuration">Configuration</h2>
+
+<p>Dillo has <b>several configuration files</b> that control the behavior of the
+browser. Each configuration file is searched <em>first</em> in the
+<a href="file:~/.dillo"><code>~/.dillo</code></a> directory and,
+<em>if not found</em>, in the default system configuration directory (typically
+<code>/etc/dillo</code>).</p>
+
+<p>Most configuration files can include comments by <em>starting</em> a line
+with the "<code>#</code>" symbol. Their specific syntax is described in the
+following sections.</p>
+
+<h3 id="dillorc">Dillorc</h3>
+
+<p>The main configuration of Dillo is controled by the
+<a href="file:~/.dillo/dillorc"><code>dillorc</code></a> file.
+The list of all available options can be found in the system
+configuration file, typically
+<a href="file:/etc/dillo/dillorc"><code>/etc/dillo/dillorc</code></a>. You may
+want to copy it into
+<a href="file:~/.dillo/dillorc"><code>~/.dillo/dillorc</code></a>
+and edit it to suit your needs.</p>
+
+The file is commented to describe what each option does. The default value for
+each option as well as other interesting values are also available as comments:
+<ul>
+ <li>"<code>#option=...</code>" shows the built-in default.</li>
+ <li>"<code># option=...</code>" is an additional example.</li>
+ <li>"<code>option=...</code>" overrides the built-in value.</li>
+</ul>
+
+<p>Some options can be specified multiple times, for example
+<code>search_url</code>:
+<pre>
+search_url="dd DuckDuckGo (https) https://duckduckgo.com/lite/?kp=-1&amp;q=%s"
+search_url="Wikipedia http://www.wikipedia.org/w/index.php?search=%s&amp;go=Go"
+</pre>
+
+<h3 id="cookiesrc">Cookiesrc</h3>
+
+<p>Cookies are configured in the
+<a href="file:~/.dillo/cookiesrc"><code>~/.dillo/cookiesrc</code></a>
+file by using rules, with one rule per line. The rule syntax is very simple,
+first specify the <em>host</em> and then the <em>action</em>, separated by
+whitespaces. Comment lines start with <code>#</code> as the first character and
+the whole line is ignored.
+<p>
+The host can be in the form <code>example.com</code> to match only that
+domain or <code>.example.com</code> to match all subdomains of example.com. The
+special word <code>DEFAULT</code> specifies the default policy, when no other
+match occurs.
+<p>
+The action can be: <code>DENY</code> to ignore cookies,
+<code>ACCEPT_SESSION</code> to only accept session cookies but don't save them
+to disk and <code>ACCEPT</code> to accept and store cookies in disk (this will
+allow sites to track you over time).
+<p>
+When the cookies plugin exits, only the accepted cookies by <code>ACCEPT</code>
+are saved to
+<a href="file:~/.dillo/cookies.txt"><code>~/.dillo/cookies.txt</code></a>,
+and ACCEPT_SESSION cookies are
+forgotten. The cookies plugin normally exits after a period of inactivity, but
+you can force it to exit with the command <code>dpidc stop</code>.
+<p>
+Here is an example <code>cookiesrc</code> file:
+<pre>
+# host action
+DEFAULT DENY
+fltk.org ACCEPT
+.example.com ACCEPT_SESSION
+</pre>
+<p> Which is parsed as follows:</p>
+<ul>
+ <li>Line 1: Comment line begins with <code>#</code>.</li>
+ <li>Line 2: Deny all cookies from all domains not otherwise specified (this is
+ the default).
+ <li>Line 3: Accept all cookies from fltk.org, and save them to disk when the
+ cookie plugin exits.</li>
+ <li>Line 4: Accept all cookies from all subdomains of example.com, but do not
+ save them when the cookie plugin exits.</li>
+</ul>
+<p>
+Dillo is especially concerned about privacy and security issues. Our advice is
+to <em>avoid cookies whenever possible</em> and at most set ACCEPT_SESSION to
+<em>specific trusted sites</em>.
- <li> If you want to try a different control panel, right-click over the
- tools button and select one that suits your needs, then make
- it the default in your <code>dillorc</code> file.
+<h3 id="domainrc">Domainrc</h3>
- <li> The whole window area can be used to display the page (ESC key).
+<p>With the
+<code>~/.dillo/domainrc</code>
+file, you can control how Dillo handles automatic requests for resources
+(like images and style sheets) that aren't at the same domain as the
+original page.
+<p>
+The file contains one rule per line. Comments are specified by starting the line
+with the <code>#</code> symbol. The default rule is either
+<code>default accept</code> or <code>default deny</code> and will cause Dillo
+to, respectively, accept all requests by default or deny all requests by
+default.
+<p>
+Depending on the default rule, the next rules behave as exceptions by denying
+specific connections or allowing specific connections, respectively.
+<p>
+Exceptions to the default rule are written in the format
+<code>source destination</code>, and match request from the source domain to the
+destination domain. The source and destination domains can be specified in three
+ways:
+<ul>
+ <li>"<code>*</code>" to match any domain</li>
+ <li>"<code>example.com</code>" to match the specific host example.com</li>
+ <li>"<code>.example.com</code>" to match example.com and any of its
+ subdomains</li>
+</ul>
+<p>
+Here is an example:
+<pre>
+# Accept all requests by default
+default accept
+# But block some ad-sites and trackers from any domain
+* .doubleclick.net
+* .googleadservices.com
+* .quantserve.com
+</pre>
+
+<h3 id="style-css">Style.css</h3>
+
+<p>Custom
+<a href="https://en.wikipedia.org/wiki/CSS">CSS styles</a> can be placed in the
+<a href="file:~/.dillo/style.css"><code>~/.dillo/style.css</code></a>
+file to set default web page styles. To override page styles add the
+"<code>!important</code>" flag.
+
+<h3 id="dpidrc">Dpidrc</h3>
+
+<p>The configuration for <a href="#plugins">plugins</a> is placed in the
+<a href="file:~/.dillo/dpidrc"><code>~/.dillo/dpidrc</code></a> file.</p>
+
+<p>Plugins are searched in the <code>~/.dillo/dpi/</code> directory first, and
+then in the system directory if not found. The <code>dpi_dir</code> option
+sets the system <code>dpi</code> directory and must be specified once. Here is
+an example:</p>
+
+<pre>
+dpi_dir=/usr/lib/dillo/dpi
+</pre>
+
+<p>By default, plugins will receive requests at the URL
+<code>dpi:/<em>name</em>/</code>, for example bookmarks are available at
+<a href="dpi:/bm/"><code>dpi:/bm/</code></a>.
+
+<p>Plugins can also be associated with a protocol (like "<code>file:</code>").
+When a request is made using the given protocol the associated plugin is used to
+process the request. The rest of the file assigns a plugin to a protocol, one
+per line. The syntax is
+<code>proto.<em>name</em>=<em>path-to-plugin.dpi</em></code>. The path of the
+plugin is relative to the <code>dpi</code> directory. Here are some
+examples of the builtin plugins:</p>
+
+<pre>
+proto.file=file/file.dpi
+proto.ftp=ftp/ftp.filter.dpi
+proto.data=datauri/datauri.filter.dpi
+</pre>
+
+<p>Here (
+<img alt="red dot"
+src="" />
+) is an example image using the <code>data:</code> protocol used to define a PNG
+image inline in a HTML document.
+</p>
+
+<h3 id="bm-txt">bm.txt</h3>
+
+<p>Web page URLs can be saved as bookmarks so they can be accessed in the future.
+Bookmarks are stored in a plain text file located at
+<a href="file:~/.dillo/bm.txt"><code>~/.dillo/bm.txt</code></a>. The file can be
+modified by using the
+<a href="dpi:/bm/">Book button</a>
+in the toolbar and the context menu on a page or link, but they can also be
+edited manually. Bookmarks are organized into sections and are given a
+description (usually the page title).</p>
+
+<p>The syntax of the <code>bm.txt</code> file is described as follows:</p>
+
+<p>First, the sections are defined at the beginning, prefixed with a
+<code>:s<em>N</em>:</code> identifier, along with the description of the
+section:</p>
+<pre>
+:s0: News
+:s1: Blog
+</pre>
+<p>Then every bookmark is added in a single line, by writing the section
+identifier, the URL and a description:</p>
+<pre>
+s0 https://slashdot.org Slashdot
+s0 https://news.ycombinator.com/ Hacker News
+s1 https://100r.co/site/log.html 100 Rabbits Log
+</pre>
+<p>The <code>bm.txt</code> file is designed to be <em>easily</em> read by humans
+and is suitable to be kept updated among machines by using a version control
+tool.
+
+<h3 id="keysrc">Keysrc</h3>
+
+<p>The mapping of keys in Dillo is contolled by the
+<a href="file:~/.dillo/keysrc"><code>~/.dillo/keysrc</code></a> file.
+The format is "<code>key = action</code>" or
+"<code>&lt;modifier&gt;key = action</code>". Lines that begin with a "#" are comments.
+The commented-out bindings below show the defaults built into Dillo.
+
+<ul>
+<li>Modifiers recognized: Shift, Ctrl, Alt, Meta (on Mac OS X use "Meta" for
+Command).
+
+<li>Key names recognized: Backspace, Delete, Down, End, Esc, F1 through
+F12, Home, Insert, Left, Menu, PageDown, PageUp, Print, Return, Right, Space,
+Tab, Up.
+
+<li>Multimedia keys: Back, Favorites, Forward, HomePage, Mail, MediaNext,
+MediaPlay, MediaPrev, MediaStop, Refresh, Search, Sleep, Stop, VolumeDown,
+VolumeMute, VolumeUp.
+</ul>
+
+<p>If Dillo is running under X11, keys whose names are not recognized can be
+specified using their keysym value in hexadecimal. Use <code>xev</code> to get
+the keysym, for example:
+<pre>
+0x1008ff27 = forward
+</pre>
+
+<p>The action "nop" (no operation) can be used to remove a binding.
+
+<p>Example file:</p>
+<pre>
+# "close-all" closes all tabs/windows and exits.
+&lt;ctrl&gt;q = close-all
+
+# "left-tab" and "right-tab" switch to the left/right of the current tab.
+&lt;ctrl&gt;&lt;shift&gt;tab = left-tab
+
+# Use HJKL to move around
+k = line-up
+j = line-down
+h = left
+l = right
+</pre>
+
+<h2 id="advanced-usage">Advanced usage</h2>
+
+These sections are regarded to experienced users of Dillo.
+
+<h3 id="plugins">Plugins</h3>
+<p>The functionality of Dillo can be extended by using plugins, which can
+translate other formats to HTML, implement new protocols or provide a custom
+service.</p>
+
+<p>Plugins can be written in <em>any programing language</em> and they
+interact with the browser using the
+<a href="https://dillo-browser.github.io/old/dpi1.html">DPI protocol</a>. A
+<a href="https://dillo-browser.github.io/#plugins">list of plugins</a>
+is available on the Dillo website. Some plugins are just a
+<a href="https://raw.githubusercontent.com/dillo-browser/dillo-plugin-man/master/man.filter.dpi">few
+lines of shell script</a>, so you are encouraged to read them to learn how to
+write your own plugins. Plugins are searched by looking for files that end with
+the <code>.dpi</code> extension (or <code>.dpi.exe</code> in Windows) in
+<code>~/.dillo/dpi</code> and <code>dpi_dir</code> (see the
+<a href="#dpidrc">Dpidrc</a> configuration section).</p>
+
+<p>There are two types of plugins: <em>filters</em> and <em>servers</em>.
+Filters are executed for each request like a
+<a href="https://en.wikipedia.org/wiki/Pipeline_(Unix)">UNIX pipe</a>,
+they read from the
+standard input and write to the standard output. The name of filter plugin
+programs must end in <code>.filter.dpi</code>. On the other hand, servers listen
+on a socket for new requests. They can process several requests at the same
+time, preventing the overhead of spawning multiple processes and they can easily
+share information among requests.</p>
+
+<p>You can install plugins from any third party, but you should always
+review the source before running code written by others. To install a new
+plugin, copy the files to <code>~/.dillo/dpi/<em>name</em>/</code> and
+then associate the <em>name</em> protocol to the program that must run in
+the
+<a href="file:~/.dillo/dpidrc"><code>~/.dillo/dpidrc</code></a> file.
+Plugins may have other software dependencies required for it to work.</p>
+
+<p>Here is an example of how to manually install the
+<a href="https://github.com/dillo-browser/dillo-plugin-gemini">Gemini protocol plugin</a>
+(it comes with a Makefile that automates the process, so this is not necessary),
+which is a filter plugin written in shell script:</p>
+<pre>
+$ mkdir -p ~/.dillo/dpi/gemini
+$ cp gemini.filter.dpi ~/.dillo/dpi/gemini/
+$ chmod +x ~/.dillo/dpi/gemini/gemini.filter.dpi
+$ echo "proto.gemini=gemini/gemini.filter.dpi" >> ~/.dillo/dpidrc
+$ dpidc stop
+</pre>
+<p>Now, when a request is made to an URL that begins with the
+<code>gemini:</code> protocol, it will be processed by the
+<code>gemini/gemini.filter.dpi</code> program, and the output will be displayed
+by Dillo.</p>
+
+<h3 id="bug-meter">Bug Meter</h3>
+<p>
+Dillo includes a
+<a href='https://dillo-browser.github.io/old/help/bug_meter.html'>bug meter</a>
+which shows the number of detected bugs inside the page. The bugs are caught at
+parsing time, so the error messages also show the line where they occur and
+provide a hint of what was expected instead.
+<p>
+The primary purpose of the bug meter is to help webmasters and page authors to
+polish the contents of their sites with a view to making them
+compliant with HTML standars.
+<p>
+The bug meter is located at the lower right corner of Dillo. Use the left-click
+to see the messages, right-click for a menu to open other HTML validators.
- </ul>
- </td></tr>
- </table>
-
- <table WIDTH="100%" BORDER=1 CELLSPACING=0 CELLPADDING=3>
- <tr ALIGN=LEFT VALIGN=TOP><td bgcolor="wheat">
- <h4><font color="green">Downloads:</font></h4>
- </td></tr>
-
- <tr><td BGCOLOR="#70a0c0">
- <p>
- Downloads are made using
- <b><font color="#5040a0">
- <a href="http://www.gnu.org/software/wget/">wget</a></font></b>
- with a <a href="http://www.fltk.org">FLTK</a>-based GUI wrapper, through
- the Dillo plugin (dpi) framework.
- If you close the browser window, downloads will continue.
- <p>
- </td></tr>
- </table>
-
- <table WIDTH="100%" BORDER=1 CELLSPACING=0 CELLPADDING=3>
- <tr ALIGN=LEFT VALIGN=TOP><td bgcolor="wheat">
- <h4><font color="green">Find text:</font></h4>
- </td></tr>
-
- <tr><td bgcolor="#70a0c0">
- <p>
- This one is very useful; it can be found in the right-mouse-button menu.
- Find text is tuned for speed, so don't hesitate to use it even for minimal
- searches.
- <p>
- <u>Semantics:</u>
- <ul>
- <li> You can search for substrings, words and sentences. </li>
- <li> To find a substring or word, just enter its text. </li>
- <li> To find a left-aligned substring, prepend it with a space. </li>
- <li> To find a right-aligned substring, append a space to it.</li>
- <li> To find full words only, prepend and append spaces to them. </li>
- <li> To find a sentence, enter the words and remember that
- the above rules apply for every word in it. </li>
- </ul>
- <p>
- Dillo will scroll the page and highlight found text.
- <p>
- <small>Default shortcut: [CTRL]+"F".</small>
-
- </td></tr>
- </table>
-
- <table WIDTH="100%" BORDER=1 CELLSPACING=0 CELLPADDING=3>
- <tr ALIGN=LEFT VALIGN=TOP><td bgcolor="wheat">
- <h4><font color="green">Copy&amp;Paste:</font></h4>
- </td></tr>
-
- <tr><td bgcolor="#70a0c0">
- <p>
- Just hold down the left mouse button and move to select the
- area to copy. To paste, go to the target application and
- press the middle mouse button.
- <p>
- If you want to select more than one screen, hold the mouse button
- down and scroll with PgUp, PgDn or the arrow keys.
- <P>
- If you want to paste an URL into Dillo, do it on the "clear-URL"
- button (the "X" next to the location bar).
- <p>
- Note: If it doesn't work, please try again. There's a bug lurking there.
- </td></tr>
- </table>
-
- <table WIDTH="100%" BORDER=1 CELLSPACING=0 CELLPADDING=3>
- <tr ALIGN=LEFT VALIGN=TOP><td bgcolor="wheat">
- <h4><font color="green">Navigation history:</font></h4>
- </td></tr>
-
- <tr><td bgcolor="#70a0c0">
- <p>
- Currently, navigation history supports the navigation-stack model; just
- right-click on the Back or Forward buttons and they will pop up!
- <p> <u>Remember:</u>
- <ul>
- <li> These history menus are relative to the current page. </li>
- <li> They show the page-title but the status bar shows the URL. </li>
- <li> Left-click jumps to the selected item. </li>
- <li> Middle-click opens the item in a new browser tab/window. </li>
- </ul>
- </td></tr>
- </table>
-
- <table WIDTH="100%" BORDER=1 CELLSPACING=0 CELLPADDING=3>
- <tr ALIGN=LEFT VALIGN=TOP><td bgcolor="wheat">
- <h4><font color="green">Cookies:</font></h4>
- </td></tr>
-
- <tr><td bgcolor="#70a0c0">
- <p>
- Due to privacy concerns, cookies are disabled by default.
- That is, if you just compile and use dillo, it will reject
- every single cookie sent to it!
- <p>
- If you want to enable cookies in dillo, please read
- <a href="Cookies.txt">Cookies.txt</a>. It's very easy --
- just a matter of setting up a <code>cookiesrc</code> file).
- </td></tr>
- </table>
-
- <table WIDTH="100%" BORDER=1 CELLSPACING=0 CELLPADDING=3>
- <tr ALIGN=LEFT VALIGN=TOP><td bgcolor="wheat">
- <h4><font color="green">Ad blocking:</font></h4>
- </td></tr>
-
- <tr><td bgcolor="#70a0c0">
- <p>
- With a
- <code>~/.dillo/<a href="https://raw.githubusercontent.com/dillo-browser/dillo/master/src/domainrc">domainrc</a></code>
- file, you can control how dillo handles automatic requests for resources
- (like images and style sheets) that aren't at the same domain as the
- original page.
- </td></tr>
- </table>
-
- <table WIDTH="100%" BORDER=1 CELLSPACING=0 CELLPADDING=3>
- <tr ALIGN=LEFT VALIGN=TOP><td bgcolor="wheat">
- <h4><font color="green">Tabs:</font></h4>
- </td></tr>
-
- <tr><td bgcolor="#70a0c0">
- <p>
- Dillo has tabbed browsing. Just middle click to open a link or submit a
- form in a new tab. It will be automatically focused. If you want to
- customize this behaviour, adjust these dillorc options:
- <ul>
- <li><code>middle_click_opens_new_tab</code>
- <li><code>focus_new_tab</code>
- </ul>
- Press SHIFT to temporarily reverse the focusing behaviour.
- <p>
- You can <b><font color="#5040a0">close</font></b>
- a tab with middle-click on its label (the default),
- or with right-click by setting this dillorc option:
- <ul><li><code>right_click_closes_tab</code></ul>
- </td></tr>
- </table>
-
- <table WIDTH="100%" BORDER=1 CELLSPACING=0 CELLPADDING=3>
- <tr ALIGN=LEFT VALIGN=TOP><td bgcolor="wheat">
- <h4><font color="green">Images-off mode:</font></h4>
- </td></tr>
- <tr><td bgcolor="#70a0c0">
- <p>
- You can browse without images now:
- <ul>
- <li>There is an option in the Tools menu to disable automatic image loading.
- An image's alt text (or <code>[IMG]</code> placeholder) will appear in the
- page.
- <li>If you want to load an individual image, left click on its text.
- <li>You can set "no images" as the default mode in dillorc.
- </ul>
- </td></tr>
- </table>
-
- <table WIDTH="100%" BORDER=1 CELLSPACING=0 CELLPADDING=3>
- <tr ALIGN=LEFT VALIGN=TOP><td bgcolor="wheat">
- <h4><font color="green">Bookmarks:</font></h4>
- </td></tr>
-
- <tr><td bgcolor="#70a0c0">
- <p>
- Bookmarks are handled by the Dillo plugin
- (<a href='https://dillo-browser.github.io/old/dpi1.html'>dpi</a>) framework.
- This should be transparent to the end user. Please note that:
- <ul>
- <li>It is a good idea to keep a backup of your
- <code>~/.dillo/bm.txt</code>
- <li>The server will stay alive after closing dillo.
- <li>You can stop the server by sending it a KILL signal. Dillo
- will automatically restart it when it is needed.
- <li>If you don't have root access, install <em>dpid</em> and
- the <em>dpis</em>
- inside your <code>~/.dillo/</code> directory as explained
- in the README file.
- </ul>
- </td></tr>
- </table>
-
- <table WIDTH="100%" BORDER=1 CELLSPACING=0 CELLPADDING=3>
- <tr ALIGN=LEFT VALIGN=TOP><td bgcolor="wheat">
- <h4><font color="green">Bug Meter:</font></h4>
- </td></tr>
- <tr><td bgcolor="#70a0c0">
- <p>
- Dillo's <em><a href='https://dillo-browser.github.io/old/help/bug_meter.html'>Bug
- meter</a></em> shows the
- number of <b><font color="#5040a0">detected bugs</font></b> inside the
- page. The bugs are caught at parsing time, so the
- error messages also show the line where they occur and provide a
- <b><font color="#5040a0">hint</font></b> of what was expected instead!
- <p>
- The primary purpose of the bug meter is to
- <b><font color="#5040a0">help</font></b> webmasters and page
- authors to polish the contents of their sites with a view to making
- them standards-compliant.
- <p>
- The Bug meter is located at the lower right corner of
- Dillo. Left-click to see the messages, right-click for a menu.
- </td></tr>
- </table>
-
- <table WIDTH="100%" BORDER=1 CELLSPACING=0 CELLPADDING=3>
- <tr ALIGN=LEFT VALIGN=TOP><td bgcolor="wheat">
- <h4><font color="green">Web search from the Location bar:</font></h4>
- </td></tr>
- <tr><td bgcolor="#70a0c0">
- <p>
- Besides the GUI, you can also use the location bar as a CLI for quick
- web search. You can specify a prefix in <b><font color="#5040a0">dillorc</font></b>
- for each search engine and use it from the location bar.
- <p>
- Example, in dillorc:<br>
- <blockquote>
- <code>search_url="dd Duckduckgo http://duckduckgo.com/lite/?kp=-1&amp;kd=-1&amp;q=%s"</code>
- </blockquote>
- means you can reach the location bar (CTRL+L), then type:
- <blockquote>
- <code>dd dillo browser</code>
- </blockquote>
- to web-search with Duckduckgo for the keywords: <code>dillo browser</code>.
- </td></tr>
- </table>
-
- <table WIDTH="100%" BORDER=1 CELLSPACING=0 CELLPADDING=3>
- <tr ALIGN=LEFT VALIGN=TOP><td bgcolor="wheat">
- <h4><font color="green">Keyboard shortcuts:</font></h4>
- </td></tr>
- <tr><td bgcolor="#70a0c0">
-<table border=1 width="100%">
+<h3 id="keyboard-shortcuts">Keyboard shortcuts</h3>
+<p>
+Most actions can be issued by using a keyboard shortcut. The key bindings can be
+changed in the
+<code><a href="file:~/.dillo/keysrc">~/.dillo/keysrc</a></code> file (see the
+<a href="#keysrc">keysrc</a> section).
+The list of default bindings is given in the following table.
+<p>
+<table>
<tr><th>Shortcut <th>Mnemonic <th>Function
-<tr><td>Ctrl-L <td>Location <td>enter a new URL
-<tr><td>Ctrl-F <td>Find <td>find text
-<tr><td>Ctrl-S <td>Search <td>search the web
-<tr><td>Ctrl-R <td>Reload <td>reload current page
+<tr><td>Ctrl-L <td>Location <td>Enter a new URL
+<tr><td>Ctrl-F <td>Find <td>Find text
+<tr><td>Ctrl-S <td>Search <td>Search the web
+<tr><td>Ctrl-R <td>Reload <td>Reload current page
<tr><td>Ctrl-N <td>New <td>New browser window
<tr><td>Ctrl-T <td>Tab <td>New tab
-<tr><td>Ctrl-W <td>Window <td>quit tab/window
+<tr><td>Ctrl-W <td>Window <td>Quit tab/window
<tr><td>Ctrl-O <td>Open <td>Open file
-<tr><td>Ctrl-U <td>(conventional) <td>view source
-<tr><td>Ctrl-B <td>Bookmarks <td>view bookmarks
+<tr><td>Ctrl-U <td> <td>View source
+<tr><td>Ctrl-B <td>Bookmarks <td>View bookmarks
<tr><td>Ctrl-Q <td>Quit <td>Quit dillo
-<tr><td>Back or "<b>,</b>" <td>< <td>previous page
-<tr><td>Shift-Back or "<b>.</b>" <td>> <td>next page
-<tr><td>Alt-F <td>File <td>file menu
-<tr><td>Ctrl-TabKey or
- Ctrl-PageDown <td>TabKey <td>Next tab
-<tr><td>Ctrl-Shift-TabKey or
- Ctrl-PageUp <td>TabKey <td>Previous tab
-<tr><td>Esc <td>escape <td>close dialog,
- close findbar,<br>
+<tr><td>Back or "<b>,</b>" <td>&lt; <td>Previous page
+<tr><td>Shift-Back or "<b>.</b>" <td>&gt; <td>Next page
+<tr><td>Alt-F <td>File <td>File menu
+<tr><td>Ctrl-Tab or<br>
+ Ctrl-PageDown <td>Tab <td>Next tab
+<tr><td>Ctrl-Shift-Tab or<br>
+ Ctrl-PageUp <td>Tab <td>Previous tab
+<tr><td>Esc <td>escape <td>Close dialog,
+ Close findbar,<br>
Hide/show control panels
</table>
-<p>
-You can <b><font color="#5040a0">change</font></b> the bindings using a
-<code>~/.dillo/<a href="https://raw.githubusercontent.com/dillo-browser/dillo/master/src/keysrc">keysrc</a></code>
-file.
- </td></tr>
- </table>
-
-
+<footer>
+<p>This manual has been written in HTML <em>by hand</em> using Vim.<br>
+If you find any issue, please report it via
+<a href="https://github.com/dillo-browser/dillo/issues/new">GitHub</a> or
+<a href="mailto:dillo-dev@mailman3.com">email</a>.
+</footer>
+</div>
</body>
</html>