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.
|
|
|
|
|
2023-09-11 12:38:13 +00:00
|
|
|
.TH UTOP 1
|
2011-08-02 17:34:27 +00:00
|
|
|
|
|
|
|
.SH NAME
|
|
|
|
utop \- Universal toplevel for OCaml
|
|
|
|
|
|
|
|
.SH SYNOPSIS
|
|
|
|
.B utop
|
|
|
|
[
|
|
|
|
.I options
|
|
|
|
]
|
|
|
|
[
|
|
|
|
.I object-files
|
|
|
|
]
|
|
|
|
[
|
|
|
|
.I script-file
|
|
|
|
]
|
|
|
|
|
|
|
|
.SH DESCRIPTION
|
|
|
|
|
|
|
|
.B utop
|
2023-09-08 09:05:52 +00:00
|
|
|
is an enhanced toplevel for OCaml with many features, including context
|
2011-08-02 17:34:27 +00:00
|
|
|
sensitive completion.
|
|
|
|
|
|
|
|
When you start
|
|
|
|
.B utop
|
|
|
|
what you see is the prompt followed by a bar containing words. This is
|
2023-09-08 09:05:52 +00:00
|
|
|
the completion bar: it contains the possible completion and is updated
|
2011-08-02 17:34:27 +00:00
|
|
|
as you type. The highlighted word in the completion bar is the
|
2023-09-11 12:38:13 +00:00
|
|
|
selected word. You can navigate using the keys \fBM-Left\fR and \fBM-Right\fR
|
|
|
|
and select one completion using \fBM-down\fR. Here \fBM\fR represents the meta key,
|
|
|
|
which is \fBAlt\fR on most systems. You can configure these bindings in the file
|
2020-04-26 04:40:26 +00:00
|
|
|
.I ~/.config/lambda-term-inputrc
|
2023-09-11 12:38:13 +00:00
|
|
|
- see
|
2011-08-02 17:34:27 +00:00
|
|
|
.BR lambda-term-inputrc (5)
|
2023-09-11 12:38:13 +00:00
|
|
|
for details.
|
2011-08-02 17:34:27 +00:00
|
|
|
|
2023-09-11 12:38:13 +00:00
|
|
|
\fButop\fR 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
|
2023-09-08 09:05:52 +00:00
|
|
|
as white on black, so the prompt may look too bright on light-colored
|
2011-08-02 17:34:27 +00:00
|
|
|
terminals. You can change that by setting the color profile of
|
2023-09-08 09:05:52 +00:00
|
|
|
utop. To do that, type:
|
2011-08-02 17:34:27 +00:00
|
|
|
|
|
|
|
UTop.set_profile UTop.Light;;
|
|
|
|
|
|
|
|
You can then add this line to your
|
2020-02-22 20:53:20 +00:00
|
|
|
.I ~/.config/utop/init.ml
|
2011-08-02 17:34:27 +00:00
|
|
|
file.
|
|
|
|
|
2023-09-11 12:38:13 +00:00
|
|
|
To turn off \fButop\fR's advanced prompt features, add the following to \fIinit.ml\fR
|
2020-03-18 02:43:05 +00:00
|
|
|
to turn off respectively (a) colors and the upper information line, and
|
2019-05-01 03:08:41 +00:00
|
|
|
(b) the lower boxed list of possible completions:
|
|
|
|
|
2020-03-18 02:43:05 +00:00
|
|
|
#utop_prompt_dummy;;
|
2019-05-01 03:08:41 +00:00
|
|
|
UTop.set_show_box false
|
|
|
|
|
2011-08-02 17:34:27 +00:00
|
|
|
You can enable basic syntax highlighting in utop by writing a
|
|
|
|
.I ~/.utoprc
|
|
|
|
file. See
|
|
|
|
.BR utoprc (5)
|
|
|
|
for that.
|
|
|
|
|
2023-09-11 12:38:13 +00:00
|
|
|
Vi edit mode is enabled by the command
|
|
|
|
|
|
|
|
#edit_mode_vi
|
2011-08-02 17:34:27 +00:00
|
|
|
|
2023-09-11 12:38:13 +00:00
|
|
|
It currently supports three vi modes: normal, insert, visual mode, and you can
|
|
|
|
get/set content with vim-like registers.
|
2011-08-02 17:34:27 +00:00
|
|
|
|
2023-09-11 12:38:13 +00:00
|
|
|
.I utop.el
|
|
|
|
is a package that provides
|
|
|
|
.B utop
|
|
|
|
integration with Emacs. The package allows you to run
|
|
|
|
.B utop
|
|
|
|
inside Emacs and to evaluate code in it straight from your source buffers
|
|
|
|
(with the help of \fIutop-minor-mode\fR).
|
|
|
|
The recommended way to install
|
|
|
|
.I utop.el
|
|
|
|
is via Emacs's built-in package manager \fBpackage.el\fR.
|
|
|
|
More detailed installation and configuration instructions may be found
|
|
|
|
on the project's code repository at \fIhttps://github.com/ocaml-community/utop\fR.
|
|
|
|
|
|
|
|
You can start \fButop\fR inside Emacs with \fBM-x utop\fR.
|
|
|
|
|
|
|
|
The default install also has a minor mode with the following key bindings:
|
|
|
|
|
|
|
|
\fBC-c C-s\fR Start a utop buffer (\fIutop\fR)
|
|
|
|
\fBC-x C-e\fR Evaluate the current phrase (\fIutop-eval-phrase\fR)
|
|
|
|
\fBC-x C-r\fR Evaluate the selected region (\fIutop-eval-region\fR)
|
|
|
|
\fBC-c C-b\fR Evaluate the current buffer (\fIutop-eval-buffer\fR)
|
|
|
|
\fBC-c C-k\fR Kill a running utop process (\fItop-kill\fR)
|
|
|
|
\fBC-c C-z\fR Switch to utop process (\fIutop-switch-to-repl\fR)
|
|
|
|
|
|
|
|
then you can run \fButop\fR by pressing \fBM-x\fR and typing "utop". \fButop\fR supports
|
|
|
|
completion in Emacs mode. Just press \fBTab\fR to complete a word. You can
|
2015-01-12 10:06:08 +00:00
|
|
|
also integrate it with the tuareg, caml or typerex mode. For that add
|
|
|
|
the following lines to your
|
2011-08-02 17:34:27 +00:00
|
|
|
.I ~/.emacs
|
|
|
|
file:
|
|
|
|
|
2015-01-12 10:06:08 +00:00
|
|
|
(autoload 'utop-minor-mode "utop" "Minor mode for utop" t)
|
|
|
|
(add-hook 'tuareg-mode-hook 'utop-minor-mode)
|
2011-08-02 17:34:27 +00:00
|
|
|
|
|
|
|
.SH OPTIONS
|
2021-11-30 10:03:06 +00:00
|
|
|
See
|
|
|
|
.B utop --help
|
2023-09-11 12:38:13 +00:00
|
|
|
for the full list of available options. There is considerable overlap
|
2021-11-30 10:03:06 +00:00
|
|
|
with options available for
|
2011-08-02 17:34:27 +00:00
|
|
|
.BR ocaml (1).
|
|
|
|
|
2021-11-30 10:03:06 +00:00
|
|
|
A commonly used option is
|
2021-12-01 09:03:12 +00:00
|
|
|
\fB-require\fI package\fR
|
2021-11-30 10:03:06 +00:00
|
|
|
to load \fIpackage\fR into the execution environment. It is equivalent
|
|
|
|
to using \fb#require\fR from inside
|
|
|
|
.BR utop (1).
|
|
|
|
|
2021-12-01 09:03:12 +00:00
|
|
|
.PP
|
|
|
|
.TP
|
|
|
|
.BI -absname
|
2021-12-02 17:04:58 +00:00
|
|
|
Show absolute filenames in error message.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -I " dir"
|
2021-12-02 17:04:58 +00:00
|
|
|
Add \fIdir\fR to the list of include directories.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -init " file"
|
2023-09-08 09:05:52 +00:00
|
|
|
Load \fIfile\fR instead of the default init file.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -labels
|
2021-12-02 17:04:58 +00:00
|
|
|
Use commuting label mode.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -no-app-funct
|
2021-12-02 17:04:58 +00:00
|
|
|
Deactivate applicative functors.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -noassert
|
2021-12-02 17:04:58 +00:00
|
|
|
Do not compile assertion checks.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -nolabels
|
2021-12-02 17:04:58 +00:00
|
|
|
Ignore non-optional labels in types.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -nostdlib
|
2023-09-08 09:05:52 +00:00
|
|
|
Do not add the default directory to the list of include directories.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -ppx " command"
|
2023-09-08 09:05:52 +00:00
|
|
|
Pipe abstract syntax trees through the preprocessor \fIcommand\fR.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -principal
|
2021-12-02 17:04:58 +00:00
|
|
|
Check principality of type inference.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -safe-string
|
2021-12-02 17:04:58 +00:00
|
|
|
Make strings immutable.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -short-paths
|
2021-12-02 17:04:58 +00:00
|
|
|
Shorten paths in types (the default).
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -no-short-paths
|
2021-12-02 17:04:58 +00:00
|
|
|
Do not shorten paths in types.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -rectypes
|
2021-12-02 17:04:58 +00:00
|
|
|
Allow arbitrary recursive types.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -stdin
|
2021-12-02 17:04:58 +00:00
|
|
|
Read script from standard input.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -strict-sequence
|
2021-12-02 17:04:58 +00:00
|
|
|
Left-hand part of a sequence must have type unit.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -unsafe
|
2021-12-02 17:04:58 +00:00
|
|
|
Do not compile bounds checking on array and string access.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -version
|
2021-12-02 17:04:58 +00:00
|
|
|
Print version and exit.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -vnum
|
2021-12-02 17:04:58 +00:00
|
|
|
Print version number and exit.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -w " list"
|
2021-12-02 17:04:58 +00:00
|
|
|
Enable or disable warnings according to \fIlist\fR.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -warn-error " list"
|
2021-12-02 17:04:58 +00:00
|
|
|
Enable or disable error status for warnings according to \fIlist\fR.
|
2021-12-01 09:03:12 +00:00
|
|
|
See option \fB-w\fR for the syntax of \fIlist\fR.
|
2021-12-02 17:04:58 +00:00
|
|
|
Default setting is \fB-a+31\fR.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -warn-help
|
2021-12-02 17:04:58 +00:00
|
|
|
Show description of warning numbers.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -emacs
|
2021-12-02 17:04:58 +00:00
|
|
|
Run in emacs mode.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -hide-reserved
|
2021-12-02 17:04:58 +00:00
|
|
|
Hide identifiers starting with a '_' (the default).
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -show-reserved
|
2021-12-02 17:04:58 +00:00
|
|
|
Show identifiers starting with a '_'.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -no-implicit-bindings
|
2021-12-02 17:04:58 +00:00
|
|
|
Don't add implicit bindings for expressions (the default).
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -implicit-bindings
|
|
|
|
Add implicit bindings: \fIexpr\fR;; -> let _0 = \fIexpr\fR;;
|
|
|
|
.TP
|
|
|
|
.BI -no-autoload
|
|
|
|
Disable autoloading of files in
|
2021-12-02 17:04:58 +00:00
|
|
|
.I $OCAML_TOPLEVEL_PATH/autoload.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -require " package"
|
2021-12-02 17:04:58 +00:00
|
|
|
Load this package.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -dparsetree
|
2021-12-02 17:04:58 +00:00
|
|
|
Dump OCaml AST after rewriting.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -dsource
|
2021-12-02 17:04:58 +00:00
|
|
|
Dump OCaml source after rewriting.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI -help
|
2021-12-02 17:04:58 +00:00
|
|
|
Display this list of options.
|
2021-12-01 09:03:12 +00:00
|
|
|
.TP
|
|
|
|
.BI --help
|
2021-12-02 17:04:58 +00:00
|
|
|
Display this list of options.
|
2021-12-01 09:03:12 +00:00
|
|
|
|
2011-08-02 17:34:27 +00:00
|
|
|
.SH FILES
|
2020-02-22 20:53:20 +00:00
|
|
|
.I ~/.config/utop/init.ml
|
2011-08-02 17:34:27 +00:00
|
|
|
.RS
|
|
|
|
The initialization file of the toplevel.
|
|
|
|
.RE
|
2020-02-22 20:53:20 +00:00
|
|
|
.I ~/.ocamlinit
|
|
|
|
.RS
|
|
|
|
The alternative initialization file of the toplevel.
|
|
|
|
.RE
|
2011-08-02 17:34:27 +00:00
|
|
|
.I ~/.utoprc
|
|
|
|
.RS
|
|
|
|
The configuration file for utop. See
|
|
|
|
.BR utoprc (5).
|
|
|
|
.RE
|
2020-04-26 04:40:26 +00:00
|
|
|
.I ~/.config/lambda-term-inputrc
|
2011-08-02 17:34:27 +00:00
|
|
|
.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).
|