source: general/prog/cmake.xml@ 6b241ec

10.0 10.1 11.0 11.1 11.2 11.3 12.0 12.1 7.10 7.9 8.0 8.1 8.2 8.3 8.4 9.0 9.1 basic bdubbs/svn elogind kea ken/TL2024 ken/inkscape-core-mods ken/tuningfonts lazarus lxqt nosym perl-modules plabs/newcss plabs/python-mods python3.11 qt5new rahul/power-profiles-daemon renodr/vulkan-addition trunk upgradedb xry111/intltool xry111/llvm18 xry111/soup3 xry111/test-20220226 xry111/xf86-video-removal
Last change on this file since 6b241ec was 6b241ec, checked in by Fernando de Oliveira <fernando@…>, 8 years ago
  • Update to taglib-1.10.
  • Update to cmake-3.4.0.
  • Update to wget-1.17.
  • Update to libinput-1.1.1.
  • Qt-5.5.1: add libinput-1.1.1 as optional dependency.

git-svn-id: svn://svn.linuxfromscratch.org/BLFS/trunk/BOOK@16671 af4574ff-66df-0310-9fd7-8a98e5e911e0

  • Property mode set to 100644
File size: 8.6 KB
Line 
1<?xml version="1.0" encoding="ISO-8859-1"?>
2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
3 "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
4 <!ENTITY % general-entities SYSTEM "../../general.ent">
5 %general-entities;
6
7 <!ENTITY cmake-download-http "http://www.cmake.org/files/v&cmake-major-version;/cmake-&cmake-version;.tar.gz">
8 <!ENTITY cmake-download-ftp " ">
9 <!ENTITY cmake-md5sum "cd3034e0a44256a0917e254167217fc8">
10 <!ENTITY cmake-size "6.5 MB">
11 <!ENTITY cmake-buildsize "696 MB (with tests and cmake-gui)">
12 <!ENTITY cmake-time "4.6 SBU, with parallelism = 4 (with tests and cmake-gui)">
13]>
14
15<sect1 id="cmake" xreflabel="CMake-&cmake-version;">
16 <?dbhtml filename="cmake.html"?>
17
18 <sect1info>
19 <othername>$LastChangedBy$</othername>
20 <date>$Date$</date>
21 </sect1info>
22
23 <title>CMake-&cmake-version;</title>
24
25 <indexterm zone="cmake">
26 <primary sortas="a-CMake">CMake</primary>
27 </indexterm>
28
29 <sect2 role="package">
30 <title>Introduction to CMake</title>
31
32 <para>
33 The <application>CMake</application> package contains a modern
34 toolset used for generating Makefiles. It is a successor of the
35 auto-generated <command>configure</command> script and aims to
36 be platform- and compiler-independent. A significant user of
37 <application>CMake</application> is <application>KDE</application>
38 since version 4.
39 </para>
40
41 &lfs78_checked;
42
43 <bridgehead renderas="sect3">Package Information</bridgehead>
44 <itemizedlist spacing="compact">
45 <listitem>
46 <para>
47 Download (HTTP): <ulink url="&cmake-download-http;"/>
48 </para>
49 </listitem>
50 <listitem>
51 <para>
52 Download (FTP): <ulink url="&cmake-download-ftp;"/>
53 </para>
54 </listitem>
55 <listitem>
56 <para>
57 Download MD5 sum: &cmake-md5sum;
58 </para>
59 </listitem>
60 <listitem>
61 <para>
62 Download size: &cmake-size;
63 </para>
64 </listitem>
65 <listitem>
66 <para>
67 Estimated disk space required: &cmake-buildsize;
68 </para>
69 </listitem>
70 <listitem>
71 <para>
72 Estimated build time: &cmake-time;
73 </para>
74 </listitem>
75 </itemizedlist>
76
77 <bridgehead renderas="sect3">CMake Dependencies</bridgehead>
78
79 <bridgehead renderas="sect4">Recommended</bridgehead>
80 <para role="recommended">
81 <xref linkend="curl"/> and
82 <xref linkend="libarchive"/>
83 </para>
84
85 <bridgehead renderas="sect4">Optional</bridgehead>
86 <para role="optional">
87 <xref linkend="qt4"/> or <xref linkend="qt5"/> (for the Qt-based GUI),
88 <xref linkend="subversion"/> (for testing), and
89 <ulink url="http://pypi.python.org/pypi/Sphinx">Sphinx</ulink>
90 (for building documents)
91 </para>
92
93 <para condition="html" role="usernotes">User Notes:
94 <ulink url="&blfs-wiki;/cmake"/>
95 </para>
96 </sect2>
97
98 <sect2 role="installation">
99 <title>Installation of CMake</title>
100
101 <para>
102 If <application>Qt4</application> and <application>Qt5</application> are
103 installed in <filename class="directory">/opt</filename>, use
104 <command>source setqt4</command> or <command>source setqt5</command> to
105 choose which one will be used to build the Qt-based GUI.
106 </para>
107
108 <para>
109 Install <application>CMake</application> by running the following
110 commands:
111 </para>
112
113<screen><userinput>./bootstrap --prefix=/usr \
114 --system-libs \
115 --mandir=/share/man \
116 --no-system-jsoncpp \
117 --docdir=/share/doc/cmake-&cmake-version; &amp;&amp;
118make</userinput></screen>
119
120 <para>
121 To test the results, issue:
122 <command>bin/ctest -j<replaceable>&lt;N&gt;</replaceable> -O
123 ../cmake-&cmake-version;-test.log</command>,
124 where
125 <replaceable>&lt;N&gt;</replaceable> is an integer between 1 and the
126 number of threads of your processor, inclusive. For some systems, it may
127 be necessary to run the tests only for Qt4 using
128 <command>source setq4</command>, then
129 <command>export CXXFLAGS="-std=c++11"</command> (just before
130 <command>./bootstrap ...</command>) and remember to unset it after
131 finishing, with
132 <command>unset CXXFLAGS</command>.
133 The worst case we have obtained in problematic systems, without those
134 extra commands, was 98% of 447 tests passed.
135 <!-- Please, don't remove this comment, needed if tests start to fail
136 again. If you want to investigate a problem with a given "problem1-test",
137 use <command>bin/ctest -R "problem1-test"</command> and, to omit it, use
138 <command>bin/ctest -E "problem1-test"</command>. These options can be
139 used together: <command>bin/ctest -R "problem1-test" -E
140 "problem2-test"</command>. Option -N can be used to display all
141 available tests, and you can run <command>bin/ctest</command> for a
142 sub-set of tests by using separated by spaces names or numbers as
143 options. Option -/-help can be used to show all options.-->
144 </para>
145
146 <para>
147 Now, as the <systemitem class="username">root</systemitem> user:
148 </para>
149
150<screen role="root"><userinput>make install</userinput></screen>
151
152 </sect2>
153
154 <sect2 role="commands">
155 <title>Command Explanations</title>
156
157 <para>
158 <parameter>--system-libs</parameter>: This switch forces the build system
159 to link against <application>Zlib</application>,
160 <application>Bzip2</application>, <application>cURL</application>,
161 <application>Expat</application> and <application>libarchive</application>
162 installed on the system.
163 </para>
164
165 <para>
166 <parameter>--no-system-jsoncpp</parameter>: This switch removes the
167 <application>JSON-C++</application> library from the list of system
168 libraries. A bundled version of that library is used instead.
169 </para>
170
171 <para>
172 <option>--qt-gui</option>: This switch enables building of the
173 <application>Qt</application>-based GUI for
174 <application>CMake</application>.
175 </para>
176
177 </sect2>
178
179 <sect2 role="content">
180 <title>Contents</title>
181
182 <segmentedlist>
183 <segtitle>Installed Programs</segtitle>
184 <segtitle>Installed Libraries</segtitle>
185 <segtitle>Installed Directories</segtitle>
186
187 <seglistitem>
188 <seg>
189 ccmake, cmake, cmake-gui (optional), cpack and ctest
190 </seg>
191 <seg>
192 None
193 </seg>
194 <seg>
195 /usr/share/cmake-&cmake-major-version; and
196 /usr/share/doc/cmake-&cmake-version;
197 </seg>
198 </seglistitem>
199 </segmentedlist>
200
201
202 <variablelist>
203 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
204 <?dbfo list-presentation="list"?>
205 <?dbhtml list-presentation="table"?>
206
207 <varlistentry id="ccmake">
208 <term><command>ccmake</command></term>
209 <listitem>
210 <para>
211 is a curses based interactive frontend to
212 <command>cmake</command>.
213 </para>
214 <indexterm zone="cmake ccmake">
215 <primary sortas="b-ccmake">ccmake</primary>
216 </indexterm>
217 </listitem>
218 </varlistentry>
219
220 <varlistentry id="cmake-prog">
221 <term><command>cmake</command></term>
222 <listitem>
223 <para>
224 is the makefile generator.
225 </para>
226 <indexterm zone="cmake cmake-prog">
227 <primary sortas="b-cmake">cmake</primary>
228 </indexterm>
229 </listitem>
230 </varlistentry>
231
232 <varlistentry id="cmake-gui">
233 <term><command>cmake-gui</command></term>
234 <listitem>
235 <para>
236 (optional) is the <application>Qt</application>-based frontent to
237 <command>cmake</command>.
238 </para>
239 <indexterm zone="cmake cmake-gui">
240 <primary sortas="b-cmake-gui">cmake-gui</primary>
241 </indexterm>
242 </listitem>
243 </varlistentry>
244
245 <varlistentry id="cpack">
246 <term><command>cpack</command></term>
247 <listitem>
248 <para>
249 is the <application>CMake</application> packaging program.
250 </para>
251 <indexterm zone="cmake cpack">
252 <primary sortas="b-cpack">cpack</primary>
253 </indexterm>
254 </listitem>
255 </varlistentry>
256
257 <varlistentry id="ctest">
258 <term><command>ctest</command></term>
259 <listitem>
260 <para>
261 is a testing utility for cmake-generated build trees.
262 </para>
263 <indexterm zone="cmake ctest">
264 <primary sortas="b-ctest">ctest</primary>
265 </indexterm>
266 </listitem>
267 </varlistentry>
268
269 </variablelist>
270
271 </sect2>
272
273</sect1>
Note: See TracBrowser for help on using the repository browser.