-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathGnome-module.html
749 lines (706 loc) · 29.4 KB
/
Gnome-module.html
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
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
<!DOCTYPE html>
<html lang="en">
<head>
<base href=".">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>GNOME module</title>
<link rel="stylesheet" href="assets/css/dark-frontend.css" type="text/css" title="dark">
<link rel="alternate stylesheet" href="assets/css/light-frontend.css" type="text/css" title="light">
<link rel="stylesheet" href="assets/css/bootstrap-toc.min.css" type="text/css">
<link rel="stylesheet" href="assets/css/jquery.mCustomScrollbar.min.css">
<link rel="stylesheet" href="assets/js/search/enable_search.css" type="text/css">
<link rel="stylesheet" href="assets/css/prism-tomorrow.css" type="text/css" title="dark">
<link rel="alternate stylesheet" href="assets/css/prism.css" type="text/css" title="light">
<script src="assets/js/mustache.min.js"></script>
<script src="assets/js/jquery.js"></script>
<script src="assets/js/bootstrap.js"></script>
<script src="assets/js/scrollspy.js"></script>
<script src="assets/js/typeahead.jquery.min.js"></script>
<script src="assets/js/search.js"></script>
<script src="assets/js/compare-versions.js"></script>
<script src="assets/js/jquery.mCustomScrollbar.concat.min.js"></script>
<script src="assets/js/bootstrap-toc.min.js"></script>
<script src="assets/js/jquery.touchSwipe.min.js"></script>
<script src="assets/js/anchor.min.js"></script>
<script src="assets/js/tag_filtering.js"></script>
<script src="assets/js/language_switching.js"></script>
<script src="assets/js/styleswitcher.js"></script>
<script src="assets/js/lines_around_headings.js"></script>
<script src="assets/js/prism-core.js"></script>
<script src="assets/js/prism-autoloader.js"></script>
<script src="assets/js/prism_autoloader_path_override.js"></script>
<script src="assets/js/prism-keep-markup.js"></script>
<script src="assets/js/trie.js"></script>
<link rel="icon" type="image/png" href="assets/images/favicon.png">
<link rel="shortcut icon" href="assets/images/favicon.png">
</head>
<body class="no-script
">
<script>
$('body').removeClass('no-script');
</script>
<nav class="navbar navbar-fixed-top navbar-default" id="topnav">
<div class="container-fluid">
<div class="navbar-right">
<a id="toc-toggle">
<span class="glyphicon glyphicon-menu-right"></span>
<span class="glyphicon glyphicon-menu-left"></span>
</a>
<button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar-wrapper" aria-expanded="false">
<span class="sr-only">Toggle navigation</span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</button>
<span title="light mode switch" class="glyphicon glyphicon-sunglasses pull-right" id="lightmode-icon"></span>
<form class="navbar-form pull-right" id="navbar-search-form">
<div class="form-group has-feedback">
<input type="text" class="form-control input-sm" name="search" id="sidenav-lookup-field" placeholder="search" disabled>
<span class="glyphicon glyphicon-search form-control-feedback" id="search-mgn-glass"></span>
</div>
</form>
</div>
<div class="navbar-header">
<a id="sidenav-toggle">
<span class="glyphicon glyphicon-menu-right"></span>
<span class="glyphicon glyphicon-menu-left"></span>
</a>
<a id="home-link" href="index.html" class="hotdoc-navbar-brand">
<img src="assets/images/meson_logo.png" alt="Home">
</a>
</div>
<div class="navbar-collapse collapse" id="navbar-wrapper">
<ul class="nav navbar-nav" id="menu">
<li class="dropdown">
<a class="dropdown-toggle" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
Modules <span class="caret"></span>
</a>
<ul class="dropdown-menu" id="modules-menu">
<li>
<a href="CMake-module.html">CMake</a>
</li>
<li>
<a href="Cuda-module.html">CUDA</a>
</li>
<li>
<a href="Dlang-module.html">Dlang</a>
</li>
<li>
<a href="External-Project-module.html">External Project</a>
</li>
<li>
<a href="Fs-module.html">Filesystem</a>
</li>
<li>
<a href="Gnome-module.html">GNOME</a>
</li>
<li>
<a href="Hotdoc-module.html">Hotdoc</a>
</li>
<li>
<a href="i18n-module.html">i18n</a>
</li>
<li>
<a href="Icestorm-module.html">Icestorm</a>
</li>
<li>
<a href="Java-module.html">Java</a>
</li>
<li>
<a href="Keyval-module.html">Keyval</a>
</li>
<li>
<a href="Pkgconfig-module.html">Pkgconfig</a>
</li>
<li>
<a href="Python-3-module.html">Python 3</a>
</li>
<li>
<a href="Python-module.html">Python</a>
</li>
<li>
<a href="Qt4-module.html">Qt4</a>
</li>
<li>
<a href="Qt5-module.html">Qt5</a>
</li>
<li>
<a href="Qt6-module.html">Qt6</a>
</li>
<li>
<a href="Rust-module.html">Rust</a>
</li>
<li>
<a href="Simd-module.html">Simd</a>
</li>
<li>
<a href="SourceSet-module.html">SourceSet</a>
</li>
<li>
<a href="Wayland-module.html">Wayland</a>
</li>
<li>
<a href="Windows-module.html">Windows</a>
</li>
</ul>
</li>
<li class="dropdown">
<a class="dropdown-toggle" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
Quick References <span class="caret"></span>
</a>
<ul class="dropdown-menu" id="quick-refs-menu">
<li>
<a href="Reference-manual.html">Functions</a>
</li>
<li>
<a href="Build-options.html">Options</a>
</li>
<li>
<a href="Configuration.html">Configuration</a>
</li>
<li>
<a href="Dependencies.html">Dependencies</a>
</li>
<li>
<a href="Unit-tests.html">Tests</a>
</li>
<li>
<a href="Syntax.html">Syntax</a>
</li>
</ul>
</li>
</ul>
<div class="hidden-xs hidden-sm navbar-text navbar-center">
<p><b>The Meson Build System</b></p>
</div>
</div>
</div>
</nav>
<main>
<div data-extension="core" data-hotdoc-in-toplevel="True" data-hotdoc-project="Meson-documentation" data-hotdoc-ref="Gnome-module.html" class="page_container" id="page-wrapper">
<script src="assets/js/utils.js"></script>
<div class="panel panel-collapse oc-collapsed" id="sidenav" data-hotdoc-role="navigation">
<script src="assets/js/full-width.js"></script>
<div id="sitenav-wrapper">
<iframe src="hotdoc-sitemap.html" id="sitenav-frame"></iframe>
</div>
</div>
<div id="body">
<div id="main">
<div id="page-description" data-hotdoc-role="main">
<h1 id="gnome-module">GNOME module</h1>
<p>This module provides helper tools for build operations needed when
building Gnome/GLib programs.</p>
<p><strong>Note</strong>: the compilation commands here might not work properly when
you change the source files. This is a bug in the respective
compilers which do not expose the required dependency
information. This has been reported upstream in <a href="https://bugzilla.gnome.org/show_bug.cgi?id=745754">this bug</a>. Until
this is fixed you need to be careful when changing your source
files.</p>
<h2 id="usage">Usage</h2>
<p>To use this module, just do: <strong><code>gnome = import('gnome')</code></strong>. The
following functions will then be available as methods on the object
with the name <code>gnome</code>. You can, of course, replace the name <code>gnome</code>
with anything else.</p>
<h3 id="gnomecompile_resources">gnome.compile_resources()</h3>
<pre><code> gnome.compile_resources(id: string, input_file: string | File,
build_by_default: bool = false,
c_name: string | None = None,
dependencies: [](File, CustomTarget, CustomTargetIndex) = [],
export: bool = false,
extra_args: []string = [],
gresource_bundle: bool = false,
install_dir: string | None = None,
source_dir: [string] = [],
): (CustomTarget, CustomTarget) | CustomTarget
</code></pre>
<p>This function compiles resources specified in an XML file into code
that can be embedded inside the main binary. Similar a build target it
takes two positional arguments. The first one is the name of the
resource and the second is the XML file containing the resource
definitions. If the name is <code>foobar</code>, Meson will generate a header
file called <code>foobar.h</code>, which you can then include in your sources.
The resources specified are automatically added as dependencies of the
generated target.</p>
<ul>
<li>
<code>c_name</code>: passed to the resource compiler as an argument after
<code>--c-name</code>
</li>
<li>
<code>dependencies</code>: extra targets to depend upon for building</li>
<li>
<code>export</code>: (<em>Added 0.37.0</em>) if true, export the symbols of the
generated sources</li>
<li>
<code>extra_args</code>: extra command line arguments to pass to the resource</li>
<li>
<code>gresource_bundle</code>: (<em>Added 0.37.0</em>) if true, output a <code>.gresource</code>
file instead of source</li>
<li>
<code>install</code>: (<em>Added 0.37.0</em>) if true, install the gresource file</li>
<li>
<code>install_dir</code>: (<em>Added 0.37.0</em>) location to install the header or
bundle depending on previous options</li>
<li>
<code>install_header</code>: (<em>Added 0.37.0</em>) if true, install the header file</li>
<li>
<code>source_dir</code>: a list of directories where the resource compiler
should look up the files</li>
</ul>
<p>Returns an array containing: <code>[c_source, header_file]</code> or
<code>[gresource_bundle]</code></p>
<p>Example:</p>
<pre><code class="language-meson">gnome = import('gnome')
asresources = gnome.compile_resources(
'as-resources', 'data/asresources.gresource.xml',
source_dir: 'data',
c_name: 'as'
)
executable(
meson.project_name(),
asresources,
dependencies: my_deps,
install: true
)
</code></pre>
<h3 id="gnomegenerate_gir">gnome.generate_gir()</h3>
<p>Generates GObject introspection data.</p>
<p>Takes one or more positional arguments:</p>
<p>Either one or more library objects you want to build gir data for, or a single
executable object.</p>
<p>There are several keyword arguments. Many of these map directly to the
<code>g-ir-scanner</code> tool so see its documentation for more information.</p>
<ul>
<li>
<code>dependencies</code>: deps to use during introspection scanning</li>
<li>
<code>extra_args</code>: command line arguments to pass to gir compiler</li>
<li>
<code>env</code>: (<em>Added 1.2.0</em>) environment variables to set, such as
<code>{'NAME1': 'value1', 'NAME2': 'value2'}</code> or <code>['NAME1=value1', 'NAME2=value2']</code>,
or an <a href="Reference-manual_returned_env.html"><ins><code>env</code></ins></a> object which allows more sophisticated environment juggling.</li>
<li>
<code>export_packages</code>: extra packages the gir file exports</li>
<li>
<code>sources</code>: the list of sources to be scanned for gir data</li>
<li>
<code>nsversion</code>: namespace version</li>
<li>
<code>namespace</code>: the namespace for this gir object which determines
output files</li>
<li>
<code>identifier_prefix</code>: the identifier prefix for the gir object,
e.g. <code>Gtk</code>
</li>
<li>
<code>includes</code>: list of gir names to be included, can also be a GirTarget</li>
<li>
<code>header</code>: <em>(Added 0.43.0)</em> name of main c header to include for the library, e.g. <code>glib.h</code>
</li>
<li>
<code>include_directories</code>: extra include paths to look for gir files</li>
<li>
<code>install</code>: if true, install the generated files</li>
<li>
<code>install_gir</code>: (<em>Added 0.61.0</em>) overrides <code>install</code>, whether to install the
generated gir</li>
<li>
<code>install_dir_gir</code>: (<em>Added 0.35.0</em>) which directory to install the
gir file into; (<em>Deprecated since 0.61.0</em>) can be false to disable installation</li>
<li>
<code>install_typelib</code>: (<em>Added 0.61.0</em>) overrides <code>install</code>, whether to install the
generated typelib</li>
<li>
<code>install_dir_typelib</code>: (<em>Added 0.35.0</em>) which directory to install
the typelib file into; (<em>Deprecated since 0.61.0</em>) can be false to disable installation</li>
<li>
<code>link_with</code>: list of libraries to link with</li>
<li>
<code>symbol_prefix</code>: the symbol prefix for the gir object, e.g. <code>gtk</code>,
(<em>Since 0.43.0</em>) an ordered list of multiple prefixes is allowed</li>
<li>
<code>fatal_warnings</code>: <em>Since 0.55.0</em> turn scanner warnings into fatal errors.</li>
</ul>
<p>Returns an array of two elements which are: <code>[gir_target, typelib_target]</code></p>
<h3 id="gnomegenmarshal">gnome.genmarshal()</h3>
<p>Generates a marshal file using the <code>glib-genmarshal</code> tool. The first
argument is the basename of the output files.</p>
<ul>
<li>
<code>depends</code> [](BuildTarget | CustomTarget | CustomTargetIndex):
passed directly to CustomTarget (<em>since 0.61.0</em>)</li>
<li>
<code>depend_files</code> [](str | File): Passed directly to CustomTarget (<em>since 0.61.0</em>)</li>
<li>
<code>extra_args</code>: (<em>Added 0.42.0</em>) additional command line arguments to pass</li>
<li>
<code>install_dir</code>: directory to install header to</li>
<li>
<code>install_header</code>: if true, install the generated header</li>
<li>
<code>install_dir</code>: directory to install header to</li>
<li>
<code>install_header</code>: if true, install the generated header</li>
<li>
<code>internal</code>: if true, mark generated sources as internal to <code>glib-genmarshal</code>
(<em>Requires GLib 2.54</em>)</li>
<li>
<code>nostdinc</code>: if true, don't include the standard marshallers from glib</li>
<li>
<code>prefix</code>: the prefix to use for symbols</li>
<li>
<code>skip_source</code>: if true, skip source location comments</li>
<li>
<code>sources</code> [](str | File) <em>required</em>: the list of sources to use as inputs</li>
<li>
<code>stdinc</code>: if true, include the standard marshallers from glib</li>
<li>
<code>valist_marshallers</code>: if true, generate va_list marshallers</li>
</ul>
<p><em>Added 0.35.0</em></p>
<p>Returns an array of two elements which are: <code>[c_source, header_file]</code></p>
<h3 id="gnomemkenums">gnome.mkenums()</h3>
<p>Generates enum files for GObject using the <code>glib-mkenums</code> tool. The
first argument is the base name of the output files, unless
<code>c_template</code> and <code>h_template</code> are specified. In this case, the output
files will be the base name of the values passed as templates.</p>
<p>This method is essentially a wrapper around the <code>glib-mkenums</code> tool's
command line API. It is the most featureful method for enum creation.</p>
<p>Typically you either provide template files or you specify the various
template sections manually as strings.</p>
<p>Most libraries and applications will be using the same standard
template with only minor tweaks, in which case the
<code>gnome.mkenums_simple()</code> convenience method can be used instead.</p>
<p>Note that if you <code>#include</code> the generated header in any of the sources
for a build target, you must add the generated header to the build
target's list of sources to codify the dependency. This is true for</p>
<p>all generated sources, not just <code>mkenums</code>.</p>
<ul>
<li>
<code>c_template</code>: template to use for generating the source</li>
<li>
<code>comments</code>: comment passed to the command</li>
<li>
<code>h_template</code>: template to use for generating the header</li>
<li>
<code>identifier_prefix</code>: prefix to use for the identifiers</li>
<li>
<code>install_header</code>: if true, install the generated header</li>
<li>
<code>install_dir</code>: directory to install the header</li>
<li>
<code>sources</code>: the list of sources to make enums with</li>
<li>
<code>symbol_prefix</code>: prefix to use for the symbols</li>
<li>
<code>eprod</code>: enum text</li>
<li>
<code>fhead</code>: file header</li>
<li>
<code>fprod</code>: file text</li>
<li>
<code>ftail</code>: file tail</li>
<li>
<code>vhead</code>: value text</li>
<li>
<code>vtail</code>: value tail</li>
</ul>
<p><em>Added 0.35.0</em></p>
<p>Returns an array of two elements which are: <code>[c_source, header_file]</code></p>
<h3 id="gnomemkenums_simple">gnome.mkenums_simple()</h3>
<p>Generates enum <code>.c</code> and <code>.h</code> files for GObject using the
<code>glib-mkenums</code> tool with the standard template used by most
GObject-based C libraries. The first argument is the base name of the
output files.</p>
<p>Note that if you <code>#include</code> the generated header in any of the sources
for a build target, you must add the generated header to the build
target's list of sources to codify the dependency. This is true for
all generated sources, not just <code>mkenums_simple</code>.</p>
<p>The generated source file includes all headers passed to the sources keyword
argument, using paths relative to current build or source directory. That means
that targets that compile the generated source file must have the current
directory in its <code>include_directories</code>. <em>Since 1.3.0</em> <code>sources</code> outside of
current directory do not require adding those directories into
<code>include_directories</code> anymore.</p>
<ul>
<li>
<code>body_prefix</code>: additional prefix at the top of the body file,
e.g. for extra includes</li>
<li>
<code>decorator</code>: optional decorator for the function declarations,
e.g. <code>GTK_AVAILABLE</code> or <code>GST_EXPORT</code>
</li>
<li>
<code>function_prefix</code>: additional prefix for function names, e.g. in
case you want to add a leading underscore to functions used only
internally</li>
<li>
<code>header_prefix</code>: additional prefix at the top of the header file,
e.g. for extra includes (which may be needed if you specify a
decorator for the function declarations)</li>
<li>
<code>install_header</code>: if true, install the generated header</li>
<li>
<code>install_dir</code>: directory to install the header</li>
<li>
<code>identifier_prefix</code>: prefix to use for the identifiers</li>
<li>
<code>sources</code>: the list of sources to make enums with</li>
<li>
<code>symbol_prefix</code>: prefix to use for the symbols</li>
</ul>
<p>Example:</p>
<pre><code class="language-meson">gnome = import('gnome')
my_headers = ['myheader1.h', 'myheader2.h']
my_sources = ['mysource1.c', 'mysource2.c']
# will generate myenums.c and myenums.h based on enums in myheader1.h and myheader2.h
enums = gnome.mkenums_simple('myenums', sources : my_headers)
mylib = library('my', my_sources, enums,
include_directories: my_incs,
dependencies: my_deps,
c_args: my_cargs,
install: true)
</code></pre>
<p><em>Added 0.42.0</em></p>
<p>Returns an array of two elements which are: <code>[c_source, header_file]</code></p>
<h3 id="gnomecompile_schemas">gnome.compile_schemas()</h3>
<p>When called, this method will compile the gschemas in the current
directory. Note that this is not for installing schemas and is only
useful when running the application locally for example during tests.</p>
<ul>
<li>
<code>build_by_default</code>: causes, when set to true, to have this target be
built by default, that is, when invoking plain <code>meson compile</code>, the default
value is true for all built target types</li>
<li>
<code>depend_files</code>: files (<a href="Reference-manual_elementary_str.html"><ins><code>str</code></ins></a>,
<a href="Reference-manual_functions.html#files"><ins><code>files()</code></ins></a>, or
<a href="Reference-manual_functions.html#configure_file"><ins><code>configure_file()</code></ins></a>) of
schema source XML files that should trigger a re-compile if changed.</li>
</ul>
<h3 id="gnomegdbus_codegen">gnome.gdbus_codegen()</h3>
<p>Compiles the given XML schema into gdbus source code. Takes two
positional arguments, the first one specifies the base name to use
while creating the output source and header and the second specifies
one XML file.</p>
<ul>
<li>
<code>sources</code>: list of XML files</li>
<li>
<code>interface_prefix</code>: prefix for the interface</li>
<li>
<code>namespace</code>: namespace of the interface</li>
<li>
<code>extra_args</code>: (<em>Added 0.47.0</em>) additional command line arguments to pass</li>
<li>
<code>autocleanup</code>: <em>(Added 0.47.0)</em> if set generates autocleanup code. Can be one of <code>none</code>, <code>objects</code> or <code>all</code>
</li>
<li>
<code>object_manager</code>: <em>(Added 0.40.0)</em> if true generates object manager code</li>
<li>
<code>annotations</code>: <em>(Added 0.43.0)</em> list of lists of 3 strings for the annotation for <code>'ELEMENT', 'KEY', 'VALUE'</code>
</li>
<li>
<code>docbook</code>: <em>(Added 0.43.0)</em> prefix to generate <code>'PREFIX'-NAME.xml</code> docbooks</li>
<li>
<code>build_by_default</code>: causes, when set to true, to have this target be
built by default, that is, when invoking plain <code>meson compile</code>, the default
value is true for all built target types</li>
<li>
<code>install_dir</code>: (<em>Added 0.46.0</em>) location to install the header or
bundle depending on previous options</li>
<li>
<code>install_header</code>: (<em>Added 0.46.0</em>) if true, install the header file</li>
</ul>
<p>Starting <em>0.46.0</em>, this function returns a list of at least two custom
targets (in order): one for the source code and one for the header.
The list will contain a third custom target for the generated docbook
files if that keyword argument is passed.</p>
<p>Earlier versions return a single custom target representing all the
outputs. Generally, you should just add this list of targets to a top
level target's source list.</p>
<p>Example:</p>
<pre><code class="language-meson">gnome = import('gnome')
# The returned source would be passed to another target
gdbus_src = gnome.gdbus_codegen('example-interface',
sources: 'com.example.Sample.xml',
interface_prefix : 'com.example.',
namespace : 'Sample',
annotations : [
['com.example.Hello()', 'org.freedesktop.DBus.Deprecated', 'true']
],
docbook : 'example-interface-doc'
)
</code></pre>
<h3 id="gnomegenerate_vapi">gnome.generate_vapi()</h3>
<p>Creates a VAPI file from gir. The first argument is the name of the
library.</p>
<ul>
<li>
<code>gir_dirs</code>: extra directories to include for gir files</li>
<li>
<code>install</code>: if true, install the VAPI file</li>
<li>
<code>install_dir</code>: location to install the VAPI file (defaults to datadir/vala/vapi)</li>
<li>
<code>metadata_dirs</code>: extra directories to include for metadata files</li>
<li>
<code>packages</code>: VAPI packages that are depended upon</li>
<li>
<code>sources</code>: the gir source to generate the VAPI from</li>
<li>
<code>vapi_dirs</code>: extra directories to include for VAPI files</li>
</ul>
<p>Returns a custom dependency that can be included when building other
VAPI or Vala binaries.</p>
<p><em>Added 0.36.0</em></p>
<h3 id="gnomeyelp">gnome.yelp()</h3>
<pre><code class="language-meson"> gnome.yelp(id: string, sources: ...string, sources: []string, media: []string,
languages: []string, symlink_media: bool = true): void
</code></pre>
<p>Installs help documentation for Yelp using itstool and gettext. The first
argument is the project id.</p>
<p>Additionally, sources can be passed as additional positional arguments. This
was, however, undocumented and never officially supported. Due to a longstanding
bug, passing sources as a keyword argument will result in the positional
argument sources to be ignored. <em>since 0.60.0</em> A warning is raised in this case.</p>
<p><em>Since 0.43.0</em> if "languages" is not specified, a
<a href="https://www.gnu.org/software/gettext/manual/html_node/po_002fLINGUAS.html">LINGUAS</a>
file will be read instead.</p>
<p><em>Since 0.60.0</em> the use of the positional argument sources has been deprecated,
and the "sources" keyword argument should be used instead. The passing of
sources as positional arguments will be removed in the future.</p>
<p>This also creates two targets for translations
<code>help-$project-update-po</code> and <code>help-$project-pot</code>.</p>
<ul>
<li>
<code>languages</code>: <em>(deprecated since 0.43.0)</em> list of languages for translation, overrides the LINGUAS file</li>
<li>
<code>media</code>: list of media such as images</li>
<li>
<code>sources</code>: list of pages</li>
<li>
<code>symlink_media</code>: if media should be symlinked not copied (defaults to <code>true</code> since 0.42.0)</li>
</ul>
<p>Note that very old versions of yelp may not support symlinked media;
At least 3.10 should work.</p>
<p><em>Added 0.36.0</em></p>
<h3 id="gnomegtkdoc">gnome.gtkdoc()</h3>
<p>Compiles and installs gtkdoc documentation into
<code>prefix/share/gtk-doc/html</code>. Takes one positional argument: The name
of the module.</p>
<ul>
<li>
<code>content_files</code>: a list of content files</li>
<li>
<code>dependencies</code>: a list of dependencies</li>
<li>
<code>fixxref_args</code>: a list of arguments to pass to <code>gtkdoc-fixxref</code>
</li>
<li>
<code>gobject_typesfile</code>: a list of type files</li>
<li>
<code>include_directories</code>: extra include paths to pass to <code>gtkdoc-scangobj</code>
</li>
<li>
<code>ignore_headers</code>: a list of header files to ignore</li>
<li>
<code>html_assets</code>: a list of assets for the HTML pages</li>
<li>
<code>html_args</code> a list of arguments to pass to <code>gtkdoc-mkhtml</code>
</li>
<li>
<code>install</code>: if true, installs the generated docs</li>
<li>
<code>install_dir</code>: the directory to install the generated docs relative
to the gtk-doc html dir or an absolute path (default: module name)</li>
<li>
<code>main_xml</code>: specifies the main XML file</li>
<li>
<code>main_sgml</code>: equal to <code>main_xml</code>
</li>
<li>
<code>mkdb_args</code>: a list of arguments to pass to <code>gtkdoc-mkdb</code>
</li>
<li>
<code>namespace</code>: specifies the name space to pass to <code>gtkdoc-mkdb</code>
</li>
<li>
<code>module_version</code>: the version of the module, affects the installed location and the devhelp2 file location</li>
<li>
<code>scan_args</code>: a list of arguments to pass to <code>gtkdoc-scan</code>
</li>
<li>
<code>scanobjs_args</code>: a list of arguments to pass to <code>gtkdoc-scangobj</code>
</li>
<li>
<code>c_args</code>: (<em>Added 0.48.0</em>) additional compile arguments to pass</li>
<li>
<code>src_dir</code>: include_directories to include</li>
<li>
<code>check</code>: (<em>Since 0.52.0</em>) if <code>true</code> runs <code>gtkdoc-check</code> when running unit tests.
Note that this has the downside of rebuilding the doc for each build, which is
often very slow. It usually should be enabled only in CI.</li>
</ul>
<p>This also creates a <code>$module-doc</code> target that can be run to build
documentation. Normally the documentation is only built on install.</p>
<p><em>Since 0.52.0</em> Returns a target object that can be passed as
dependency to other targets using generated doc files (e.g. in
<code>content_files</code> of another doc).</p>
<h3 id="gnomegtkdoc_html_dir">gnome.gtkdoc_html_dir()</h3>
<p>Takes as argument a module name and returns the path where that
module's HTML files will be installed. Usually used with
<code>install_data</code> to install extra files, such as images, to the output
directory.</p>
<h3 id="gnomepost_install">gnome.post_install()</h3>
<p><em>Since 0.57.0</em></p>
<p>Post-install update of various system wide caches. Each script will be executed
only once even if <code>gnome.post_install()</code> is called multiple times from multiple
subprojects. If <code>DESTDIR</code> is specified during installation all scripts will be
skipped.</p>
<p>It takes the following keyword arguments:</p>
<ul>
<li>
<code>glib_compile_schemas</code>: If set to <code>true</code>, update <code>gschemas.compiled</code> file in
<code><prefix>/<datadir>/glib-2.0/schemas</code>.</li>
<li>
<code>gio_querymodules</code>: List of directories relative to <code>prefix</code> where
<code>giomodule.cache</code> file will be updated.</li>
<li>
<code>gtk_update_icon_cache</code>: If set to <code>true</code>, update <code>icon-theme.cache</code> file in
<code><prefix>/<datadir>/icons/hicolor</code>.</li>
<li>
<code>update_desktop_database</code>: <em>Since 0.59.0</em> If set to <code>true</code>, update cache of
MIME types handled by desktop files in <code><prefix>/<datadir>/applications</code>.</li>
<li>
<code>update_mime_database</code>: <em>Since 0.64.0</em> If set to <code>true</code>, update cache of
MIME types in <code><prefix>/<datadir>/mime</code>.</li>
</ul>
</div>
</div>
<div id="search_results">
<p>The results of the search are</p>
</div>
<div id="footer">
<hr>
<div class="license-description">
Website licensing information are available on the <a href="legal.html">Legal</a> page.
</div>
</div>
</div>
<div id="toc-column">
<div class="edit-button">
<a href="https://github.com/mesonbuild/meson/edit/master/docs/markdown/Gnome-module.md" data-hotdoc-role="edit-button">Edit on GitHub</a>
</div>
<div id="toc-wrapper">
<nav id="toc"></nav>
</div>
</div>
</div>
</main>
<script src="assets/js/navbar_offset_scroller.js"></script>
</body>
</html>