-
Notifications
You must be signed in to change notification settings - Fork 43
/
Copy pathdocumentation.py
254 lines (220 loc) · 10.6 KB
/
documentation.py
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
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
import docutils.parsers.rst.roles
from langkit.documentation import PassthroughNode
# Passthrough some roles that we want to be handled during doc generation
docutils.parsers.rst.roles.register_local_role(
"rmlink", PassthroughNode.role_fn
)
docutils.parsers.rst.roles.register_local_role(
"gnat_rm", PassthroughNode.role_fn
)
libadalang_docs = {
'libadalang.gpr_project': """
Loaded GPR project file.
""",
'libadalang.gpr_scenario_variable': """
Couple name/value to define a scenario variable for a project.
""",
'libadalang.string_array': """
List of strings.
""",
'libadalang.free_string_array': """
Free the given list of strings.
""",
'libadalang.gpr_project_load': """
Load the ``Project_File`` GPR file with the given scenario variables,
target, runtime and GPR configuration file (all optional).
If ``Ada_Only`` is true, call ``Restrict_Autoconf_To_Languages`` to
make GPR only consider the Ada language.
On success, set ``Project`` to a newly allocated ``ada_gpr_project``,
as well as a possibly empty list of error messages in ``Errors``.
Raise an ``Invalid_Project`` exception on failure.
""",
'libadalang.gpr_project_load_implicit': """
Load an implicit project in the current directory. This function uses
``GNATCOLL.Projects.Load_Implicit_Project`` to load the
``_default.gpr`` project file.
""",
'libadalang.gpr_project_free': """
Free resources allocated for ``Self``.
""",
'libadalang.gpr_project_create_unit_provider': """
Create a project provider using the given GPR project ``Self``.
If ``Project`` is passed, it must be the name of a sub-project. If the
selected project contains conflicting sources, raise an
``Project_Error`` exception.
The returned unit provider assumes that resources allocated by ``Self``
are kept live: it is the responsibility of the caller to make ``Self``
live at least as long as the returned unit provider.
""",
'libadalang.gpr_project_source_files': """
Compute the list of source files in the given GPR project according to
``Mode`` (whose value maps to positions in the
``Libadalang.Project_Provider.Source_Files_Mode`` enum) and return it.
""",
'libadalang.gpr_project_default_charset': """
Try to detect the default charset to use for the given project.
Restrict the detection to the subproject ``Project``, or to ``Self``'s
root project if left to ``Prj.No_Project``.
Note that, as of today, this detection only looks for the ``-gnatW8``
compiler switch: other charsets are not supported.
""",
'libadalang.gpr_project_initialize_context': """
Wrapper around ``Initialize_Context_From_Project`` to initialize
``Context`` (an already allocated but not yet initialized analysis
context) from ``Self``.
""",
'libadalang.gpr_project_create_context': """
Create a new analysis context from a GPR project.
The unit provider, file reader, config pragmas and default charset are
inferred from the designated project: see the
% if lang == "python":
``create_unit_provider``
% elif lang == "java":
``getProvider``
% endif
method for the semantics of the ``project`` argument.
See
% if lang == "python":
``AnalysisContext.__init__``
% elif lang == "java":
the ``AnalysisContext`` class constructor
% endif
for the semantics of the other arguments.
% if lang == "java":
.. TODO: For now, the returned ``AnalysisContext`` instance has a weak
reference to the project manager: make sure the ``ProjectManager``
instance lives at least as long as the ``AnalysisContext`` one.
% endif
""",
'libadalang.create_project_unit_provider': """
Load the project file at ``Project_File`` and return a unit provider
that uses it.
If ``Project`` is passed, use it to provide units, otherwise, try use
the whole project tree.
As unit providers must guarantee that there exists at most one source
file for each couple (unit name, unit kind), aggregate projects that
contains several conflicting units are not supported: trying to load
one will yield an error (see below).
% if lang == 'python':
If provided, ``Scenario_Vars`` must be a dict with key strings and
key values to describe the set of scenario variables for this
project.
In order to load the given project with non-default target and
runtimes, pass these as strings to the ``target`` and ``runtime``
arguments.
% else:
If not ``${null}``, ``Scenario_Vars`` must point to an array of
``${capi.get_name('project_scenario_variable')}`` couples to
provide scenario variables for this project. The last element of
this array must end with a ``{ ${null}, ${null} }`` couple.
If not ``${null}``, ``target`` and ``runtime`` must point to valid
NULL-terminated strings.
% endif
% if lang == 'c':
When done with it, the result must be free'd with
``${capi.get_name('destroy_unit_provider')}``.
% endif
If the requested project is invalid (error while opening the file,
error while analysing its syntax, ...), or if it is an unsupported
aggregate project,
% if lang == 'python':
this raises an ``InvalidProjectError`` exception.
% else:
this returns ``${null}``.
% endif
""",
'libadalang.create_preprocessor_from_file': """
Load the preprocessor data file at
%if lang == 'c':
``Filename`` using, directory names in the
``Path_Data``/``Path_Length`` array
% else:
``filename``, using directory names in ``path``
% endif
to look for for it and the definition files it references.
% if lang == 'c':
If ``Line_Mode`` is not null,
% else:
If ``line_mode`` is passed,
% endif
use it to force the line mode for source files on which the
preprocessor is enabled. Forcing the line mode is often needed as the
default is to remove lines that contain preprocessor directives and
disabled code, which breaks the line number correspondence between
original source code and preprocessed one. Forcing to ``blank_lines``
or ``comment_lines`` preserves this correspondence.
Return a file reader that preprocesses sources accordingly.
""",
'libadalang.gpr_project_create_preprocessor': """
Create preprocessor data from compiler arguments found in the given GPR
project ``Self`` (``-gnatep`` and ``-gnateD`` compiler switches), or
from the ``Project`` sub-project (if the argument is passed).
If ``Line_Mode`` is not null, use it to force the line mode in each
preprocessed source file.
Note that this function collects all arguments and returns an
approximation from them: it does not replicates exactly gprbuild's
behavior. This may raise a ``File_Read_Error`` exception if this fails
to read a preprocessor data file and a ``Syntax_Error`` exception if
one such file has invalid syntax.
The returned file reader assumes that resources allocated by ``Self``
are kept live: it is the responsibility of the caller to make ``Self``
live at least as long as the returned file reader.
""",
'libadalang.set_config_pragmas_mapping': """
Assign in ``Context`` configuration pragmas files to analysis units as
described in ``Global_Pragmas`` (configuration pragmas file that
applies to all analysis units, or null) and ``Local_Pragmas`` (mapping
that associates an analysis unit to the local configuration pragmas
file that applies to it).
% if lang == "c":
The ``Local_Pragmas`` mapping is encoded as a NULL-trailing analysis
unit array that describes a unit-to-unit mapping: for N associations,
``Local_Pragmas[2 * (N - 1)]`` is they key and
``Local_Pragmas[2 * (N - 1) + 1]`` is the value.
% endif
This raises a ``Precondition_Failure`` exception if any analysis unit
in ``Mapping`` does not belong to ``Context`` or if an analysis unit
appears twice as a key in ``Mapping``.
""",
'libadalang.target_info_type': """
Built in types characteristics for a given target platform.
""",
'libadalang.target_info_load': """
Read target information from ``filename`` and return it. Raise an
``Langkit_Support.Errors.Invalid_Input`` exception if it cannot be read
of if there is any trouble decoding it.
""",
'libadalang.target_info_free': """
Free resources allocated for ``self``.
""",
'libadalang.target_info_set': """
Assign target information to ``self``. This will affect specific bound
values for types defined in the built in Standard package.
""",
'libadalang.project_provider.project_error': """
Raised when an error occurs while loading a project file.
""",
'libadalang.project_provider.unsupported_view_error': """
Raised when creating a project unit provider for an unsupported project
view (for instance, a view with conflicting aggregated projects).
""",
'libadalang.create_auto_provider': """
Return a unit provider that knows which compilation units are to be
found in the given list of source files.
This knowledge is built trying to parse all given input files as Ada
source files and listing the compilation units found there. Files that
cannot be parsed properly are discarded. If two compilation units are
found for the same unit, the first that is found in the given input
files is taken and the other ones are discarded.
Source files are decoded using the given charset. If it is ``${null}``,
the default charset (ISO-8859-1) is used.
% if lang == 'c':
``input_files`` must point to a ``NULL``-terminated array of
filenames. Once this function returns, this array and the strings
it contains can be deallocated.
When done with it, the result must be free'd with
``${capi.get_name('destroy_unit_provider')}``.
% endif
.. TODO: Find a way to report discarded source files/compilation units.
""",
}