2011-08-02 17:34:27 +00:00
|
|
|
\" utop.1
|
|
|
|
\" ------
|
|
|
|
\" Copyright : (c) 2011, Jeremie Dimino <jeremie@dimino.org>
|
|
|
|
\" Licence : BSD3
|
|
|
|
\"
|
|
|
|
\" This file is a part of utop.
|
|
|
|
|
|
|
|
.TH UTOP 1 "August 2011"
|
|
|
|
|
|
|
|
.SH NAME
|
|
|
|
utop \- Universal toplevel for OCaml
|
|
|
|
|
|
|
|
.SH SYNOPSIS
|
|
|
|
.B utop
|
|
|
|
[
|
|
|
|
.I options
|
|
|
|
]
|
|
|
|
[
|
|
|
|
.I object-files
|
|
|
|
]
|
|
|
|
[
|
|
|
|
.I script-file
|
|
|
|
]
|
|
|
|
|
|
|
|
.SH DESCRIPTION
|
|
|
|
|
|
|
|
.B utop
|
|
|
|
is a enhanced toplevel for OCaml with many features, including context
|
|
|
|
sensitive completion.
|
|
|
|
|
|
|
|
When you start
|
|
|
|
.B utop
|
|
|
|
what you see is the prompt followed by a bar containing words. This is
|
|
|
|
the completion bar, it contains the possible completion and is updated
|
|
|
|
as you type. The highlighted word in the completion bar is the
|
|
|
|
selected word. You can navigate using the keys Alt+Left and Alt+Right
|
|
|
|
and you can complete using the currently selected word by pressing
|
|
|
|
Alt+Tab (you can configure these bindings in the file
|
|
|
|
.I ~/.lambda-term-inputrc
|
|
|
|
, see
|
|
|
|
.BR lambda-term-inputrc (5)
|
|
|
|
for details).
|
|
|
|
|
2011-08-03 07:47:05 +00:00
|
|
|
utop supports completion on:
|
2011-08-02 17:34:27 +00:00
|
|
|
|
|
|
|
* directives and directive arguments
|
|
|
|
* identifiers
|
|
|
|
* record fields
|
|
|
|
* variants
|
|
|
|
* function labels
|
|
|
|
* object methods
|
|
|
|
|
|
|
|
Colors are by default configured for terminals with dark colors, such
|
|
|
|
as white on black, so the prompt may looks too bright on light colors
|
|
|
|
terminals. You can change that by setting the color profile of
|
|
|
|
utop. For that type:
|
|
|
|
|
|
|
|
UTop.set_profile UTop.Light;;
|
|
|
|
|
|
|
|
You can then add this line to your
|
|
|
|
.I ~/.ocamlinit
|
|
|
|
file.
|
|
|
|
|
|
|
|
You can enable basic syntax highlighting in utop by writing a
|
|
|
|
.I ~/.utoprc
|
|
|
|
file. See
|
|
|
|
.BR utoprc (5)
|
|
|
|
for that.
|
|
|
|
|
|
|
|
Finally utop can run in emacs. For that you have to add the following line to your
|
|
|
|
.I ~/.emacs
|
|
|
|
file:
|
|
|
|
|
|
|
|
(autoload 'utop "utop" "Toplevel for OCaml" t)
|
|
|
|
|
|
|
|
then you can run utop by pressing M-x and typing "utop". utop support
|
|
|
|
completion in emacs mode. Just press Tab to complete a word. You can
|
|
|
|
also integrate it with the tuareg mode. For that add the following
|
|
|
|
lines to your
|
|
|
|
.I ~/.emacs
|
|
|
|
file:
|
|
|
|
|
|
|
|
(autoload 'utop-eval-region "utop" "Toplevel for OCaml" t)
|
|
|
|
(autoload 'utop-eval-phrase "utop" "Toplevel for OCaml" t)
|
|
|
|
(autoload 'utop-eval-buffer "utop" "Toplevel for OCaml" t)
|
|
|
|
|
|
|
|
(defun tuareg-utop-hook ()
|
|
|
|
(local-set-key "\\M-\\C-x" 'utop-eval-phrase)
|
|
|
|
(local-set-key "\\C-x\\C-e" 'utop-eval-phrase)
|
|
|
|
(local-set-key "\\C-c\\C-e" 'utop-eval-phrase)
|
|
|
|
(local-set-key "\\C-c\\C-r" 'utop-eval-region)
|
|
|
|
(local-set-key "\\C-c\\C-b" 'utop-eval-buffer))
|
|
|
|
|
|
|
|
(add-hook 'tuareg-mode-hook 'tuareg-utop-hook)
|
|
|
|
|
|
|
|
.SH OPTIONS
|
|
|
|
Same as
|
|
|
|
.BR ocaml (1).
|
|
|
|
|
|
|
|
.SH FILES
|
|
|
|
.I ~/.ocamlinit
|
|
|
|
.RS
|
|
|
|
The initialization file of the toplevel.
|
|
|
|
.RE
|
|
|
|
.I ~/.utoprc
|
|
|
|
.RS
|
|
|
|
The configuration file for utop. See
|
|
|
|
.BR utoprc (5).
|
|
|
|
.RE
|
|
|
|
.I ~/.lambda-term-inputrc
|
|
|
|
.RS
|
|
|
|
The file containing key bindings. See
|
|
|
|
.BR lambda-term-inputrc (5).
|
|
|
|
|
|
|
|
.SH AUTHOR
|
|
|
|
Jérémie Dimino <jeremie@dimino.org>
|
|
|
|
|
|
|
|
.SH "SEE ALSO"
|
|
|
|
.BR utoprc (5),
|
|
|
|
.BR lambda-term-inputrc (5),
|
|
|
|
.BR ocaml (1).
|