File: app.md

package info (click to toggle)
erlang 1%3A27.3.4.1%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 225,000 kB
  • sloc: erlang: 1,658,966; ansic: 405,769; cpp: 177,850; xml: 82,435; makefile: 15,031; sh: 14,401; lisp: 9,812; java: 8,603; asm: 6,541; perl: 5,836; python: 5,484; sed: 72
file content (194 lines) | stat: -rw-r--r-- 7,645 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
<!--
%CopyrightBegin%

Copyright Ericsson AB 2023-2024. All Rights Reserved.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

%CopyrightEnd%
-->
# app

Application resource file.

## Description

The _application resource file_ specifies the resources an application uses, and
how the application is started. There must always be one application resource
file called `Application.app` for each application `Application` in the system.

The file is read by the application controller when an application is
loaded/started. It is also used by the functions in `systools`, for example when
generating start scripts.

## File Syntax

The application resource file is to be called `Application.app`, where
`Application` is the application name. The file is to be located in directory
`ebin` for the application.

The file must contain a single Erlang term, which is called an _application
specification_:

```erlang
{application, Application,
  [{description,  Description},
   {id,           Id},
   {vsn,          Vsn},
   {modules,      Modules},
   {maxP,         MaxP},
   {maxT,         MaxT},
   {registered,   Names},
   {included_applications, Apps},
   {optional_applications, Apps},
   {applications, Apps},
   {env,          Env},
   {mod,          Start},
   {start_phases, Phases},
   {runtime_dependencies, RTDeps}]}.

             Value                Default
             -----                -------
Application  atom()               -
Description  string()             ""
Id           string()             ""
Vsn          string()             ""
Modules      [Module]             []
MaxP         int()                infinity
MaxT         int()                infinity
Names        [Name]               []
Apps         [App]                []
Env          [{Par,Val}]          []
Start        {Module,StartArgs}   []
Phases       [{Phase,PhaseArgs}]  undefined
RTDeps       [ApplicationVersion] []

Module = Name = App = Par = Phase = atom()
Val = StartArgs = PhaseArgs = term()
ApplicationVersion = string()
```

- **`Application`** - Application name.

For the application controller, all keys are optional. The respective default
values are used for any omitted keys.

The functions in `systools` require more information. If they are used, the
following keys are mandatory:

- `description`
- `vsn`
- `modules`
- `registered`
- `applications`

The other keys are ignored by `systools`.

- **`description`** - A one-line description of the application.

- **`id`** - Product identification, or similar.

- **`vsn`** - Version of the application.

- **`modules`** - All modules introduced by this application. `systools` uses
  this list when generating start scripts and tar files. A module can only be
  defined in one application.

- **`maxP`** - _Deprecated - is ignored_

  Maximum number of processes allowed in the application.

- **`maxT`** - Maximum time, in milliseconds, that the application is allowed to
  run. After the specified time, the application terminates automatically.

- **`registered`** - All names of registered processes started in this
  application. `systools` uses this list to detect name clashes between
  different applications.

- **`included_applications`** - All applications included by this application.
  When this application is started, all included applications are loaded
  automatically, but not started, by the application controller. It is assumed
  that the top-most supervisor of the included application is started by a
  supervisor of this application.

- **`applications`** - All applications that must be started before this
  application. If an application is also listed in `optional_applications`, then
  the application is not required to exist (but if it exists, it is also
  guaranteed to be started before this one).

  `systools` uses this list to generate correct start scripts. Defaults to the
  empty list, but notice that all applications have dependencies to (at least)
  Kernel and STDLIB.

- **`optional_applications`** - A list of `applications` that are optional. Note
  if you want an optional dependency to be automatically started before the
  current application whenever it is available, it must be listed on both
  `applications` and `optional_applications`.

- **`env`** - Configuration parameters used by the application. The value of a
  configuration parameter is retrieved by calling `application:get_env/1,2`. The
  values in the application resource file can be overridden by values in a
  configuration file (see [`config(4)`](config.md)) or by command-line flags
  (see [`erts:erl(1)`](`e:erts:erl_cmd.md`)).

- **`mod`** - Specifies the application callback module and a start argument,
  see `m:application`.

  Key `mod` is necessary for an application implemented as a supervision tree,
  otherwise the application controller does not know how to start it. `mod` can
  be omitted for applications without processes, typically code libraries, for
  example, STDLIB.

- **`start_phases`** - A list of start phases and corresponding start arguments
  for the application. If this key is present, the application master, in
  addition to the usual call to `Module:start/2`, also calls
  `Module:start_phase(Phase,Type,PhaseArgs)` for each start phase defined by key
  `start_phases`. Only after this extended start procedure,
  `application:start(Application)` returns.

  Start phases can be used to synchronize startup of an application and its
  included applications. In this case, key `mod` must be specified as follows:

  ```erlang
  {mod, {application_starter,[Module,StartArgs]}}
  ```

  The application master then calls `Module:start/2` for the primary
  application, followed by calls to `Module:start_phase/3` for each start phase
  (as defined for the primary application), both for the primary application and
  for each of its included applications, for which the start phase is defined.

  This implies that for an included application, the set of start phases must be
  a subset of the set of phases defined for the primary application. For more
  information, see [OTP Design Principles](`e:system:applications.md`).

- **`runtime_dependencies`{: #runtime_dependencies }** - A list of application
  versions that the application depends on. An example of such an application
  version is `"kernel-3.0"`. Application versions specified as runtime
  dependencies are minimum requirements. That is, a larger application version
  than the one specified in the dependency satisfies the requirement. For
  information about how to compare application versions, see section
  [Versions](`e:system:versions.md`) in the System Principles User's Guide.

  Notice that the application version specifies a source code version. One more,
  indirect, requirement is that the installed binary application of the
  specified version is built so that it is compatible with the rest of the
  system.

  Some dependencies can only be required in specific runtime scenarios. When
  such optional dependencies exist, these are specified and documented in the
  corresponding "App" documentation of the specific application.

## See Also

`m:application`, `m:systools`