URL Shortcuts in ELinks ----------------------- One extremely useful and convenient feature in ELinks, which may not be very well known, is so-called URL rewriting. If you give ELinks a URL (by passing it on the command line, through the -remote magic device or, most frequently, by typing it to the Goto URL dialog), it has the ability to mangle it in certain ways before processing it. This mangling is called URI rewriting. What it does ~~~~~~~~~~~~ The URI rewriting can expand certain URL shortcuts to complete URLs. For example, if you type 'sd' to the Goto URL dialog, it will be rewritten to: http://www.slashdot.org/ first, and then loaded. /.'s front page will be displayed. Further, if you type 'g elinks' to the Goto URL dialog, it will be rewritten to: http://www.google.com/search?q=elinks&btnG=Google+Search and then loaded, therefore, a Google search for the keyword 'elinks' will be performed. Note that you can separate the 'g' by either a space or a colon, so 'g:elinks' will do the exact same thing. A large number of those shortcuts are already defined for you. You can browse Protocols :: URI Rewriting :: Dumb/Smart prefixes in the Options Manager for a complete listing of already defined shortcuts (press the [Info] button on a shortcut to see what it will be rewritten to). See below for details on how to enable or disable this rewriting and how to define your own shortcuts. How it works ~~~~~~~~~~~~ All the URI rewriting can be controlled by options in the 'protocol.rewrite' option tree. In the case of 'sd', a URI rewriting mechanism called 'dumb prefixes' is used. If protocol.rewrite.enable-dumb is true, ELinks looks at the contents of the protocol.rewrite.dumb.* tree, and if it finds option protocol.rewrite.dumb.sd, it will use its value as the target URI. Therefore, more generally speaking, if ELinks looks at protocol.rewrite.dumb.<typed_string>, and if it exists, will replace the entered URI with it. These dumb prefixes can be used as a kind of alternative bookmark systen - if you want to have fast access to a certain site and you don't want to spend a while navigating the bookmarks manager, you can just fire up the Goto URL dialog, type the shortcut and there you go. A dumb prefix can contain '%c', which will be replaced by the URI of the current document. This is used, for example, in the 'arc' dumb-prefix, which provides a shortcut to the Wayback machine at archive.org. In the case of 'g', a slightly different URI rewriting mechanism called 'smart prefixes' is used. If protocol.rewrite.enable-smart is true, ELinks looks at the contents of the protocol.rewrite.smart tree and, if it finds option protocol.rewrite.smart.g, it will use its value as the target URI. The difference is that the smart prefixes can take arguments and reference them in the target URI. As with dumb prefixes, '%c' in the URI means the current address. Additionally, '%s' will be substituted by the whole string following the prefix ('elinks' in the 'g' example above; '%s' is by far the most frequently used expansion), while you can reference individual space-separated arguments with the codes '%0' thru '%9'. Finally, if you want a plain % to the resulting URI, use '%%'. Note that the prefix searched in the protocol.rewrite.smart tree is everything in the typed address up to the first space or colon (so 'bug:123' and 'bug 123' are identical). These prefixes are generally useful for searching anything very fast - be it Google ('g:foo', 'gi:foo', 'gr:foo', ...), ELinks Bugzilla bugs ('bug:1234'), the RFC database ('cr:foo'), or the Czech-English dictionary ('czen:foo'). The only limit is your imagination. Alternative URI rewriting mechanisms ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ In the past, before this was implemented, Lua scripting did the job. And you still have complete control over the URI in the internal scripting goto-url hook. The advantages are clear - you get complete control over the URI and you can do many more interesting things with it. For example, there are some very advanced CVSweb and Debian package database URI prefixes implemented in the sample Lua hooks file. The one disadvantage to this is that you must have Lua scripting enabled in order to make use of it, and many users don't have Lua installed.