2010-01-07 10:31:24 +01:00
|
|
|
<?xml version="1.0"?>
|
2012-04-23 03:45:08 +02:00
|
|
|
<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
|
|
|
|
"http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
|
2010-01-07 10:31:24 +01:00
|
|
|
]>
|
2002-01-18 00:06:12 +01:00
|
|
|
<refentry id="glib-compiling" revision="17 Jan 2002">
|
|
|
|
<refmeta>
|
|
|
|
<refentrytitle>Compiling GLib Applications</refentrytitle>
|
|
|
|
<manvolnum>3</manvolnum>
|
|
|
|
<refmiscinfo>GLib Library</refmiscinfo>
|
|
|
|
</refmeta>
|
|
|
|
|
|
|
|
<refnamediv>
|
|
|
|
<refname>Compiling GLib Applications</refname>
|
|
|
|
<refpurpose>
|
|
|
|
How to compile your GLib application
|
|
|
|
</refpurpose>
|
|
|
|
</refnamediv>
|
|
|
|
|
|
|
|
<refsect1>
|
|
|
|
<title>Compiling GLib Applications on UNIX</title>
|
|
|
|
|
|
|
|
<para>
|
2011-10-06 04:31:17 +02:00
|
|
|
To compile a GLib application, you need to tell the compiler where to
|
2002-01-18 00:06:12 +01:00
|
|
|
find the GLib header files and libraries. This is done with the
|
|
|
|
<application>pkg-config</application> utility.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
The following interactive shell session demonstrates how
|
2005-05-20 16:33:21 +02:00
|
|
|
<application>pkg-config</application> is used (the actual output on
|
|
|
|
your system may be different):
|
2002-01-18 00:06:12 +01:00
|
|
|
<programlisting>
|
|
|
|
$ pkg-config --cflags glib-2.0
|
2011-10-06 04:31:17 +02:00
|
|
|
-I/usr/include/glib-2.0 -I/usr/lib/glib-2.0/include
|
2002-01-18 00:06:12 +01:00
|
|
|
$ pkg-config --libs glib-2.0
|
2011-10-06 04:31:17 +02:00
|
|
|
-L/usr/lib -lm -lglib-2.0
|
2002-01-18 00:06:12 +01:00
|
|
|
</programlisting>
|
|
|
|
</para>
|
|
|
|
<para>
|
2011-10-06 04:31:17 +02:00
|
|
|
See the <ulink url="http://www.freedesktop.org/wiki/Software/pkg-config">pkg-config website</ulink>
|
|
|
|
for more information about <application>pkg-config</application>.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
If your application uses or <structname>GObject</structname>
|
|
|
|
features, it must be compiled and linked with the options returned
|
|
|
|
by the following <application>pkg-config</application> invocation:
|
2002-01-18 00:06:12 +01:00
|
|
|
<programlisting>
|
|
|
|
$ pkg-config --cflags --libs gobject-2.0
|
|
|
|
</programlisting>
|
|
|
|
</para>
|
|
|
|
<para>
|
2011-10-06 04:31:17 +02:00
|
|
|
If your application uses modules, it must be compiled and linked
|
|
|
|
with the options returned by one of the following
|
|
|
|
<application>pkg-config</application> invocations:
|
2005-10-05 22:45:50 +02:00
|
|
|
<programlisting>
|
2011-10-06 04:31:17 +02:00
|
|
|
$ pkg-config --cflags --libs gmodule-no-export-2.0
|
|
|
|
$ pkg-config --cflags --libs gmodule-2.0
|
2005-10-05 22:45:50 +02:00
|
|
|
</programlisting>
|
2011-10-06 04:31:17 +02:00
|
|
|
The difference between the two is that gmodule-2.0 adds
|
|
|
|
<option>--export-dynamic</option> to the linker flags,
|
|
|
|
which is often not needed.
|
2005-10-05 22:45:50 +02:00
|
|
|
</para>
|
|
|
|
<para>
|
2002-01-18 00:06:12 +01:00
|
|
|
The simplest way to compile a program is to use the "backticks"
|
|
|
|
feature of the shell. If you enclose a command in backticks
|
2011-10-06 04:31:17 +02:00
|
|
|
(<emphasis>not single quotes</emphasis>), then its output will
|
|
|
|
be substituted into the command line before execution. So to
|
|
|
|
compile a GLib Hello, World, you would type the following:
|
2002-01-18 00:06:12 +01:00
|
|
|
<programlisting>
|
2012-08-09 23:01:29 +02:00
|
|
|
$ cc hello.c `pkg-config --cflags --libs glib-2.0` -o hello
|
2002-01-18 00:06:12 +01:00
|
|
|
</programlisting>
|
|
|
|
</para>
|
2012-08-09 23:01:29 +02:00
|
|
|
<note><para>
|
|
|
|
Note that the name of the file must come before the other options
|
|
|
|
(such as <emphasis>pkg-config</emphasis>), or else you may get an
|
|
|
|
error from the linker.
|
|
|
|
</para></note>
|
2002-01-18 00:06:12 +01:00
|
|
|
|
2006-08-28 19:20:02 +02:00
|
|
|
<para>
|
2011-10-12 05:50:34 +02:00
|
|
|
Deprecated GLib functions are annotated to make the compiler
|
|
|
|
emit warnings when they are used (e.g. with gcc, you need to use
|
|
|
|
the -Wdeprecated-declarations option). If these warnings are
|
|
|
|
problematic, they can be turned off by defining the preprocessor
|
2012-02-27 06:18:47 +01:00
|
|
|
symbol %GLIB_DISABLE_DEPRECATION_WARNINGS by using the commandline
|
2011-10-12 05:50:34 +02:00
|
|
|
option <literal>-DGLIB_DISABLE_DEPRECATION_WARNINGS</literal>
|
|
|
|
</para>
|
2012-02-20 17:20:15 +01:00
|
|
|
|
|
|
|
<para>
|
|
|
|
GLib deprecation annotations are versioned; by defining the
|
|
|
|
macros %GLIB_VERSION_MIN_REQUIRED and %GLIB_VERSION_MAX_ALLOWED,
|
|
|
|
you can specify the range of GLib versions whose API you want
|
|
|
|
to use. APIs that were deprecated before or introduced after
|
|
|
|
this range will trigger compiler warnings.
|
|
|
|
</para>
|
|
|
|
|
2011-10-12 05:50:34 +02:00
|
|
|
<para>
|
2011-11-03 05:05:29 +01:00
|
|
|
The older deprecation mechanism of hiding deprecated interfaces
|
|
|
|
entirely from the compiler by using the preprocessor symbol
|
|
|
|
G_DISABLE_DEPRECATED is still used for deprecated macros,
|
|
|
|
enumeration values, etc. To detect uses of these in your code,
|
|
|
|
use the commandline option <literal>-DG_DISABLE_DEPRECATED</literal>.
|
2006-08-28 19:20:02 +02:00
|
|
|
</para>
|
|
|
|
|
2008-05-27 18:46:43 +02:00
|
|
|
<para>
|
2011-10-06 04:31:17 +02:00
|
|
|
The recommended way of using GLib has always been to only include the
|
|
|
|
toplevel headers <filename>glib.h</filename>,
|
2008-05-27 18:46:43 +02:00
|
|
|
<filename>glib-object.h</filename>, <filename>gio.h</filename>.
|
2011-11-03 05:05:29 +01:00
|
|
|
Starting with 2.32, GLib enforces this by generating an error
|
|
|
|
when individual headers are directly included.
|
|
|
|
</para>
|
|
|
|
|
|
|
|
<para>
|
2011-10-06 04:31:17 +02:00
|
|
|
Still, there are some exceptions; these headers have to be included
|
|
|
|
separately:
|
2010-03-12 20:37:04 +01:00
|
|
|
<filename>gmodule.h</filename>,
|
2011-10-06 04:31:17 +02:00
|
|
|
<filename>glib-unix.h</filename>,
|
|
|
|
<filename>glib/gi18n-lib.h</filename> or
|
|
|
|
<filename>glib/gi18n.h</filename> (see
|
2010-03-12 20:37:04 +01:00
|
|
|
the <link linkend="glib-I18N">Internationalization section</link>),
|
2011-10-06 04:31:17 +02:00
|
|
|
<filename>glib/gprintf.h</filename> and
|
|
|
|
<filename>glib/gstdio.h</filename>
|
2010-03-12 20:37:04 +01:00
|
|
|
(we don't want to pull in all of stdio).
|
|
|
|
</para>
|
|
|
|
|
2002-01-18 00:06:12 +01:00
|
|
|
</refsect1>
|
|
|
|
|
|
|
|
</refentry>
|