2015-01-18 17:58:24 +01:00
|
|
|
<?xml version="1.0" encoding="UTF-8"?>
|
|
|
|
<!-- Above is a mandatory header for xml files. It must be the first
|
|
|
|
line in the file. Change encoding to the one you use on your computer -->
|
|
|
|
<!-- $Id$ -->
|
|
|
|
<!-- Mandatory DOCTYPE declaration. Fill free to add entities,
|
|
|
|
but no external entities in local files, since they would not
|
|
|
|
be accessible from JHALFSDIR. Change the document type `article' to
|
|
|
|
book if you prefer. That slightly changes the aspect if you render
|
|
|
|
it in html -->
|
|
|
|
<!DOCTYPE article PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
|
2019-04-11 09:40:50 +02:00
|
|
|
"http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
|
|
|
|
<!ENTITY libarchive-version "3.1.2">
|
|
|
|
<!ENTITY curl-version "7.39.0">
|
|
|
|
<!ENTITY pacman-version "4.1.2">
|
|
|
|
<!ENTITY libarchive-url "http://www.libarchive.org/downloads/libarchive-&libarchive-version;.tar.gz">
|
|
|
|
<!ENTITY curl-url "http://curl.haxx.se/download/curl-&curl-version;.tar.lzma">
|
|
|
|
<!ENTITY pacman-url "https://sources.archlinux.org/other/pacman/pacman-&pacman-version;.tar.gz">
|
|
|
|
<!ENTITY curl-md5 "e9aa6dec29920eba8ef706ea5823bad7">
|
|
|
|
<!ENTITY libarchive-md5 "efad5a503f66329bb9d2f4308b5de98a">
|
|
|
|
<!ENTITY pacman-md5 "063c8b0ff6bdf903dc235445525627cd">
|
|
|
|
]>
|
|
|
|
|
2015-01-18 17:58:24 +01:00
|
|
|
|
|
|
|
<!-- The first markup should be the one defined in the DOCTYPE DECLARATION -->
|
|
|
|
<article>
|
|
|
|
|
|
|
|
<!-- First section for the tarball download address.
|
|
|
|
Only the next four lines are mandatory, but you can add anything
|
|
|
|
to make the text look more like the LFS book.
|
|
|
|
Do not change anything, except the url and the md5 checksum. -->
|
|
|
|
<sect1 id="package">
|
2019-04-11 09:40:50 +02:00
|
|
|
<?dbhtml filename="package.html"?>
|
|
|
|
|
|
|
|
<title>All Packages</title>
|
|
|
|
<para>Download: <ulink url="&curl-url;"/></para>
|
|
|
|
<para>MD5 sum: <literal>&curl-md5;</literal></para>
|
|
|
|
<para>Download: <ulink url="&libarchive-url;"/></para>
|
|
|
|
<para>MD5 sum: <literal>&libarchive-md5;</literal></para>
|
|
|
|
<para>Download: <ulink url="&pacman-url;"/></para>
|
|
|
|
<para>MD5 sum: <literal>&pacman-md5;</literal></para>
|
2015-01-18 17:58:24 +01:00
|
|
|
</sect1>
|
|
|
|
|
|
|
|
<!-- If needed, uncomment and edit this:
|
|
|
|
<sect1 id="patches">
|
|
|
|
<para>Download: <ulink url="somepatch-url"/></para>
|
|
|
|
<para>MD5 sum: <literal>somepatch-md5</literal></para>
|
|
|
|
</sect1>
|
|
|
|
-->
|
|
|
|
|
|
|
|
<!-- Do not change the next line. The name of the scriptlet will be taken
|
|
|
|
from the dbhtml instruction: it is the name of the file less .html, with
|
2019-04-11 09:40:50 +02:00
|
|
|
xxx-x-added before (x, digits).-->
|
2015-01-18 17:58:24 +01:00
|
|
|
<sect1 id="ch-tools-libarchive" role="wrap">
|
|
|
|
<?dbhtml filename="libarchive.html"?>
|
2019-04-11 09:40:50 +02:00
|
|
|
|
|
|
|
<sect1info condition="script">
|
|
|
|
<productname>libarchive</productname>
|
|
|
|
<productnumber>&libarchive-version;</productnumber>
|
|
|
|
<address>&libarchive-url;</address>
|
|
|
|
</sect1info>
|
|
|
|
|
|
|
|
<title>Libarchive-&libarchive-version;</title>
|
|
|
|
|
2015-01-18 17:58:24 +01:00
|
|
|
<sect2 role="installation">
|
2019-04-11 09:40:50 +02:00
|
|
|
<title/>
|
2015-01-18 17:58:24 +01:00
|
|
|
<screen><userinput remap="configure">./configure --prefix=/tools \
|
|
|
|
--without-bz2lib \
|
2017-03-11 17:47:43 +01:00
|
|
|
--without-xml2 \
|
2015-01-18 17:58:24 +01:00
|
|
|
--enable-bsdtar=static \
|
|
|
|
--enable-bsdcpio=static</userinput></screen>
|
|
|
|
<screen><userinput remap="make">make</userinput></screen>
|
|
|
|
<screen><userinput remap="install">make install</userinput></screen>
|
|
|
|
</sect2>
|
|
|
|
|
|
|
|
</sect1>
|
2019-04-11 09:40:50 +02:00
|
|
|
|
2015-01-18 17:58:24 +01:00
|
|
|
<sect1 id="ch-tools-curl" role="wrap">
|
|
|
|
<?dbhtml filename="curl.html"?>
|
2019-04-11 09:40:50 +02:00
|
|
|
|
|
|
|
<sect1info condition="script">
|
|
|
|
<productname>curl</productname>
|
|
|
|
<productnumber>&curl-version;</productnumber>
|
|
|
|
<address>&curl-url;</address>
|
|
|
|
</sect1info>
|
|
|
|
|
|
|
|
<title>Curl-&curl-version;</title>
|
|
|
|
|
2015-01-18 17:58:24 +01:00
|
|
|
<sect2 role="installation">
|
2019-04-11 09:40:50 +02:00
|
|
|
<title/>
|
2015-01-18 17:58:24 +01:00
|
|
|
<screen><userinput remap="configure">./configure --prefix=/tools \
|
|
|
|
--disable-static</userinput></screen>
|
|
|
|
<screen><userinput remap="make">make</userinput></screen>
|
|
|
|
<screen><userinput remap="install">make install</userinput></screen>
|
|
|
|
</sect2>
|
|
|
|
|
|
|
|
</sect1>
|
|
|
|
|
|
|
|
<sect1 id="ch-tools-pkgmngt" role="wrap">
|
|
|
|
<?dbhtml filename="pacman.html"?>
|
2019-04-11 09:40:50 +02:00
|
|
|
|
|
|
|
<sect1info condition="script">
|
|
|
|
<productname>pacman</productname>
|
|
|
|
<productnumber>&pacman-version;</productnumber>
|
|
|
|
<address>&pacman-url;</address>
|
|
|
|
</sect1info>
|
|
|
|
|
|
|
|
<title>Pacman-&pacman-version;</title>
|
|
|
|
|
2015-01-18 17:58:24 +01:00
|
|
|
<sect2 role="installation">
|
2019-04-11 09:40:50 +02:00
|
|
|
<title/>
|
2015-01-18 17:58:24 +01:00
|
|
|
<!-- You can use any number of remap="pre", "configure", "make", "test", "install"
|
|
|
|
<screen><userinput remap="something">Instructions</userinput></screen>.
|
|
|
|
They are executed in that order. "pre" can be used for patching for example.
|
|
|
|
In case testing is enabled, the instructions flagged test are logged to a different
|
|
|
|
file (test-log). If testing is not enabled, they are not executed at all. Do not
|
|
|
|
put line breaks before and after your instructions. <userinput> without
|
|
|
|
remap attribute are considered configuration instructions and executed last. You
|
|
|
|
can also use remap="adjust" for the same purpose. -->
|
|
|
|
<screen><userinput remap="configure">./configure --prefix=/tools \
|
2017-03-11 17:47:43 +01:00
|
|
|
--without-openssl \
|
2015-01-18 17:58:24 +01:00
|
|
|
PKG_CONFIG_PATH=/tools/lib/pkgconfig \
|
|
|
|
DUPATH=/tools/bin/du</userinput></screen>
|
|
|
|
|
|
|
|
<screen><userinput remap="make">make</userinput></screen>
|
|
|
|
|
|
|
|
<screen><userinput remap="install">make install</userinput></screen>
|
|
|
|
|
|
|
|
<screen><userinput>sed -e 's@/usr@/tools@g' \
|
|
|
|
-e 's/\([^!]\)strip/\1!strip/' \
|
|
|
|
-e 's/\([^!]\)zipman/\1!zipman/' \
|
|
|
|
-i /tools/etc/makepkg.conf
|
|
|
|
cat >> /tools/etc/makepkg.conf << EOF
|
|
|
|
BUILDDIR=/sources
|
|
|
|
PKGDEST=/var/lib/packages
|
|
|
|
PACKAGER="Pierre Labastie <lnimbus@club-internet.fr>"
|
|
|
|
EOF
|
|
|
|
cat >> /tools/etc/pacman.conf << EOF
|
|
|
|
DBPath = /var/lib/pacman/
|
|
|
|
CacheDir = /var/cache/pacman/pkg/
|
|
|
|
LogFile = /var/log/pacman.log
|
|
|
|
SigLevel = Never
|
|
|
|
# Repository: do not add one now: repo-add needs openssl.
|
|
|
|
EOF</userinput></screen>
|
|
|
|
|
|
|
|
</sect2>
|
|
|
|
|
|
|
|
</sect1>
|
|
|
|
|
|
|
|
<!-- Mandatory section for creating dirs. These instructions are added at the
|
|
|
|
end of the creating dirs instructions of the book. Do not change the
|
|
|
|
following line -->
|
|
|
|
<sect1 id="ch-pkgmngt-creatingdirs">
|
|
|
|
|
2019-04-11 09:40:50 +02:00
|
|
|
<title>Creating Directories</title>
|
|
|
|
|
2015-01-18 17:58:24 +01:00
|
|
|
<screen><userinput>mkdir -pv /var/{lib/{packages,pacman},cache/pkg}</userinput></screen>
|
|
|
|
|
|
|
|
</sect1>
|
|
|
|
<!-- Same for files. Do not change the following line -->
|
|
|
|
<sect1 id="ch-pkgmngt-createfiles">
|
|
|
|
|
2019-04-11 09:40:50 +02:00
|
|
|
<title>Creating Essential Files</title>
|
|
|
|
|
2015-01-18 17:58:24 +01:00
|
|
|
<para>No file?</para>
|
|
|
|
|
|
|
|
</sect1>
|
|
|
|
|
|
|
|
<!-- Last but not least : Final instructions for installing the
|
|
|
|
package manager at the end of chapter 6. Again, the scriptlet file name is
|
|
|
|
taken from the dbhtml instruction, with digits added before and .html cut
|
|
|
|
and the tarball name is formed from this name + version. So the file
|
|
|
|
here _must_ be the same as in chapter 5. If rendering in html, both
|
|
|
|
sets of instructions end up in the same file, which is usually not a problem.
|
|
|
|
-->
|
|
|
|
<sect1 id="ch-system-libarchive" role="wrap">
|
|
|
|
<?dbhtml filename="libarchive.html"?>
|
2019-04-11 09:40:50 +02:00
|
|
|
|
|
|
|
<sect1info condition="script">
|
|
|
|
<productname>libarchive</productname>
|
|
|
|
<productnumber>&libarchive-version;</productnumber>
|
|
|
|
<address>&libarchive-url;</address>
|
|
|
|
</sect1info>
|
|
|
|
|
|
|
|
<title>Libarchive-&libarchive-version;</title>
|
|
|
|
|
2015-01-18 17:58:24 +01:00
|
|
|
<sect2 role="installation">
|
2019-04-11 09:40:50 +02:00
|
|
|
<title/>
|
2015-01-18 17:58:24 +01:00
|
|
|
<screen><userinput remap="configure">./configure --prefix=/usr \
|
|
|
|
--disable-static</userinput></screen>
|
|
|
|
<screen><userinput remap="make">make</userinput></screen>
|
|
|
|
<screen><userinput remap="install">make DESTDIR=$PKG_DEST install</userinput></screen>
|
|
|
|
</sect2>
|
|
|
|
|
|
|
|
</sect1>
|
|
|
|
<sect1 id="ch-system-curl" role="wrap">
|
|
|
|
<?dbhtml filename="curl.html"?>
|
2019-04-11 09:40:50 +02:00
|
|
|
|
|
|
|
<sect1info condition="script">
|
|
|
|
<productname>curl</productname>
|
|
|
|
<productnumber>&curl-version;</productnumber>
|
|
|
|
<address>&curl-url;</address>
|
|
|
|
</sect1info>
|
|
|
|
|
|
|
|
<title>Curl-&curl-version;</title>
|
|
|
|
|
2015-01-18 17:58:24 +01:00
|
|
|
<sect2 role="installation">
|
2019-04-11 09:40:50 +02:00
|
|
|
<title/>
|
2015-01-18 17:58:24 +01:00
|
|
|
<screen><userinput remap="configure">./configure --prefix=/usr \
|
|
|
|
--disable-static \
|
|
|
|
--enable-threaded-resolver</userinput></screen>
|
|
|
|
<screen><userinput remap="make">make</userinput></screen>
|
|
|
|
<screen><userinput remap="install">make DESTDIR=$PKG_DEST install
|
|
|
|
find docs \( -name "Makefile*" -o -name "*.1" -o -name "*.3" \) -exec rm {} \;
|
2019-04-11 09:40:50 +02:00
|
|
|
install -v -d -m755 $PKG_DEST/usr/share/doc/curl-&curl-version;
|
|
|
|
cp -v -R docs/* $PKG_DEST/usr/share/doc/curl-&curl-version;</userinput></screen>
|
2015-01-18 17:58:24 +01:00
|
|
|
</sect2>
|
|
|
|
|
|
|
|
</sect1>
|
|
|
|
<sect1 id="ch-system-pkgmngt" role="wrap">
|
|
|
|
<?dbhtml filename="pacman.html"?>
|
|
|
|
|
2019-04-11 09:40:50 +02:00
|
|
|
<sect1info condition="script">
|
|
|
|
<productname>pacman</productname>
|
|
|
|
<productnumber>&pacman-version;</productnumber>
|
|
|
|
<address>&pacman-url;</address>
|
|
|
|
</sect1info>
|
|
|
|
|
|
|
|
<title>Pacman-&pacman-version;</title>
|
|
|
|
|
2015-01-18 17:58:24 +01:00
|
|
|
<sect2 role="installation">
|
2019-04-11 09:40:50 +02:00
|
|
|
<title/>
|
2015-01-18 17:58:24 +01:00
|
|
|
|
|
|
|
<screen><userinput remap="configure">./configure --prefix=/usr \
|
|
|
|
--sysconfdir=/etc \
|
|
|
|
--localstatedir=/var</userinput></screen>
|
|
|
|
|
|
|
|
<screen><userinput remap="make">make</userinput></screen>
|
|
|
|
|
|
|
|
<!-- Those instructions are executed with PKG_DEST set. They are not processed
|
|
|
|
in any way to add $PKG_DEST at some place, and the PKG_DEST directory is not
|
|
|
|
populated before, so it is basically empty. You have thus to create any directory
|
|
|
|
needed in $PKG_DEST and not otherwise created by the make install command. -->
|
|
|
|
<screen><userinput remap="install">make DESTDIR=$PKG_DEST install</userinput></screen>
|
|
|
|
|
|
|
|
<screen><userinput>sed -e 's/\([^!]\)strip/\1!strip/' \
|
|
|
|
-e 's/\([^!]\)zipman/\1!zipman/' \
|
|
|
|
-i /etc/makepkg.conf
|
|
|
|
cat >> /etc/makepkg.conf << EOF
|
|
|
|
BUILDDIR=/sources
|
|
|
|
PKGDEST=/var/lib/packages
|
|
|
|
PACKAGER="Pierre Labastie <lnimbus@club-internet.fr<"
|
|
|
|
EOF
|
|
|
|
cat >> /etc/pacman.conf << EOF
|
|
|
|
DBPath = /var/lib/pacman/
|
|
|
|
CacheDir = /var/cache/pacman/pkg/
|
|
|
|
LogFile = /var/log/pacman.log
|
|
|
|
SigLevel = Never
|
|
|
|
EOF</userinput></screen>
|
|
|
|
|
|
|
|
</sect2>
|
|
|
|
|
|
|
|
</sect1>
|
|
|
|
</article>
|