Provided by: erlang-manpages_25.3.2.8+dfsg-1ubuntu4.4_all bug

NAME

       reltool - Main API of the Reltool application

DESCRIPTION

       This is an interface module for the Reltool application.

       Reltool  is a release management tool. It analyses a given Erlang/OTP installation and determines various
       dependencies  between  applications.  The  graphical  frontend  depicts  the  dependencies  and   enables
       interactive  customization  of  a target system. The backend provides a batch interface for generation of
       customized target systems.

       The tool uses an installed Erlang/OTP system as input. root_dir is the root  directory  of  the  analysed
       system  and  it  defaults  to  the  system  executing  Reltool.  Applications may also be located outside
       root_dir. lib_dirs defines library directories where additional applications may reside and  it  defaults
       to  the directories listed by the operating system environment variable ERL_LIBS. See the module code for
       more info.

       An application directory AppDir  under  a  library  directory  is  recognized  by  the  existence  of  an
       AppDir/ebin  directory.  If this does not exist, Reltool will not consider AppDir at all when looking for
       applications.

       It is recommended that application directories are named as the application, possibly followed by a  dash
       and the version number. For example myapp or myapp-1.1.

       Finally single modules and entire applications may be read from Escripts.

       Some  configuration  parameters  control  the  behavior  of Reltool on system (sys) level. Others provide
       control on application (app) level and yet others are on module  (mod)  level.  Module  level  parameters
       override  application level parameters and application level parameters override system level parameters.
       Escript escript level parameters override system level parameters.

       The following top level options are supported:

         config:
           This is the main option and it controls the configuration of Reltool. It can either be a sys tuple or
           a name of a file containing a sys tuple.

         trap_exit:
           This option controls the error handling behavior of Reltool. By default the  window  processes  traps
           exit, but this behavior can altered by setting trap_exit to false.

         wx_debug:
           This  option  controls  the debug level of wx. As its name indicates it is only useful for debugging.
           See wx:debug/1 for more info.

       Besides the already mentioned source parameters root_dir and lib_dirs, the following system  (sys)  level
       options are supported:

         erts:
           Erts specific configuration. See application level options below.

         escript:
           Escript  specific  configuration. An escript has a mandatory file name and escript level options that
           are described below.

         app:
           Application specific configuration. An application has a mandatory name and application level options
           that are described below.

         mod_cond:
           This parameter controls the module inclusion policy. It defaults  to  all  which  means  that  if  an
           application  is  included  (either  explicitly or implicitly) all modules in that application will be
           included. This implies that both modules that exist in the ebin directory of the application, as well
           as modules that are named in the app file will be included. If the parameter is  set  to  ebin,  both
           modules  in the ebin directory and derived modules are included. If the parameter is set to app, both
           modules in the app file and derived modules are included. derived means that only  modules  that  are
           used  by other included modules are included. The mod_cond setting on system level is used as default
           for all applications.

         incl_cond:
           This parameter controls the application and escript inclusion policy. It defaults  to  derived  which
           means that the applications that do not have any explicit incl_cond setting, will only be included if
           any other (explicitly or implicitly included) application uses it. The value include implies that all
           applications  and  escripts that do not have any explicit incl_cond setting will be included. exclude
           implies that all applications and escripts that do not have any explicit incl_cond  setting  will  be
           excluded.

         boot_rel:
           A  target system may have several releases but the one given as boot_rel will be used as default when
           the system is booting up.

         rel:
           Release specific configuration. Each release maps to a rel, script and  boot  file.  See  the  module
           systools  for  more  info  about  the  details.  Each  release  has  a  name,  a version and a set of
           applications with a few release specific parameters such as type and included applications.

         relocatable:
           This parameter controls whether  the  erl  executable  in  the  target  system  should  automatically
           determine  where  it  is  installed  or if it should use a hardcoded path to the installation. In the
           latter case the target system must be installed with reltool:install/2 before it can be used. If  the
           system  is  relocatable,  the file tree containing the target system can be moved to another location
           without re-installation. The default is true.

         profile:
           The creation of the specification for a target system is performed in two steps. In the first step  a
           complete  specification  is generated. It will likely contain much more files than you are interested
           in in your customized target system. In the second step the specification will be filtered  according
           to your filters. There you have the ability to specify filters per application as well as system wide
           filters.  You  can also select a profile for your system. Depending on the profile, different default
           filters will be used. There are three different profiles to choose from:  development,  embedded  and
           standalone.   development  is  default.  The  parameters  that  are  affected  by  the  profile  are:
           incl_sys_filters, excl_sys_filters, incl_app_filters and excl_app_filters.

         app_file:
           This parameter controls the default handling of the app files when a target system is  generated.  It
           defaults  to  keep  which means that app files are copied to the target system and their contents are
           kept as they are. strip means that a new app file is generated from the contents of the original  app
           file  where  the  non  included modules are removed from the file. all does also imply that a new app
           file is generated from the contents of the original app file, with the difference that  all  included
           modules  are  added to the file. If the application does not have any app file a file will be created
           for all but not for keep and strip.

         debug_info:
           The debug_info parameter controls whether the debug information in  the  beam  file  should  be  kept
           (keep) or stripped strip when the file is copied to the target system.

         excl_lib:

     Warning:
         This option is experimental.

           If  the  excl_lib  option  is set to otp_root then reltool will not copy anything from the Erlang/OTP
           installation ($OTP_ROOT) into the target structure. The goal is to create a "slim" release which  can
           be  used  together with an existing Erlang/OTP installation. The target structure will therefore only
           contain a lib directory with the applications that were found outside of  $OTP_ROOT  (typically  your
           own applications), and a releases directory with the generated .rel, .script and .boot files.

           When starting this release, three things must be specified:

           Which releases directory to use:
             Tell  the  release  handler  to  use  the  releases  directory  in  our target structure instead of
             $OTP_ROOT/releases. This is done by setting the SASL environment variable releases_dir, either from
             the command line (-sasl releases_dir <target-dir>/releases) or in sys.config.

           Which boot file to use:
             The default boot file is $OTP_ROOT/bin/start, but in this case we need to specify a boot file  from
             our  target structure, typically <target-dir>/releases/<vsn>/<RelName>. This is done with the -boot
             command line option to erl

           The location of our applications:
             The generated .script (and .boot) file uses the environment variable $RELTOOL_EXT_LIB as prefix for
             the paths to all applications. The -boot_var option to erl can be used for specifying the value  of
             this variable, typically -boot_var RELTOOL_EXT_LIB <target-dir>/lib.

           Example:

         erl -sasl releases_dir \"mytarget/releases\" -boot mytarget/releases/1.0/myrel\
          -boot_var RELTOOL_EXT_LIB mytarget/lib

         incl_sys_filters:
           This  parameter  normally  contains  a  list  of regular expressions that controls which files in the
           system should be included. Each file in the target system must match  at  least  one  of  the  listed
           regular  expressions  in  order  to  be  included.  Further  the  files  may  not match any filter in
           excl_sys_filters in order to be included. Which application files should be  included  is  controlled
           with the parameters incl_app_filters and excl_app_filters. This parameter defaults to [".*"].

         excl_sys_filters:
           This  parameter  normally  contains  a  list  of regular expressions that controls which files in the
           system should not be included in the target system. In order to be included, a file must  match  some
           filter in incl_sys_filters but not any filter in excl_sys_filters. This parameter defaults to [].

         incl_app_filters:
           This  parameter  normally  contains  a  list  of  regular expressions that controls which application
           specific files that should be included. Each file in the application must match at least one  of  the
           listed  regular  expressions  in  order to be included. Further the files may not match any filter in
           excl_app_filters in order to be included. This parameter defaults to [".*"].

         excl_app_filters:
           This parameter normally contains a list  of  regular  expressions  that  controls  which  application
           specific  files  should  not  be  included in the target system. In order to be included, a file must
           match some filter in incl_app_filters but not any filter in excl_app_filters. This parameter defaults
           to [].

         incl_archive_filters:
           This parameter normally contains a  list  of  regular  expressions  that  controls  which  top  level
           directories  in an application should be included in an archive file (as opposed to being included as
           a regular directory outside the archive). Each top directory in the application must match  at  least
           one  of  the  listed regular expressions in order to be included. Further the files may not match any
           filter in excl_app_filters in order to be included. This parameter defaults to [".*"].

         excl_archive_filters:
           This parameter normally contains a  list  of  regular  expressions  that  controls  which  top  level
           directories  in  an application should not be included in an archive file. In order to be included in
           the application archive, a top directory must match some filter in incl_archive_filters but  not  any
           filter in excl_archive_filters. This parameter defaults to ["^include$","^priv$"].

         archive_opts:
           This  parameter  contains  a list of options that are given to zip:create/3 when application specific
           files are packaged into an archive. Only a subset of the  options  are  supported.  The  most  useful
           options  in  this  context  are the ones that control which types of files should be compressed. This
           parameter defaults to [].

       On application (escript) level, the following options are supported:

         incl_cond:
           The value of this parameter overrides the parameter with the same name on system level.

       On application (app) level, the following options are supported:

         vsn:
           The version of the application. In an installed  system  there  may  exist  several  versions  of  an
           application. The vsn parameter controls which version of the application will be chosen.

           This  parameter  is  mutual  exclusive  with lib_dir. If vsn and lib_dir are both omitted, the latest
           version will be chosen.

           Note that in order for reltool to sort application versions and thereby be able to select the latest,
           it is required that the version id for the application  consists  of  integers  and  dots  only,  for
           example 1, 2.0 or 3.17.1.

         lib_dir:
           The  directory  to  read  the  application  from.  This parameter can be used to point out a specific
           location to fetch the application from. This is useful for instance if the parent directory for  some
           reason is no good as a library directory on system level.

           This  parameter is mutual exclusive with vsn. If vsn and lib_dir are both omitted, the latest version
           will be chosen.

           Note that in order for reltool to sort application versions and thereby be able to select the latest,
           it is required that the version id for the application  consists  of  integers  and  dots  only,  for
           example 1, 2.0 or 3.17.1.

         mod:
           Module  specific  configuration.  A  module  has  a  mandatory name and module level options that are
           described below.

         mod_cond:
           The value of this parameter overrides the parameter with the same name on system level.

         incl_cond:
           The value of this parameter overrides the parameter with the same name on system level.

         app_file:
           The value of this parameter overrides the parameter with the same name on system level.

         debug_info:
           The value of this parameter overrides the parameter with the same name on system level.

         incl_app_filters:
           The value of this parameter overrides the parameter with the same name on system level.

         excl_app_filters:
           The value of this parameter overrides the parameter with the same name on system level.

         incl_archive_filters:
           The value of this parameter overrides the parameter with the same name on system level.

         excl_archive_filters:
           The value of this parameter overrides the parameter with the same name on system level.

         archive_opts:
           The value of this parameter overrides the parameter with the same name on system level.

       On module (mod) level, the following options are supported:

         incl_cond:
           This parameter controls whether the module is included or not. By default the mod_cond  parameter  on
           application and system level will be used to control whether the module is included or not. The value
           of  incl_cond  overrides  the  module  inclusion policy. include implies that the module is included,
           while exclude implies that the module is not included. derived implies that the module is included if
           it is used by any other included module.

         debug_info:
           The value of this parameter overrides the parameter with the same name on application level.

