glfs/general/prog/gc.xml

179 lines
5.8 KiB
XML
Raw Normal View History

<?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;
<!ENTITY gc-download-http
"http://www.hpl.hp.com/personal/Hans_Boehm/gc/gc_source/gc-&gc-version;.tar.gz">
<!ENTITY gc-download-ftp " ">
<!ENTITY gc-md5sum "edd99c64174a1f3b10a474b3e4c74634">
<!ENTITY gc-size "1.2 MB">
<!ENTITY gc-buildsize "12 MB">
<!ENTITY gc-time "0.3 SBU">
]>
<sect1 id="gc" xreflabel="GC-&gc-version;">
<?dbhtml filename="gc.html"?>
<sect1info>
<othername>$LastChangedBy$</othername>
<date>$Date$</date>
</sect1info>
<title>GC-&gc-version;</title>
<indexterm zone="gc">
<primary sortas="a-GC">GC</primary>
</indexterm>
<sect2 role="package">
<title>Introduction to GC</title>
<para>
The <application>GC</application> package contains the Boehm-Demers-Weiser
conservative garbage collector, which can be used as a garbage collecting
replacement for the C malloc function or C++ new operator. It allows you
to allocate memory basically as you normally would, without explicitly
deallocating memory that is no longer useful. The collector automatically
recycles memory when it determines that it can no longer be otherwise
accessed. The collector is also used by a number of programming language
implementations that either use C as intermediate code, want to facilitate
easier interoperation with C libraries, or just prefer the simple
collector interface. Alternatively, the garbage collector may be used as a
leak detector for C or C++ programs, though that is not its primary goal.
</para>
&lfs72_checked;
<bridgehead renderas="sect3">Package Information</bridgehead>
<itemizedlist spacing="compact">
<listitem>
<para>Download (HTTP): <ulink url="&gc-download-http;"/></para>
</listitem>
<listitem>
<para>Download (FTP): <ulink url="&gc-download-ftp;"/></para>
</listitem>
<listitem>
<para>Download MD5 sum: &gc-md5sum;</para>
</listitem>
<listitem>
<para>Download size: &gc-size;</para>
</listitem>
<listitem>
<para>Estimated disk space required: &gc-buildsize;</para>
</listitem>
<listitem>
<para>Estimated build time: &gc-time;</para>
</listitem>
</itemizedlist>
<bridgehead renderas="sect4">Optional</bridgehead>
<para role="optional">
<xref linkend="libatomic_ops"/> (Gc contains a copy of
Libatomic_ops-&gc-version; which it will compile and statically link if
configure doesn't find Libatomic_ops installed on your system).
</para>
<para condition="html" role="usernotes">
User Notes: <ulink url="&blfs-wiki;/gc"/>
</para>
</sect2>
<sect2 role="installation">
<title>Installation of GC</title>
<para>
Install <application>GC</application> by running the following commands:
</para>
<screen><userinput>sed -i 's#pkgdata#doc#' doc/doc.am &amp;&amp; autoreconf &amp;&amp;
./configure --prefix=/usr \
--enable-cplusplus \
--disable-static \
--docdir=/usr/share/doc/gc-&gc-version; &amp;&amp;
make</userinput></screen>
<para>To test the results, issue: <command>make check</command>.</para>
<para>
Now, as the <systemitem class="username">root</systemitem> user:
</para>
<screen role="root"><userinput>make install &amp;&amp;
install -v -m644 doc/gc.man /usr/share/man/man3/gc_malloc.3 &amp;&amp;
ln -sfv gc_malloc.3 /usr/share/man/man3/gc.3 </userinput></screen>
</sect2>
<sect2 role="commands">
<title>Command Explanations</title>
<para>
<command>sed -i 's#pkgdata#doc#' doc/doc.am</command>,
<command>autoreconf</command> and
<option>--docdir=/usr/share/doc/gc-&gc-version;</option>: These commands
allow us to install the documentation in a versioned directory.
</para>
<xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
href="../../xincludes/static-libraries.xml"/>
<para>
<parameter>--enable-cplusplus</parameter>: This parameter enables the
building and installing the C++ library along with the standard C library.
</para>
</sect2>
<sect2 role="content">
<title>Contents</title>
<segmentedlist>
<segtitle>Installed Libraries</segtitle>
<segtitle>Installed Directories</segtitle>
<seglistitem>
<seg>
libcord.so,
libgc.so and
libgccpp.so
</seg>
<seg>
/usr/include/gc and
/usr/share/doc/gc
</seg>
</seglistitem>
</segmentedlist>
<variablelist>
<bridgehead renderas="sect3">Short Descriptions</bridgehead>
<?dbfo list-presentation="list"?>
<?dbhtml list-presentation="table"?>
<varlistentry id="libgc">
<term><filename class='libraryfile'>libgc.so</filename></term>
<listitem>
<para>
contains a C interface to the conservative garbage collector,
primarily designed to replace the C malloc function.
</para>
<indexterm zone="gc libgc">
<primary sortas="c-libgc">libgc.so</primary>
</indexterm>
</listitem>
</varlistentry>
<varlistentry id="libgccpp">
<term><filename class='libraryfile'>libgccpp.so</filename></term>
<listitem>
<para>
contains a C++ interface to the conservative garbage collector.
</para>
<indexterm zone="gc libgccpp">
<primary sortas="c-libgccpp">libgccpp.so</primary>
</indexterm>
</listitem>
</varlistentry>
</variablelist>
</sect2>
</sect1>