help
This tool provides help for Logtalk features and libraries when running
in most operating-systems. For help on the Logtalk compiler error and
warning messages, see the tutor tool.
Requirements
On Windows, the start command must be available. On Linux, the
xdg-open command must be available. On macOS, the command open
is used.
Browsing the Handbook and APIs documentation at the top-level requires a POSIX system and one of the following terminal-based browsers installed:
The preferred browser can be set in a settings.lgt file by defining
the help_default_browser user-defined flag as follows:
:- initialization(
create_logtalk_flag(help_default_browser, Browser, [type(atom), keep(true)])
).
The valid values for Browser are: lynx, w3m, links,
cha, and default (default means use the operating-system
default browser instead of one of the terminal-based browsers).
The samples/settings-sample.lgt file contains commented out code for
this flag.
On Windows systems, the documentation is open in the operating-system default browser.
API documentation
This tool API documentation is available at:
Loading
| ?- logtalk_load(help(loader)).
Testing
To test this tool, load the tester.lgt file:
| ?- logtalk_load(help(tester)).
Supported operating-systems
Currently, support is limited to Linux, macOS, and Windows.
This tool relies on the library portable operating-system access abstraction.
Usage
After loading the tool, use the query help::help to get started:
| ?- logtalk_load(help(loader)).
...
| ?- help::help.
...
When using ECLiPSe, you will need to write the object name, help,
between parentheses to avoid a clash with the “help” built-in operator:
| ?- (help)::help.
...
Same sample help queries:
% get et on-line help for the `logtalk_load/2` built-in predicate:
| ?- help::logtalk_load/2.
...
% get on-line help for the `eos//0` built-in non-terminal:
| ?- help::eos//0.
...
% consult the Handbook:
| ?- help::handbook.
...
% consult the APIs documentation:
| ?- help::apis.
...
% consult the APIs documentation about a library predicate:
| ?- help::apis(member/2).
...
% consult the APIs documentation about a library non-terminal:
| ?- help::apis(one_or_more//0).
...
% consult the documentation of a library:
| ?- help::library(random).
...
% consult the documentation of an entity:
| ?- help::entity(logtalk).
...
% consult the developer tools documentation:
| ?- help::tools.
...
% consult the documentation of the lgtunit tool:
| ?- help::tool(lgtunit).
...
When using the terminal-based browsers, after finishing consulting the
documentation and quitting the process, you will be back to the
top-level prompt (if you find that the top-level have scrolled from its
last position, try to set your terminal terminfo to
xterm-256colour).
If you’re running Logtalk from a git clone of its repo, you will need to
run the docs/apis/sources/build.sh or
docs/apis/sources/build.ps1 scripts to generate APIs documentation
HTML files and also run the docs/handbook/sources/build.sh or
docs/handbook/sources/build.ps1 scripts to generate the Handbook
HTML files. Alternatively, you can download the documentation for the
latest stable release from the Logtalk website and save them to the
docs directories.
On POSIX systems, one of the supported terminal-based browsers must be
installed unless you prefer using the default browser. By default, the
tool checks first for lynx, second for w3m, third for links,
and finally for chawan.
On macOS, these browsers can be installed with either MacPorts:
$ sudo port install lynx
$ sudo port install w3m
$ sudo port install links
Or using Homebrew:
$ brew install lynx
$ brew install w3m
$ brew install links
$ brew install chawan
On Linux systems, use the distribution’s own package manager to install the browsers. For example, in Ubuntu systems:
$ sudo apt install lynx
$ sudo apt install w3m
Known issues
When using the terminal-based browsers, the Handbook and APIs search boxes are not usable as they require JavaScript support. Use instead the indexes.
The open commands used to open documentation URLs in the default browser drop the fragment part, thus preventing navigation to the specified position on the documentation page.
ECLiPSe defines a help prefix operator that forces wrapping this
atom between parentheses when sending messages to the tool. E.g. use
(help)::help instead of help::help.