1reltool(3) Erlang Module Definition reltool(3)
2
3
4
6 reltool - Main API of the Reltool application
7
9 This is an interface module for the Reltool application.
10
11 Reltool is a release management tool. It analyses a given Erlang/OTP
12 installation and determines various dependencies between applications.
13 The graphical frontend depicts the dependencies and enables interactive
14 customization of a target system. The backend provides a batch inter‐
15 face for generation of customized target systems.
16
17 The tool uses an installed Erlang/OTP system as input. root_dir is the
18 root directory of the analysed system and it defaults to the system ex‐
19 ecuting Reltool. Applications may also be located outside root_dir.
20 lib_dirs defines library directories where additional applications may
21 reside and it defaults to the directories listed by the operating sys‐
22 tem environment variable ERL_LIBS. See the module code for more info.
23
24 An application directory AppDir under a library directory is recognized
25 by the existence of an AppDir/ebin directory. If this does not exist,
26 Reltool will not consider AppDir at all when looking for applications.
27
28 It is recommended that application directories are named as the appli‐
29 cation, possibly followed by a dash and the version number. For example
30 myapp or myapp-1.1.
31
32 Finally single modules and entire applications may be read from Es‐
33 cripts.
34
35 Some configuration parameters control the behavior of Reltool on system
36 (sys) level. Others provide control on application (app) level and yet
37 others are on module (mod) level. Module level parameters override ap‐
38 plication level parameters and application level parameters override
39 system level parameters. Escript escript level parameters override sys‐
40 tem level parameters.
41
42 The following top level options are supported:
43
44 config:
45 This is the main option and it controls the configuration of Rel‐
46 tool. It can either be a sys tuple or a name of a file containing a
47 sys tuple.
48
49 trap_exit:
50 This option controls the error handling behavior of Reltool. By de‐
51 fault the window processes traps exit, but this behavior can al‐
52 tered by setting trap_exit to false.
53
54 wx_debug:
55 This option controls the debug level of wx. As its name indicates
56 it is only useful for debugging. See wx:debug/1 for more info.
57
58 Besides the already mentioned source parameters root_dir and lib_dirs,
59 the following system (sys) level options are supported:
60
61 erts:
62 Erts specific configuration. See application level options below.
63
64 escript:
65 Escript specific configuration. An escript has a mandatory file
66 name and escript level options that are described below.
67
68 app:
69 Application specific configuration. An application has a mandatory
70 name and application level options that are described below.
71
72 mod_cond:
73 This parameter controls the module inclusion policy. It defaults to
74 all which means that if an application is included (either explic‐
75 itly or implicitly) all modules in that application will be in‐
76 cluded. This implies that both modules that exist in the ebin di‐
77 rectory of the application, as well as modules that are named in
78 the app file will be included. If the parameter is set to ebin,
79 both modules in the ebin directory and derived modules are in‐
80 cluded. If the parameter is set to app, both modules in the app
81 file and derived modules are included. derived means that only mod‐
82 ules that are used by other included modules are included. The
83 mod_cond setting on system level is used as default for all appli‐
84 cations.
85
86 incl_cond:
87 This parameter controls the application and escript inclusion pol‐
88 icy. It defaults to derived which means that the applications that
89 do not have any explicit incl_cond setting, will only be included
90 if any other (explicitly or implicitly included) application uses
91 it. The value include implies that all applications and escripts
92 that do not have any explicit incl_cond setting will be included.
93 exclude implies that all applications and escripts that do not have
94 any explicit incl_cond setting will be excluded.
95
96 boot_rel:
97 A target system may have several releases but the one given as
98 boot_rel will be used as default when the system is booting up.
99
100 rel:
101 Release specific configuration. Each release maps to a rel, script
102 and boot file. See the module systools for more info about the de‐
103 tails. Each release has a name, a version and a set of applications
104 with a few release specific parameters such as type and included
105 applications.
106
107 relocatable:
108 This parameter controls whether the erl executable in the target
109 system should automatically determine where it is installed or if
110 it should use a hardcoded path to the installation. In the latter
111 case the target system must be installed with reltool:install/2 be‐
112 fore it can be used. If the system is relocatable, the file tree
113 containing the target system can be moved to another location with‐
114 out re-installation. The default is true.
115
116 profile:
117 The creation of the specification for a target system is performed
118 in two steps. In the first step a complete specification is gener‐
119 ated. It will likely contain much more files than you are inter‐
120 ested in in your customized target system. In the second step the
121 specification will be filtered according to your filters. There you
122 have the ability to specify filters per application as well as sys‐
123 tem wide filters. You can also select a profile for your system.
124 Depending on the profile, different default filters will be used.
125 There are three different profiles to choose from: development, em‐
126 bedded and standalone. development is default. The parameters that
127 are affected by the profile are: incl_sys_filters, excl_sys_fil‐
128 ters, incl_app_filters and excl_app_filters.
129
130 app_file:
131 This parameter controls the default handling of the app files when
132 a target system is generated. It defaults to keep which means that
133 app files are copied to the target system and their contents are
134 kept as they are. strip means that a new app file is generated from
135 the contents of the original app file where the non included mod‐
136 ules are removed from the file. all does also imply that a new app
137 file is generated from the contents of the original app file, with
138 the difference that all included modules are added to the file. If
139 the application does not have any app file a file will be created
140 for all but not for keep and strip.
141
142 debug_info:
143 The debug_info parameter controls whether the debug information in
144 the beam file should be kept (keep) or stripped strip when the file
145 is copied to the target system.
146
147 excl_lib:
148
149
150 Warning:
151 This option is experimental.
152
153
154 If the excl_lib option is set to otp_root then reltool will not
155 copy anything from the Erlang/OTP installation ($OTP_ROOT) into the
156 target structure. The goal is to create a "slim" release which can
157 be used together with an existing Erlang/OTP installation. The tar‐
158 get structure will therefore only contain a lib directory with the
159 applications that were found outside of $OTP_ROOT (typically your
160 own applications), and a releases directory with the generated
161 .rel, .script and .boot files.
162
163 When starting this release, three things must be specified:
164
165 Which releases directory to use:
166 Tell the release handler to use the releases directory in our
167 target structure instead of $OTP_ROOT/releases. This is done by
168 setting the SASL environment variable releases_dir, either from
169 the command line (-sasl releases_dir <target-dir>/releases) or in
170 sys.config.
171
172 Which boot file to use:
173 The default boot file is $OTP_ROOT/bin/start, but in this case we
174 need to specify a boot file from our target structure, typically
175 <target-dir>/releases/<vsn>/<RelName>. This is done with the
176 -boot command line option to erl
177
178 The location of our applications:
179 The generated .script (and .boot) file uses the environment vari‐
180 able $RELTOOL_EXT_LIB as prefix for the paths to all applica‐
181 tions. The -boot_var option to erl can be used for specifying the
182 value of this variable, typically -boot_var RELTOOL_EXT_LIB <tar‐
183 get-dir>/lib.
184
185 Example:
186
187 erl -sasl releases_dir \"mytarget/releases\" -boot mytarget/releases/1.0/myrel\
188 -boot_var RELTOOL_EXT_LIB mytarget/lib
189
190 incl_sys_filters:
191 This parameter normally contains a list of regular expressions that
192 controls which files in the system should be included. Each file in
193 the target system must match at least one of the listed regular ex‐
194 pressions in order to be included. Further the files may not match
195 any filter in excl_sys_filters in order to be included. Which ap‐
196 plication files should be included is controlled with the parame‐
197 ters incl_app_filters and excl_app_filters. This parameter defaults
198 to [".*"].
199
200 excl_sys_filters:
201 This parameter normally contains a list of regular expressions that
202 controls which files in the system should not be included in the
203 target system. In order to be included, a file must match some fil‐
204 ter in incl_sys_filters but not any filter in excl_sys_filters.
205 This parameter defaults to [].
206
207 incl_app_filters:
208 This parameter normally contains a list of regular expressions that
209 controls which application specific files that should be included.
210 Each file in the application must match at least one of the listed
211 regular expressions in order to be included. Further the files may
212 not match any filter in excl_app_filters in order to be included.
213 This parameter defaults to [".*"].
214
215 excl_app_filters:
216 This parameter normally contains a list of regular expressions that
217 controls which application specific files should not be included in
218 the target system. In order to be included, a file must match some
219 filter in incl_app_filters but not any filter in excl_app_filters.
220 This parameter defaults to [].
221
222 incl_archive_filters:
223 This parameter normally contains a list of regular expressions that
224 controls which top level directories in an application should be
225 included in an archive file (as opposed to being included as a reg‐
226 ular directory outside the archive). Each top directory in the ap‐
227 plication must match at least one of the listed regular expressions
228 in order to be included. Further the files may not match any filter
229 in excl_app_filters in order to be included. This parameter de‐
230 faults to [".*"].
231
232 excl_archive_filters:
233 This parameter normally contains a list of regular expressions that
234 controls which top level directories in an application should not
235 be included in an archive file. In order to be included in the ap‐
236 plication archive, a top directory must match some filter in
237 incl_archive_filters but not any filter in excl_archive_filters.
238 This parameter defaults to ["^include$","^priv$"].
239
240 archive_opts:
241 This parameter contains a list of options that are given to
242 zip:create/3 when application specific files are packaged into an
243 archive. Only a subset of the options are supported. The most use‐
244 ful options in this context are the ones that control which types
245 of files should be compressed. This parameter defaults to [].
246
247 On application (escript) level, the following options are supported:
248
249 incl_cond:
250 The value of this parameter overrides the parameter with the same
251 name on system level.
252
253 On application (app) level, the following options are supported:
254
255 vsn:
256 The version of the application. In an installed system there may
257 exist several versions of an application. The vsn parameter con‐
258 trols which version of the application will be chosen.
259
260 This parameter is mutual exclusive with lib_dir. If vsn and lib_dir
261 are both omitted, the latest version will be chosen.
262
263 Note that in order for reltool to sort application versions and
264 thereby be able to select the latest, it is required that the ver‐
265 sion id for the application consists of integers and dots only, for
266 example 1, 2.0 or 3.17.1.
267
268 lib_dir:
269 The directory to read the application from. This parameter can be
270 used to point out a specific location to fetch the application
271 from. This is useful for instance if the parent directory for some
272 reason is no good as a library directory on system level.
273
274 This parameter is mutual exclusive with vsn. If vsn and lib_dir are
275 both omitted, the latest version will be chosen.
276
277 Note that in order for reltool to sort application versions and
278 thereby be able to select the latest, it is required that the ver‐
279 sion id for the application consists of integers and dots only, for
280 example 1, 2.0 or 3.17.1.
281
282 mod:
283 Module specific configuration. A module has a mandatory name and
284 module level options that are described below.
285
286 mod_cond:
287 The value of this parameter overrides the parameter with the same
288 name on system level.
289
290 incl_cond:
291 The value of this parameter overrides the parameter with the same
292 name on system level.
293
294 app_file:
295 The value of this parameter overrides the parameter with the same
296 name on system level.
297
298 debug_info:
299 The value of this parameter overrides the parameter with the same
300 name on system level.
301
302 incl_app_filters:
303 The value of this parameter overrides the parameter with the same
304 name on system level.
305
306 excl_app_filters:
307 The value of this parameter overrides the parameter with the same
308 name on system level.
309
310 incl_archive_filters:
311 The value of this parameter overrides the parameter with the same
312 name on system level.
313
314 excl_archive_filters:
315 The value of this parameter overrides the parameter with the same
316 name on system level.
317
318 archive_opts:
319 The value of this parameter overrides the parameter with the same
320 name on system level.
321
322 On module (mod) level, the following options are supported:
323
324 incl_cond:
325 This parameter controls whether the module is included or not. By
326 default the mod_cond parameter on application and system level will
327 be used to control whether the module is included or not. The value
328 of incl_cond overrides the module inclusion policy. include implies
329 that the module is included, while exclude implies that the module
330 is not included. derived implies that the module is included if it
331 is used by any other included module.
332
333 debug_info:
334 The value of this parameter overrides the parameter with the same
335 name on application level.
336
338 options() = [option()]
339 option() = {config, config() | file()}
340 | {trap_exit, bool()}
341 | {wx_debug, term()}
342 config() = {sys, [sys()]}
343 sys() = {root_dir, root_dir()}
344 | {lib_dirs, [lib_dir()]}
345 | {profile, profile()}
346 | {erts, app()}
347 | {escript, escript_file(), [escript()]}
348 | {app, app_name(), [app()]}
349 | {mod_cond, mod_cond()}
350 | {incl_cond, incl_cond()}
351 | {boot_rel, boot_rel()}
352 | {rel, rel_name(), rel_vsn(), [rel_app()]}
353 | {rel, rel_name(), rel_vsn(), [rel_app()], [rel_opt()]}
354 | {relocatable, relocatable()}
355 | {app_file, app_file()}
356 | {debug_info, debug_info()}
357 | {incl_sys_filters, incl_sys_filters()}
358 | {excl_sys_filters, excl_sys_filters()}
359 | {incl_app_filters, incl_app_filters()}
360 | {excl_app_filters, excl_app_filters()}
361 | {incl_archive_filters, incl_archive_filters()}
362 | {excl_archive_filters, excl_archive_filters()}
363 | {archive_opts, [archive_opt()]}
364 app() = {vsn, app_vsn()}
365 | {lib_dir, lib_dir()}
366 | {mod, mod_name(), [mod()]}
367 | {mod_cond, mod_cond()}
368 | {incl_cond, incl_cond()}
369 | {debug_info, debug_info()}
370 | {app_file, app_file()}
371 | {excl_lib, excl_lib()}
372 | {incl_sys_filters, incl_sys_filters()}
373 | {excl_sys_filters, excl_sys_filters()}
374 | {incl_app_filters, incl_app_filters()}
375 | {excl_app_filters, excl_app_filters()}
376 | {incl_archive_filters, incl_archive_filters()}
377 | {excl_archive_filters, excl_archive_filters()}
378 | {archive_opts, [archive_opt()]}
379 mod() = {incl_cond, incl_cond()}
380 | {debug_info, debug_info()}
381 rel_app() = app_name()
382 | {app_name(), app_type()}
383 | {app_name(), [incl_app()]}
384 | {app_name(), app_type(), [incl_app()]}
385 rel_opt() = {load_dot_erlang, boolean()}
386 app_name() = atom()
387 app_type() = permanent | transient | temporary | load | none
388 app_vsn() = string()
389 archive_opt = zip_create_opt()
390 boot_rel() = rel_name()
391 app_file() = keep | strip | all
392 debug_info() = keep | strip
393 dir() = string()
394 escript() = {incl_cond, incl_cond()}
395 escript_file() = file()
396 excl_app_filters() = regexps()
397 excl_archive_filters() = regexps()
398 excl_lib() = otp_root
399 excl_sys_filters() = regexps()
400 file() = string()
401 incl_app() = app_name()
402 incl_app_filters() = regexps()
403 incl_archive_filters() = regexps()
404 incl_cond() = include | exclude | derived
405 incl_sys_filters() = regexps()
406 lib_dir() = dir()
407 mod_cond() = all | app | ebin | derived | none
408 mod_name() = atom()
409 profile() = development | embedded | standalone
410 re_regexp() = string()
411 reason() = string()
412 regexps() = [re_regexp()]
413 | {add, [re_regexp()]}
414 | {del, [re_regexp()]}
415 rel_file() = term()
416 rel_name() = string()
417 rel_vsn() = string()
418 relocatable = boolean()
419 root_dir() = dir()
420 script_file() = term()
421 server() = server_pid() | options()
422 server_pid() = pid()
423 target_dir() = file()
424 window_pid() = pid()
425 base_dir() = dir()
426 base_file() = file()
427 top_dir() = file()
428 top_file() = file()
429 target_spec() = [target_spec()]
430 | {create_dir, base_dir(), [target_spec()]}
431 | {create_dir, base_dir(), top_dir(), [target_spec()]}
432 | {archive, base_file(), [archive_opt()], [target_spec()]}
433 | {copy_file, base_file()}
434 | {copy_file, base_file(), top_file()}
435 | {write_file, base_file(), iolist()}
436 | {strip_beam_file, base_file()}
437
439 create_target(Server, TargetDir) -> ok | {error, Reason}
440
441 Types:
442
443 Server = server()
444 TargetDir = target_dir()
445 Reason = reason()
446
447 Create a target system. Gives the same result as {ok,Target‐
448 Spec}=reltool:get_target_spec(Server) and reltool:eval_tar‐
449 get_spec(TargetSpec,RootDir,TargetDir).
450
451 eval_target_spec(TargetSpec, RootDir, TargetDir) -> ok | {error, Rea‐
452 son}
453
454 Types:
455
456 TargetSpec = target_spec()
457 RootDir = root_dir()
458 TargetDir = target_dir()
459 Reason = reason()
460
461 Create the actual target system from a specification generated
462 by reltool:get_target_spec/1. The creation of the specification
463 for a target system is performed in two steps. In the first step
464 a complete specification will be generated. It will likely con‐
465 tain much more files than you are interested in in your target
466 system. In the second step the specification will be filtered
467 according to your filters. There you have the ability to specify
468 filters per application as well as system wide filters. You can
469 also select a profile for your system. Depending on the profile,
470 different default filters will be used.
471
472 The top directories bin, releases and lib are treated differ‐
473 ently from other files. All other files are by default copied to
474 the target system. The releases directory contains generated
475 rel, script, and boot files. The lib directory contains the ap‐
476 plications. Which applications are included and if they should
477 be customized (archived, stripped from debug info etc.) is spec‐
478 ified with various configuration parameters. The files in the
479 bin directory are copied from the erts-vsn/bin directory, but
480 only those files that were originally included in the bin direc‐
481 tory of the source system.
482
483 If the configuration parameter relocatable was set to true there
484 is no need to install the target system with reltool:install/2
485 before it can be started. In that case the file tree containing
486 the target system can be moved without re-installation.
487
488 In most cases, the RootDir parameter should be set to the same
489 as the root_dir configuration parameter used in the call to rel‐
490 tool:get_target_spec/1 (or code:root_dir() if the configuration
491 parameter is not set). In some cases it might be useful to eval‐
492 uate the same target specification towards different root direc‐
493 tories. This should, however, be used with great care as it re‐
494 quires equivalent file structures under all roots.
495
496 get_config(Server) -> {ok, Config} | {error, Reason}
497
498 Types:
499
500 Server = server()
501 Config = config()
502 Reason = reason()
503
504 Get reltool configuration. Shorthand for reltool:get_con‐
505 fig(Server,false,false).
506
507 get_config(Server, InclDefaults, InclDerived) -> {ok, Config} | {error,
508 Reason}
509
510 Types:
511
512 Server = server()
513 InclDefaults = incl_defaults()
514 InclDerived = incl_derived()
515 Config = config()
516 Reason = reason()
517
518 Get reltool configuration. Normally, only the explicit configu‐
519 ration parameters with values that differ from their defaults
520 are interesting. But the builtin default values can be returned
521 by setting InclDefaults to true. The derived configuration can
522 be returned by setting InclDerived to true.
523
524 get_rel(Server, Relname) -> {ok, RelFile} | {error, Reason}
525
526 Types:
527
528 Server = server()
529 RelName = rel_name()
530 RelFile = rel_file()
531 Reason = reason()
532
533 Get contents of a release file. See rel(4) for more details.
534
535 get_script(Server, Relname) -> {ok, ScriptFile | {error, Reason}
536
537 Types:
538
539 Server = server()
540 RelName = rel_name()
541 ScriptFile = script_file()
542 Reason = reason()
543
544 Get contents of a boot script file. See script(4) for more de‐
545 tails.
546
547 get_status(Server) -> {ok, [Warning]} | {error, Reason}
548
549 Types:
550
551 Server = server()
552 Warning = string()
553 Reason = reason()
554
555 Get status about the configuration
556
557 get_server(WindowPid) -> {ok, ServerPid} | {error, Reason}
558
559 Types:
560
561 WindowPid = window_pid()
562 ServerPid = server_pid()
563 Reason = reason()
564
565 Return the process identifier of the server process.
566
567 get_target_spec(Server) -> {ok, TargetSpec} | {error, Reason}
568
569 Types:
570
571 Server = server()
572 TargetSpec = target_spec()
573 Reason = reason()
574
575 Return a specification of the target system. The actual target
576 system can be created with reltool:eval_target_spec/3.
577
578 install(RelName, TargetDir) -> ok | {error, Reason}
579
580 Types:
581
582 RelName = rel_name()
583 TargetDir = target_dir()
584 Reason = reason()
585
586 Install a created target system
587
588 start() -> {ok, WindowPid} | {error, Reason}
589
590 Types:
591
592 WindowPid = window_pid()
593 Reason = reason()
594
595 Start a main window process with default options
596
597 start(Options) -> {ok, WindowPid} | {error, Reason}
598
599 Types:
600
601 Options = options()
602 WindowPid = window_pid()
603 Reason = reason()
604
605 Start a main window process with options
606
607 start_link(Options) -> {ok, WindowPid} | {error, Reason}
608
609 Types:
610
611 Options = options()
612 WindowPid = window_pid()
613 Reason = reason()
614
615 Start a main window process with options. The process is linked.
616
617 start_server(Options) -> {ok, ServerPid} | {error, Reason}
618
619 Types:
620
621 Options = options()
622 ServerPid = server_pid()
623 Reason = reason()
624
625 Start a server process with options. The server process identity
626 can be given as an argument to several other functions in the
627 API.
628
629 stop(Pid) -> ok | {error, Reason}
630
631 Types:
632
633 Pid = server_pid() | window_pid()
634 Reason = reason()
635
636 Stop a server or window process
637
638
639
640Ericsson AB reltool 0.9.1 reltool(3)