DATA TYPES

       options()           = [option()]
       option()            = {config, config() | file()}
                           | {trap_exit, bool()}
                           | {wx_debug, term()}
       config()            = {sys, [sys()]}
       sys()               = {root_dir, root_dir()}
                           | {lib_dirs, [lib_dir()]}
                           | {profile, profile()}
                           | {erts, app()}
                           | {escript, escript_file(), [escript()]}
                           | {app, app_name(), [app()]}
                           | {mod_cond, mod_cond()}
                           | {incl_cond, incl_cond()}
                           | {boot_rel, boot_rel()}
                           | {rel, rel_name(), rel_vsn(), [rel_app()]}
                           | {rel, rel_name(), rel_vsn(), [rel_app()], [rel_opt()]}
                           | {relocatable, relocatable()}
                           | {app_file, app_file()}
                           | {debug_info, debug_info()}
                           | {incl_sys_filters, incl_sys_filters()}
                           | {excl_sys_filters, excl_sys_filters()}
                           | {incl_app_filters, incl_app_filters()}
                           | {excl_app_filters, excl_app_filters()}
                           | {incl_archive_filters, incl_archive_filters()}
                           | {excl_archive_filters, excl_archive_filters()}
                           | {archive_opts, [archive_opt()]}
       app()               = {vsn, app_vsn()}
                           | {lib_dir, lib_dir()}
                           | {mod, mod_name(), [mod()]}
                           | {mod_cond, mod_cond()}
                           | {incl_cond, incl_cond()}
                           | {debug_info, debug_info()}
                           | {app_file, app_file()}
                     | {excl_lib, excl_lib()}
                           | {incl_sys_filters, incl_sys_filters()}
                           | {excl_sys_filters, excl_sys_filters()}
                           | {incl_app_filters, incl_app_filters()}
                           | {excl_app_filters, excl_app_filters()}
                           | {incl_archive_filters, incl_archive_filters()}
                           | {excl_archive_filters, excl_archive_filters()}
                           | {archive_opts, [archive_opt()]}
       mod()               = {incl_cond, incl_cond()}
                           | {debug_info, debug_info()}
       rel_app()           = app_name()
                           | {app_name(), app_type()}
                           | {app_name(), [incl_app()]}
                           | {app_name(), app_type(), [incl_app()]}
       rel_opt()           = {load_dot_erlang, boolean()}
       app_name()          = atom()
       app_type()          = permanent | transient | temporary | load | none
       app_vsn()           = string()
       archive_opt         = zip_create_opt()
       boot_rel()          = rel_name()
       app_file()          = keep | strip | all
       debug_info()        = keep | strip
       dir()               = string()
       escript()           = {incl_cond, incl_cond()}
       escript_file()      = file()
       excl_app_filters()  = regexps()
       excl_archive_filters() = regexps()
       excl_lib()          = otp_root
       excl_sys_filters()  = regexps()
       file()              = string()
       incl_app()          = app_name()
       incl_app_filters()  = regexps()
       incl_archive_filters() = regexps()
       incl_cond()         = include | exclude | derived
       incl_sys_filters()  = regexps()
       lib_dir()           = dir()
       mod_cond()          = all | app | ebin | derived | none
       mod_name()          = atom()
       profile()           = development | embedded | standalone
       re_regexp()         = string()
       reason()            = string()
       regexps()           = [re_regexp()]
                           | {add, [re_regexp()]}
                           | {del, [re_regexp()]}
       rel_file()          = term()
       rel_name()          = string()
       rel_vsn()           = string()
       relocatable         = boolean()
       root_dir()          = dir()
       script_file()       = term()
       server()            = server_pid() | options()
       server_pid()        = pid()
       target_dir()        = file()
       window_pid()        = pid()
       base_dir()          = dir()
       base_file()         = file()
       top_dir()           = file()
       top_file()          = file()
       target_spec()       = [target_spec()]
                           | {create_dir, base_dir(), [target_spec()]}
                           | {create_dir, base_dir(), top_dir(), [target_spec()]}
                           | {archive, base_file(), [archive_opt()], [target_spec()]}
                           | {copy_file, base_file()}
                           | {copy_file, base_file(), top_file()}
                           | {write_file, base_file(), iolist()}
                           | {strip_beam_file, base_file()}

