help.pl -- Text based manual
This module provides help/1 and apropos/1 that give help on a topic or searches the manual for relevant topics.
By default the result of help/1 is sent through a pager such as
less
. This behaviour is controlled by the following:
- The Prolog flag
help_pager
, which can be set to one of the following values:- false
- Never use a pager.
- default
- Use default behaviour. This tries to determine whether Prolog
is running interactively in an environment that allows for
a pager. If so it examines the environment variable
PAGER
or otherwise tries to find theless
program. - Callable
- A Callable term is interpreted as
program_name(Arg, ...)
. For example,less('-r')
would be the default. Note that the program name can be an absolute path if single quotes are used.
- help is det
- help(+What) is det
- Show help for What. What is a term that describes the
topics(s)
to give help for. Notations for What are:- Atom
- This ambiguous form is most commonly used and shows all
matching documents. For example:
?- help(append).
- Name / Arity
- Give help on predicates with matching Name/Arity. Arity may be unbound.
- Name // Arity
- Give help on the matching DCG rule (non-terminal)
- f(Name/Arity)
- Give help on the matching Prolog arithmetic functions.
- c(Name)
- Give help on the matching C interface function
- section(Label)
- Show the section from the manual with matching Label.
If an exact match fails this predicates attempts fuzzy matching and, when successful, display the results headed by a warning that the matches are based on fuzzy matching.
If possible, the results are sent through a pager such as the
less
program. This behaviour is controlled by the Prolog flaghelp_pager
. See section level documentation. - show_html_hook(+HTML:string) is semidet[multifile]
- Hook called to display the extracted HTML document. If this hook fails the HTML is rendered to the console as plain text using html_text/2.
- tty_width(-Width) is det[private]
- Return the believed width of the terminal. If we do not know Width is bound to 80.
- current_predicate_help(?PI) is nondet[private]
- True when we have documentation on PI. First we decide we have a definition for PI, then we check whether or not we have documentation for the module in which PI resides. If not, we switch to documentation collect mode and reload the file that defines PI.
- with_pager(+Goal)[private]
- Send the current output of Goal through a pager. If no pager can be found we simply dump the output to the current output.
- running_under_emacs[private]
- True when we believe to be running in Emacs. Unfortunately there is no easy unambiguous way to tell.
- apropos(+Query) is det
- Print objects from the manual whose name or summary match with
Query. Query takes one of the following forms:
- Type:Text
- Find objects matching Text and filter the results by Type.
Type matching is a case intensitive prefix match.
Defined types are
section
,cfunction
,function
,iso_predicate
,swi_builtin_predicate
,library_predicate
,dcg
and aliaseschapter
,arithmetic
,c_function
,predicate
,nonterminal
andnon_terminal
. For example:?- apropos(c:close). ?- apropos(f:min).
- Text
- Text is broken into tokens. A topic matches if all tokens appear in the name or summary of the topic. Matching is case insensitive. Results are ordered depending on the quality of the match.
Re-exported predicates
The following predicates are exported from this file while their implementation is defined in imported modules or non-module files loaded by this module.
- help is det
- help(+What) is det
- Show help for What. What is a term that describes the
topics(s)
to give help for. Notations for What are:- Atom
- This ambiguous form is most commonly used and shows all
matching documents. For example:
?- help(append).
- Name / Arity
- Give help on predicates with matching Name/Arity. Arity may be unbound.
- Name // Arity
- Give help on the matching DCG rule (non-terminal)
- f(Name/Arity)
- Give help on the matching Prolog arithmetic functions.
- c(Name)
- Give help on the matching C interface function
- section(Label)
- Show the section from the manual with matching Label.
If an exact match fails this predicates attempts fuzzy matching and, when successful, display the results headed by a warning that the matches are based on fuzzy matching.
If possible, the results are sent through a pager such as the
less
program. This behaviour is controlled by the Prolog flaghelp_pager
. See section level documentation.