Provided by: ocaml-base-nox_4.08.1-8_amd64 bug

NAME

       ocamlrun - The OCaml bytecode interpreter

SYNOPSIS

       ocamlrun [ options ] filename argument ...

DESCRIPTION

       The ocamlrun(1) command executes bytecode files produced by the linking phase of the ocamlc(1) command.

       The  first  non-option  argument  is taken to be the name of the file containing the executable bytecode.
       (That file is searched in the executable path as  well  as  in  the  current  directory.)  The  remaining
       arguments  are passed to the OCaml program, in the string array Sys.argv.  Element 0 of this array is the
       name of the bytecode executable file; elements 1 to n are the remaining arguments.

       In most cases, the bytecode executable files produced by the ocamlc(1) command are  self-executable,  and
       manage to launch the ocamlrun(1) command on themselves automatically.

OPTIONS

       The following command-line options are recognized by ocamlrun(1).

       -b     When  the  program  aborts  due  to  an  uncaught  exception, print a detailed "back trace" of the
              execution, showing where the exception was raised and which function  calls  were  outstanding  at
              this  point.   The  back  trace  is  printed  only  if  the bytecode executable contains debugging
              information, i.e. was compiled and linked with the -g option to ocamlc(1)  set.   This  option  is
              equivalent to setting the b flag in the OCAMLRUNPARAM environment variable (see below).

       -I dir Search  the  directory  dir  for  dynamically-loaded libraries, in addition to the standard search
              path.

       -p     Print the names of the primitives known to this version of ocamlrun(1) and exit.

       -v     Direct the memory manager to print verbose messages on standard  error.   This  is  equivalent  to
              setting v=63 in the OCAMLRUNPARAM environment variable (see below).

       -version
              Print version string and exit.

       -vnum  Print short version number and exit.

ENVIRONMENT VARIABLES

       The following environment variable are also consulted:

       CAML_LD_LIBRARY_PATH
              Additional directories to search for dynamically-loaded libraries.

       OCAMLLIB
              The  directory  containing  the  OCaml standard library.  (If OCAMLLIB is not set, CAMLLIB will be
              used instead.) Used to locate the ld.conf configuration file for dynamic  loading.   If  not  set,
              default to the library directory specified when compiling OCaml.

       OCAMLRUNPARAM
              Set  the  runtime system options and garbage collection parameters.  (If OCAMLRUNPARAM is not set,
              CAMLRUNPARAM will be used instead.)  This variable must be a sequence of parameter  specifications
              separated  by  commas.  A parameter specification is a letter, optionally followed by an = sign, a
              decimal number (or a hexadecimal number prefixed by 0x), and an optional multiplier. If the letter
              is  followed  by anything else, the corresponding option is set to 1. Unknown letters are ignored.
              The options are documented below; the last six correspond to the  fields  of  the  control  record
              documented in The OCaml user's manual, chapter "Standard Library", section "Gc".

       b      Trigger  the  printing  of  a stack backtrace when an uncaught exception aborts the program.  This
              option takes no argument.

       p      Turn on debugging support for ocamlyacc-generated parsers.  When this option is on,  the  pushdown
              automaton that executes the parsers prints a trace of its actions.  This option takes no argument.

       R      Turn  on  randomization  of  all  hash  tables  by default (see the Hashtbl module of the standard
              library). This option takes no argument.

       h      The initial size of the major heap (in words).

       a (allocation_policy)
              The policy used for allocating in the OCaml heap.  Possible values are 0 for the next-fit  policy,
              and  1 for the first-fit policy.  Next-fit is usually faster, but first-fit is better for avoiding
              fragmentation and the associated heap compactions.

       s (minor_heap_size)
              The size of the minor heap (in words).

       i (major_heap_increment)
              The default size increment for the major heap (in words).

       o (space_overhead)
              The major GC speed setting.

       O (max_overhead)
              The heap compaction trigger setting.

       l (stack_limit)
              The limit (in words) of the stack size.

       M (custom_major_ratio)
              Target ratio of floating garbage to major heap size for out-of-heap memory held by  custom  values
              located in the major heap. The GC speed is adjusted to try to use this much memory for dead values
              that are not yet collected. Expressed as a percentage of major heap size.  The default value keeps
              the  out-of-heap  floating  garbage  about the same size as the in-heap overhead.  Note: this only
              applies to values allocated with caml_alloc_custom_mem (e.g. bigarrays).  Default: 44.

       m (custom_minor_ratio)
              Bound on floating garbage for out-of-heap memory held by custom values in the minor heap. A  minor
              GC  is  triggered  when  this  much  memory  is  held  by custom values located in the minor heap.
              Expressed as a percentage of minor heap size.  Note: this only applies to  values  allocated  with
              caml_alloc_custom_mem (e.g. bigarrays).
               Default: 100.

       n (custom_minor_max_size)
              Maximum  amount  of  out-of-heap  memory for each custom value allocated in the minor heap. When a
              custom value is allocated on the minor heap and holds more than this many bytes, only  this  value
              is counted against custom_minor_ratio and the rest is directly counted against custom_major_ratio.
              Note: this only applies to values allocated with caml_alloc_custom_mem (e.g. bigarrays).  Default:
              8192 bytes.

       v (verbose)
              What GC messages to print to stderr.  This is a sum of values selected from the following:

              0x001 Start of major GC cycle.

              0x002 Minor collection and major GC slice.

              0x004 Growing and shrinking of the heap.

              0x008 Resizing of stacks and memory manager tables.

              0x010 Heap compaction.

              0x020 Change of GC parameters.

              0x040 Computation of major GC slice size.

              0x080 Calling of finalisation functions.

              0x100 Startup messages (loading the bytecode executable file, resolving shared libraries).

              0x200 Computation of compaction-triggering condition.

              0x400 Output GC statistics at program exit, in the same format as Gc.print_stat.

              The multiplier is k, M, or G, for multiplication by 2^10, 2^20, and 2^30 respectively.

              If  the  option letter is not recognized, the whole parameter is ignored; if the equal sign or the
              number is missing, the value is taken as 1; if the multiplier is not recognized, it is ignored.

              For example, on a 32-bit machine under bash, the command export OCAMLRUNPARAM='s=256k,v=1' tells a
              subsequent ocamlrun to set its initial minor heap size to 1 megabyte and to print a message at the
              start of each major GC cycle.

       CAMLRUNPARAM
              If OCAMLRUNPARAM is not found in the environment, then CAMLRUNPARAM  will  be  used  instead.   If
              CAMLRUNPARAM is also not found, then the default values will be used.

       PATH   List of directories searched to find the bytecode executable file.

SEE ALSO

       ocamlc(1).
       The OCaml user's manual, chapter "Runtime system".

                                                                                                     OCAMLRUN(1)