source: introduction/important/beyond.xml@ ca1500d

10.0 10.1 11.0 11.1 11.2 11.3 12.0 12.1 7.10 7.4 7.5 7.6 7.6-blfs 7.6-systemd 7.7 7.8 7.9 8.0 8.1 8.2 8.3 8.4 9.0 9.1 basic bdubbs/svn elogind gnome kde5-13430 kde5-14269 kde5-14686 kea ken/TL2024 ken/inkscape-core-mods ken/tuningfonts krejzi/svn lazarus lxqt nosym perl-modules plabs/newcss plabs/python-mods python3.11 qt5new rahul/power-profiles-daemon renodr/vulkan-addition systemd-11177 systemd-13485 trunk upgradedb xry111/intltool xry111/llvm18 xry111/soup3 xry111/test-20220226 xry111/xf86-video-removal
Last change on this file since ca1500d was ca1500d, checked in by Ken Moffat <ken@…>, 12 years ago

Change the fedora link to cgit instead of the obsolete gitweb.

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

  • Property mode set to 100644
File size: 10.5 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
8<sect1 id="beyond" xreflabel="Going Beyond BLFS">
9 <?dbhtml filename="beyond.html"?>
10
11 <sect1info>
12 <othername>$LastChangedBy$</othername>
13 <date>$Date$</date>
14 </sect1info>
15
16 <title>Going Beyond BLFS</title>
17
18 <para>The packages that are installed in this book are only the tip of the
19 iceberg. We hope that the experience you gained with the LFS book and
20 the BLFS book will give you the background needed to compile, install
21 and configure packages that are not included in this book.</para>
22
23 <para>When you want to install a package to a location other than
24 <filename class='directory'>/</filename>, or
25 <filename class='directory'>/usr</filename>, you are installing
26 outside the default environment settings on most machines. The following
27 examples should assist you in determining how to correct this situation.
28 The examples cover the complete range of settings that may need
29 updating, but they are not all needed in every situation.</para>
30
31 <itemizedlist>
32 <listitem>
33 <para>Expand the <envar>PATH</envar> to include
34 <filename class='directory'>$PREFIX/bin</filename>.</para>
35 </listitem>
36 <listitem>
37 <para>Expand the <envar>PATH</envar> for
38 <systemitem class="username">root</systemitem> to include
39 <filename class='directory'>$PREFIX/sbin</filename>.</para>
40 </listitem>
41 <listitem>
42 <para>Add <filename class='directory'>$PREFIX/lib</filename>
43 to <filename>/etc/ld.so.conf</filename> or expand
44 <envar>LD_LIBRARY_PATH</envar> to include it. Before using the latter
45 option, check out <ulink
46 url="http://xahlee.org/UnixResource_dir/_/ldpath.html"/>.
47 If you modify <filename>/etc/ld.so.conf</filename>, remember to update
48 <filename>/etc/ld.so.cache</filename> by executing
49 <command>ldconfig</command> as the
50 <systemitem class="username">root</systemitem> user.</para>
51 </listitem>
52 <listitem>
53 <para>Add <filename class='directory'>$PREFIX/man</filename>
54 to <filename>/etc/man_db.conf</filename> or expand
55 <envar>MANPATH</envar>.</para>
56 </listitem>
57 <listitem>
58 <para>Add <filename class='directory'>$PREFIX/info</filename>
59 to <envar>INFOPATH</envar>.</para>
60 </listitem>
61 <listitem>
62 <para>Add <filename class='directory'>$PREFIX/lib/pkgconfig</filename>
63 to <envar>PKG_CONFIG_PATH</envar>. Some packages are now installing
64 <filename class='extension'>.pc</filename> files in
65 <filename class='directory'>$PREFIX/share/pkgconfig</filename>, so you may
66 have to include this directory also.</para>
67 </listitem>
68 <listitem>
69 <para>Add <filename class='directory'>$PREFIX/include</filename> to
70 <envar>CPPFLAGS</envar> when compiling packages that depend on
71 the package you installed.</para>
72 </listitem>
73 <listitem>
74 <para>Add <filename class='directory'>$PREFIX/lib</filename> to
75 <envar>LDFLAGS</envar> when compiling packages that depend on a library
76 installed by the package.</para>
77 </listitem>
78 </itemizedlist>
79
80 <para>If you are in search of a package that is not in the book, the following
81 are different ways you can search for the desired package.</para>
82
83 <itemizedlist>
84 <listitem>
85 <para>If you know the name of the package, then search Freecode for
86 it at <ulink url="http://freecode.com/"/>. Also search Google at
87 <ulink url="http://google.com/"/>. Sometimes a search for the
88 <filename class='extension'>rpm</filename> at
89 <ulink url="http://rpmfind.net/"/> or the
90 <filename class='extension'>deb</filename> at
91 <ulink url="http://www.debian.org/distrib/packages#search_packages"/> can
92 also lead to a link to the package.</para>
93 </listitem>
94 <listitem>
95 <para>If you know the name of the executable, but not the package
96 that the executable belongs to, first try a Google search with the name
97 of the executable. If the results are overwhelming, try searching for the
98 given executable in the Debian repository at <ulink
99 url="http://www.debian.org/distrib/packages#search_contents"/>.</para>
100 </listitem>
101 </itemizedlist>
102
103 <para>Some general hints on handling new packages:</para>
104
105 <itemizedlist>
106 <listitem>
107 <para>Many of the newer packages follow the <command>./configure
108 &amp;&amp; make &amp;&amp; make install</command> process.
109 Help on the options accepted by configure can be obtained via the
110 command <command>./configure --help</command>.</para>
111 </listitem>
112 <listitem>
113 <para>Most of the packages contain documentation on compiling and
114 installing the package. Some of the documents are excellent, some not so
115 excellent. Check out the homepage of the package for any additional and
116 updated hints for compiling and configuring the package.</para>
117 </listitem>
118 <listitem>
119 <para>If you are having a problem compiling the package, try
120 searching the LFS archives at
121 <ulink url="http://www.&lfs-domainname;/search.html"/> for the error or if
122 that fails, try searching Google. Often, a distribution will have already
123 solved the problem (many of them use development versions of packages, so
124 they see the changes sooner than those of us who normally use stable released
125 versions). But be cautious - all builders tend to carry patches which are no
126 longer necessary, and to have fixes which are only required because of their
127 particular choices in how they build a package. You may have to search
128 deeply to find a fix for the package version you are trying to use, or even
129 to find the package (names are sometimes not what you might expect, e.g.
130 <application>ghostscript</application> often has a prefix or a suffix in its
131 name), but the following notes might help:</para>
132 <itemizedlist>
133 <listitem>
134 <para>Arch
135 <ulink url="http://www.archlinux.org/packages/"/> - enter the package name
136 in the 'Keywords' box, select the package name, select one of the 'SVN
137 Entries' fields, then select the <filename>PKGBUILD</filename> to see how
138 they build this package, or look at any patches.</para>
139 </listitem>
140 <listitem>
141 <para>Debian
142 <ulink url="ftp://ftp.uk.debian.org/debian/pool"/> (use your country's
143 version if there is one) - the source will be in .tar.gz tarballs (either
144 the original upstream <filename class='extension'>.orig</filename> source,
145 or else a <filename>dfsg</filename> containing those parts which comply
146 with debian's free software guidelines) accompanied by versioned .diff.gz
147 or .tar.gz additions. These additions often show how the package is built,
148 and may contain patches. In the .diff.gz versions, any patches create files
149 in <filename class="directory">debian/patches</filename>.</para>
150 </listitem>
151 <listitem>
152 <para>Fedora
153 <ulink url="http://pkgs.fedoraproject.org/cgit/"/> - this site
154 is still occasionally overloaded, and somewhat hard to navigate (nearly
155 300 pages, linked by number) but it is an easy way of looking at .spec
156 files and patches. If you know their name for the package (e.g. mesa.git)
157 you can append that to the URI to get to it. If unavailable, try
158 looking for a local mirror of ftp.fedora.com (the primary site is usually
159 unavailable if fedora cgit is not responding) and download a source
160 rpm to see what they do.</para>
161 </listitem>
162 <listitem>
163 <para>Gentoo - the mirrors for ebuilds and patches seem to be well-hidden,
164 and they change frequently. Also, if you have found a mirror, you need to
165 know which directory the application has been assigned to. The ebuilds
166 themselves can be found at <ulink url="http://packages.gentoo.org/"/> -
167 use the search field. If there are any patches, a mirror will have them
168 in the <filename class="directory">files/</filename> directory. Depending
169 on your browser, or the mirror, you might need to download the ebuild to
170 be able to read it. Treat the ebuild as a sort of pseudo-code / shell
171 combination - look in particular for <command>sed</command> commands and
172 patches, or hazard a guess at the meanings of the functions such as
173 <command>dodoc</command>.</para>
174 </listitem>
175 <listitem>
176 <para>PLD
177 <ulink url="http://cvs.pld-linux.org/cgi-bin/cvsweb/packages/"/> -
178 another distro which uses rpms, cvsweb provides access to patches and the
179 spec files.</para>
180 </listitem>
181 <listitem>
182 <para>Slackware - the official package browser is currently broken. The
183 site at <ulink url="http://slackbuilds.org/"/> has current and previous
184 versions in their unofficial repository with links to homepages, downloads,
185 and some individual files, particularly the <filename>.SlackBuild</filename>
186 files.</para>
187 </listitem>
188 <listitem>
189 <para>Ubuntu <ulink url="ftp://ftp.ubuntu.com/ubuntu/pool/"/> - see the
190 debian notes above.</para>
191 </listitem>
192 </itemizedlist>
193 <para>If everything else fails, try the blfs-support mailing-list.</para>
194 </listitem>
195 </itemizedlist>
196
197 <tip>
198 <para>If you have found a package that is only available in
199 <filename class='extension'>.deb</filename> or
200 <filename class='extension'>.rpm</filename>
201 format, there are two small scripts, <command>rpm2targz</command> and
202 <command>deb2targz</command> that are available at
203 <ulink url="&downloads-project;/deb2targz.tar.bz2"/> and
204 <ulink url="&downloads-project;/rpm2targz.tar.bz2"/> to convert the archives
205 into a simple <filename>tar.gz</filename> format.</para>
206 <para>You may also find an rpm2cpio script useful. The perl version in the
207 linux kernel archives at <ulink
208 url="http://lkml.indiana.edu/hypermail/linux/kernel/0210.2/att-0093/01-rpm2cpio"/>
209 works for most source rpms. The rpm2targz script will use an rpm2cpio script
210 or binary if one is on your path. Note that rpm2cpio will unpack a source
211 rpm in the current directory, giving a tarball, a spec file, and perhaps patches
212 or other files.</para>
213 </tip>
214
215</sect1>
Note: See TracBrowser for help on using the repository browser.