blob: ffd4153b010de5fd401c004e77ecfde23871a340 (
plain)
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
|
<?xml version="1.0" encoding="ISO-8859-1"?>
<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
"http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
<!ENTITY % general-entities SYSTEM "../general.ent">
%general-entities;
]>
<sect1 id="ch-system-meson" role="wrap">
<?dbhtml filename="meson.html"?>
<sect1info condition="script">
<productname>meson</productname>
<productnumber>&meson-version;</productnumber>
<address>&meson-url;</address>
</sect1info>
<title>Meson-&meson-version;</title>
<indexterm zone="ch-system-meson">
<primary sortas="a-Meson">Meson</primary>
</indexterm>
<sect2 role="package">
<title/>
<para>Meson is an open source build system meant to be both extremely fast
and as user friendly as possible.</para>
<segmentedlist>
<segtitle>&buildtime;</segtitle>
<segtitle>&diskspace;</segtitle>
<seglistitem>
<seg>&meson-fin-sbu;</seg>
<seg>&meson-fin-du;</seg>
</seglistitem>
</segmentedlist>
<tip revision="sysv">
<para>This section is not strictly required for LFS if not using
systemd. On the other hand, meson/ninja is a powerful build system,
which is expected to be used more and more often. It is required for
several packages in <ulink url="&blfs-book;">the BLFS
book</ulink>.</para>
</tip>
</sect2>
<sect2 role="installation">
<title>Installation of Meson</title>
<!--
<para>First, apply a patch that fixes an issue identified upstream:</para>
<screen><userinput remap="pre">patch -Np1 -i ../&meson-fix-patch;</userinput></screen>
-->
<para>Compile Meson with the following command:</para>
<screen><userinput remap="make">python3 setup.py build</userinput></screen>
<para>The test suite requires some packages out of the scope of LFS.</para>
<para>Install the package:</para>
<screen><userinput remap="install">python3 setup.py install --root=dest
cp -rv dest/* /
install -vDm644 data/shell-completions/bash/meson /usr/share/bash-completion/completions/meson
install -vDm644 data/shell-completions/zsh/_meson /usr/share/zsh/site-functions/_meson</userinput></screen>
<variablelist>
<title>The meaning of the install parameters:</title>
<varlistentry>
<term><parameter>--root=dest</parameter></term>
<listitem>
<para>By default <command>python3 setup.py install</command>
installs various files (such as man pages) into Python Eggs.
With a specified root location, <command>setup.py</command> installs
these files into a standard hierarchy. Then the hierarchy
can just be copied to the standard location.
</para>
</listitem>
</varlistentry>
</variablelist>
</sect2>
<sect2 id="contents-meson" role="content">
<title>Contents of Meson</title>
<segmentedlist>
<segtitle>Installed programs</segtitle>
<segtitle>Installed directory</segtitle>
<seglistitem>
<seg>meson</seg>
<!-- We are using DESTDIR installation here, so the directory layout
is different than other Python modules in LFS
(Jinja2 & MarkupSafe). -->
<seg>/usr/lib/python&python-minor;/site-packages/meson-&meson-version;-py&python-minor;.egg-info and /usr/lib/python&python-minor;/site-packages/mesonbuild</seg>
</seglistitem>
</segmentedlist>
<variablelist>
<bridgehead renderas="sect3">Short Descriptions</bridgehead>
<?dbfo list-presentation="list"?>
<?dbhtml list-presentation="table"?>
<varlistentry id="meson">
<term><command>meson</command></term>
<listitem>
<para>A high productivity build system</para>
<indexterm zone="ch-system-meson meson">
<primary sortas="b-meson">meson</primary>
</indexterm>
</listitem>
</varlistentry>
</variablelist>
</sect2>
</sect1>
|