This library wraps the BSD libedit command line editor. The binding provides a high level API to enable command line editing on the Prolog user streams and low level predicates to apply the library on other streams and program the library.
user_input 
is connected to a terminal. This is the high level predicate used for 
most purposes. The remainder of the library interface deals with low 
level predicates that allows for applying and programming libedit in 
non-standard situations.
The library is registered with ProgName set to swipl 
(see
el_wrap/4).
| ProgName | is the name of the 
invoking program, used when reading the editrc(5)file to 
determine which settings to use. | 
forall(el_setup(Input), true) after 
the input stream has been wrapped, the default Prolog commands have been 
added and the default user setup file has been sourced using
el_source/2. It can be used to 
define and bind additional commands.$HOME/.editrcbind command with the given arguments. 
The example below lists the current key bindings.
?- el_bind(user_input, ['-a']).
The predicate el_bind/2 is 
typically used to bind commands defined using el_addfn/4. 
Note that the C proxy function has only the last character of the 
command as context to find the Prolog binding. This implies we cannot 
both bind e.g., "^[?" *and "?" to a Prolog function.
bind -a (see el_bind/2) 
and Goal is called of the associated key-binding is 
activated. Goal is called as
call(:Goal, +Input, +Char, -Continue)
where Input is the input stream providing access to the 
editor, Char the activating character and Continue must be instantated 
with one of the known continuation codes as defined by libedit: norm,
newline, eof, arghack, refresh, refresh_beep, cursor,
redisplay, error or fatal. In 
addition, the following Continue code is provided.
The registered Goal typically used el_line/2 to fetch the input line and el_cursor/2, el_insertstr/2 and/or el_deletestr/2 to manipulate the input line.
Normally el_bind/2 is used to associate the defined command with a keyboard sequence.
line(Before, After), 
where Before is a string holding the text before the cursor 
and After is a string holding the text after the cursor.history() from libedit. Supported actions are:
Num-String, 
where
Num is the event number and String is the 
associated string without terminating newline.| File | is a file specification for absolute_file_name/3. | 
| File | is a file specification for absolute_file_name/3. |