EXPORTS

       create_target(Server, TargetDir) -> ok | {error, Reason}

              Types:

                 Server = server()
                 TargetDir = target_dir()
                 Reason = reason()

              Create a target system. Gives the same result  as  {ok,TargetSpec}=reltool:get_target_spec(Server)
              and reltool:eval_target_spec(TargetSpec,RootDir,TargetDir).

       eval_target_spec(TargetSpec, RootDir, TargetDir) -> ok | {error, Reason}

              Types:

                 TargetSpec = target_spec()
                 RootDir = root_dir()
                 TargetDir = target_dir()
                 Reason = reason()

              Create  the  actual target system from a specification generated by reltool:get_target_spec/1. The
              creation of the specification for a target system is performed in two steps. In the first  step  a
              complete  specification  will  be  generated.  It will likely contain much more files than you are
              interested in in your target system. In  the  second  step  the  specification  will  be  filtered
              according  to  your filters. There you have the ability to specify filters per application as well
              as system wide filters. You can also select a profile for your system. Depending on  the  profile,
              different default filters will be used.

              The  top  directories  bin,  releases  and lib are treated differently from other files. All other
              files are by default copied to the target system. The releases directory contains  generated  rel,
              script,  and  boot  files.  The  lib  directory  contains the applications. Which applications are
              included and if they should be customized (archived, stripped from debug info etc.)  is  specified
              with  various  configuration  parameters. The files in the bin directory are copied from the erts-
              vsn/bin directory, but only those files that were originally included in the bin directory of  the
              source system.

              If  the configuration parameter relocatable was set to true there is no need to install the target
              system with reltool:install/2 before it can be started. In that case the file tree containing  the
              target system can be moved without re-installation.

              In  most  cases,  the  RootDir  parameter  should be set to the same as the root_dir configuration
              parameter used in the call to reltool:get_target_spec/1 (or code:root_dir() if  the  configuration
              parameter  is not set). In some cases it might be useful to evaluate the same target specification
              towards different root directories. This should, however, be used with great care as  it  requires
              equivalent file structures under all roots.

       get_config(Server) -> {ok, Config} | {error, Reason}

              Types:

                 Server = server()
                 Config = config()
                 Reason = reason()

              Get reltool configuration. Shorthand for reltool:get_config(Server,false,false).

       get_config(Server, InclDefaults, InclDerived) -> {ok, Config} | {error, Reason}

              Types:

                 Server = server()
                 InclDefaults = incl_defaults()
                 InclDerived = incl_derived()
                 Config = config()
                 Reason = reason()

              Get  reltool  configuration. Normally, only the explicit configuration parameters with values that
              differ from their defaults are interesting. But the builtin default  values  can  be  returned  by
              setting  InclDefaults to true. The derived configuration can be returned by setting InclDerived to
              true.

       get_rel(Server, Relname) -> {ok, RelFile} | {error, Reason}

              Types:

                 Server = server()
                 RelName = rel_name()
                 RelFile = rel_file()
                 Reason = reason()

              Get contents of a release file. See rel(5) for more details.

       get_script(Server, Relname) -> {ok, ScriptFile | {error, Reason}

              Types:

                 Server = server()
                 RelName = rel_name()
                 ScriptFile = script_file()
                 Reason = reason()

              Get contents of a boot script file. See script(5) for more details.

       get_status(Server) -> {ok, [Warning]} | {error, Reason}

              Types:

                 Server = server()
                 Warning = string()
                 Reason = reason()

              Get status about the configuration

       get_server(WindowPid) -> {ok, ServerPid} | {error, Reason}

              Types:

                 WindowPid = window_pid()
                 ServerPid = server_pid()
                 Reason = reason()

              Return the process identifier of the server process.

       get_target_spec(Server) -> {ok, TargetSpec} | {error, Reason}

              Types:

                 Server = server()
                 TargetSpec = target_spec()
                 Reason = reason()

              Return a specification of the target  system.  The  actual  target  system  can  be  created  with
              reltool:eval_target_spec/3.

       install(RelName, TargetDir) -> ok | {error, Reason}

              Types:

                 RelName = rel_name()
                 TargetDir = target_dir()
                 Reason = reason()

              Install a created target system

       start() -> {ok, WindowPid} | {error, Reason}

              Types:

                 WindowPid = window_pid()
                 Reason = reason()

              Start a main window process with default options

       start(Options) -> {ok, WindowPid} | {error, Reason}

              Types:

                 Options = options()
                 WindowPid = window_pid()
                 Reason = reason()

              Start a main window process with options

       start_link(Options) -> {ok, WindowPid} | {error, Reason}

              Types:

                 Options = options()
                 WindowPid = window_pid()
                 Reason = reason()

              Start a main window process with options. The process is linked.

       start_server(Options) -> {ok, ServerPid} | {error, Reason}

              Types:

                 Options = options()
                 ServerPid = server_pid()
                 Reason = reason()

              Start  a  server  process with options. The server process identity can be given as an argument to
              several other functions in the API.

       stop(Pid) -> ok | {error, Reason}

              Types:

                 Pid = server_pid() | window_pid()
                 Reason = reason()

              Stop a server or window process

Ericsson AB                                       reltool 0.9.1                                    reltool(3erl)