source: chapter06/ncurses.xml

trunk
Last change on this file was 7db3765, checked in by Xi Ruoyao <xry111@…>, 3 days ago

chapter06/ncurses: Use ncurses-release instead of ncurses-version for library file names

Reported-by: Stefano Moretti <stemoretti@…>
Closes: https://lists.linuxfromscratch.org/sympa/arc/lfs-dev/2024-04/msg00051.html

  • Property mode set to 100644
File size: 7.5 KB
RevLine 
[7152faa]1<?xml version="1.0" encoding="UTF-8"?>
[b06ca36]2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
3 "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
[673b0d8]4 <!ENTITY % general-entities SYSTEM "../general.ent">
5 %general-entities;
6]>
[2fa922f]7
[fcc02767]8<sect1 id="ch-tools-ncurses" role="wrap">
[2fa922f]9 <?dbhtml filename="ncurses.html"?>
10
[e747759]11 <sect1info condition="script">
12 <productname>ncurses</productname>
13 <productnumber>&ncurses-version;</productnumber>
14 <address>&ncurses-url;</address>
15 </sect1info>
16
[2fa922f]17 <title>Ncurses-&ncurses-version;</title>
18
[fcc02767]19 <indexterm zone="ch-tools-ncurses">
[2fa922f]20 <primary sortas="a-Ncurses">Ncurses</primary>
[fcc02767]21 <secondary>tools</secondary>
[2fa922f]22 </indexterm>
23
24 <sect2 role="package">
25 <title/>
[6370fa6]26
[fcc02767]27 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
28 href="../chapter08/ncurses.xml"
29 xpointer="xpointer(/sect1/sect2[1]/para[1])"/>
[673b0d8]30
[2fa922f]31 <segmentedlist>
32 <segtitle>&buildtime;</segtitle>
33 <segtitle>&diskspace;</segtitle>
[5888299]34
[2fa922f]35 <seglistitem>
[fb386e0]36 <seg>&ncurses-tmp-sbu;</seg>
37 <seg>&ncurses-tmp-du;</seg>
[2fa922f]38 </seglistitem>
39 </segmentedlist>
[673b0d8]40
[2fa922f]41 </sect2>
42
43 <sect2 role="installation">
44 <title>Installation of Ncurses</title>
[004616a]45
[fcc02767]46 <para>First, ensure that <command>gawk</command> is found first during configuration:</para>
[2fa922f]47
[fcc02767]48<screen><userinput remap="pre">sed -i s/mawk// configure</userinput></screen>
49
50 <para>Then, run the following commands to build the <quote>tic</quote>
51 program on the build host:</para>
52
53<screen><userinput remap="pre">mkdir build
[bc8cca5]54pushd build
55 ../configure
56 make -C include
57 make -C progs tic
58popd</userinput></screen>
[fa21b3d]59
[2fa922f]60 <para>Prepare Ncurses for compilation:</para>
[73aedd1d]61
[94ec149]62<screen><userinput remap="configure">./configure --prefix=/usr \
63 --host=$LFS_TGT \
64 --build=$(./config.guess) \
65 --mandir=/usr/share/man \
66 --with-manpage-format=normal \
67 --with-shared \
[f8b27ab]68 --without-normal \
69 --with-cxx-shared \
[94ec149]70 --without-debug \
71 --without-ada \
[e0f124e]72 --disable-stripping \
[a0d9193f]73 --enable-widec</userinput></screen>
[fa21b3d]74
[2fa922f]75 <variablelist>
[d51dfb9]76 <title>The meaning of the new configure options:</title>
[2fa922f]77
[94ec149]78 <varlistentry>
79 <term><parameter>--with-manpage-format=normal</parameter></term>
80 <listitem>
[5e8bab7]81 <para>This prevents Ncurses from installing compressed manual
[94ec149]82 pages, which may happen if the host distribution itself
83 has compressed manual pages.</para>
84 </listitem>
85 </varlistentry>
86
[f8b27ab]87 <varlistentry>
88 <term><parameter>--with-shared</parameter></term>
89 <listitem>
90 <para>This makes Ncurses build and install shared C libraries.</para>
91 </listitem>
92 </varlistentry>
93
94 <varlistentry>
95 <term><parameter>--without-normal</parameter></term>
96 <listitem>
[5e8bab7]97 <para>This prevents Ncurses from building and installing static C
[f8b27ab]98 libraries.</para>
99 </listitem>
100 </varlistentry>
101
102 <varlistentry>
103 <term><parameter>--without-debug</parameter></term>
104 <listitem>
[5e8bab7]105 <para>This prevents Ncurses from building and installing debug
[f8b27ab]106 libraries.</para>
107 </listitem>
108 </varlistentry>
109
110 <varlistentry>
111 <term><parameter>--with-cxx-shared</parameter></term>
112 <listitem>
113 <para>This makes Ncurses build and install shared C++ bindings. It
114 also prevents it building and installing static C++ bindings.</para>
115 </listitem>
116 </varlistentry>
117
[fcc02767]118 <varlistentry>
119 <term><parameter>--without-ada</parameter></term>
120 <listitem>
121 <para>This ensures that Ncurses does not build support for the Ada
[6dff9ef]122 compiler, which may be present on the host but will not be available
[fcc02767]123 once we enter the <command>chroot</command> environment.</para>
124 </listitem>
125 </varlistentry>
126
[e0f124e]127 <varlistentry>
128 <term><parameter>--disable-stripping</parameter></term>
129 <listitem>
[6dff9ef]130 <para>This switch prevents the building system from
131 using the <command>strip</command> program from the host.
132 Using host tools on cross-compiled programs can cause failure.</para>
[e0f124e]133 </listitem>
134 </varlistentry>
135
[2fa922f]136 <varlistentry>
137 <term><parameter>--enable-widec</parameter></term>
138 <listitem>
139 <para>This switch causes wide-character libraries (e.g., <filename
[7db3765]140 class="libraryfile">libncursesw.so.&ncurses-release;</filename>)
[2fa922f]141 to be built instead of normal ones (e.g., <filename
[7db3765]142 class="libraryfile">libncurses.so.&ncurses-release;</filename>).
[2fa922f]143 These wide-character libraries are usable in both multibyte and
144 traditional 8-bit locales, while normal libraries work properly
145 only in 8-bit locales. Wide-character and normal libraries are
146 source-compatible, but not binary-compatible.</para>
147 </listitem>
148 </varlistentry>
149
150 </variablelist>
151
152 <para>Compile the package:</para>
[73aedd1d]153
[0445a3d]154<screen><userinput remap="make">make</userinput></screen>
[73aedd1d]155
[2fa922f]156 <para>Install the package:</para>
[fe039b5]157
[fcc02767]158<screen><userinput remap="install">make DESTDIR=$LFS TIC_PATH=$(pwd)/build/progs/tic install
[943f225]159ln -sv libncursesw.so $LFS/usr/lib/libncurses.so
[d282f88]160sed -e 's/^#if.*XOPEN.*$/#if 1/' \
161 -i $LFS/usr/include/curses.h</userinput></screen>
[f8b27ab]162<!--
[2bb813a]163 <para>Remove an unneeded static library not handled by
164 <command>configure</command>:</para>
165
[f81a8a4]166<screen><userinput remap="install">rm -v $LFS/usr/lib/libncurses++w.a</userinput></screen>
[f8b27ab]167-->
[fe039b5]168 <variablelist>
169 <title>The meaning of the install options:</title>
170
171 <varlistentry>
172 <term><parameter>TIC_PATH=$(pwd)/build/progs/tic</parameter></term>
173 <listitem>
[6dff9ef]174 <para>We need to pass the path of the newly built
175 <command>tic</command> program that runs on the building machine, so
[fe039b5]176 the terminal database can be created without errors.</para>
177 </listitem>
178 </varlistentry>
179
180 <varlistentry>
[943f225]181 <term><command>ln -sv libncursesw.so $LFS/usr/lib/libncurses.so</command></term>
[fe039b5]182 <listitem>
183 <para>The <filename>libncurses.so</filename> library is needed by
[943f225]184 a few packages we will build soon. We create this symlink to use
185 <filename>libncursesw.so</filename> as a replacement.</para>
[fe039b5]186 </listitem>
187 </varlistentry>
188
[d282f88]189 <varlistentry>
190 <term><command>sed -e 's/^#if.*XOPEN.*$/#if 1/' ...</command></term>
191 <listitem>
192 <para>The header file <filename>curses.h</filename> contains
193 the definition of various Ncurses data structures. With different
194 preprocessor macro definitions two different sets of the data
195 structure definition may be used: the 8-bit definition is
196 compatible with <filename>libncurses.so</filename> and the
197 wide-character definition is compatible with
198 <filename>libncursesw.so</filename>. Since we are using
199 <filename>libncursesw.so</filename> as a replacement of
200 <filename>libncurses.so</filename>, edit the header file so it
201 will always use the wide-character data structure definition
202 compatible with <filename>libncursesw.so</filename>.</para>
203 </listitem>
204 </varlistentry>
205
[fe039b5]206 </variablelist>
[73aedd1d]207
[2fa922f]208 </sect2>
209
[fcc02767]210 <sect2 role="content">
211 <title/>
[2fa922f]212
[fcc02767]213 <para>Details on this package are located in
214 <xref linkend="contents-ncurses" role="."/></para>
[2fa922f]215
216 </sect2>
[673b0d8]217
218</sect1>
Note: See TracBrowser for help on using the repository browser.