1998-12-19 03:13:34 +01:00
|
|
|
dnl ***********************************
|
|
|
|
dnl *** include special GLib macros ***
|
|
|
|
dnl ***********************************
|
|
|
|
builtin(include, acglib.m4)dnl
|
|
|
|
|
1999-01-21 04:14:53 +01:00
|
|
|
# require autoconf 2.13
|
1999-01-21 15:38:14 +01:00
|
|
|
AC_PREREQ(2.13)
|
1999-01-21 04:14:53 +01:00
|
|
|
|
1998-06-11 01:21:14 +02:00
|
|
|
# Process this file with autoconf to produce a configure script.
|
|
|
|
AC_INIT(glist.c)
|
|
|
|
|
|
|
|
# Save this value here, since automake will set cflags later
|
|
|
|
cflags_set=${CFLAGS+set}
|
|
|
|
|
1998-12-19 04:44:30 +01:00
|
|
|
# we rewrite this file
|
|
|
|
rm -f glibconfig-sysdefs.h
|
|
|
|
|
2000-12-08 23:48:45 +01:00
|
|
|
GLIB_AC_DIVERT_BEFORE_HELP([
|
1999-02-15 07:50:15 +01:00
|
|
|
#
|
2000-12-08 23:48:45 +01:00
|
|
|
# The following version number definitions apply to GLib, GModule, GObject
|
|
|
|
# and GThread as a whole, so if changes occoured in any of them, they are all
|
1998-09-21 04:32:30 +02:00
|
|
|
# treated with the same interface and binary age.
|
|
|
|
#
|
1998-06-11 01:21:14 +02:00
|
|
|
# Making releases:
|
|
|
|
# GLIB_MICRO_VERSION += 1;
|
|
|
|
# GLIB_INTERFACE_AGE += 1;
|
|
|
|
# GLIB_BINARY_AGE += 1;
|
|
|
|
# if any functions have been added, set GLIB_INTERFACE_AGE to 0.
|
|
|
|
# if backwards compatibility has been broken,
|
1999-07-24 20:50:58 +02:00
|
|
|
# set GLIB_BINARY_AGE _and_ GLIB_INTERFACE_AGE to 0.
|
1998-06-11 01:21:14 +02:00
|
|
|
#
|
|
|
|
GLIB_MAJOR_VERSION=1
|
1999-02-27 01:25:58 +01:00
|
|
|
GLIB_MINOR_VERSION=3
|
2000-11-13 20:01:28 +01:00
|
|
|
GLIB_MICRO_VERSION=2
|
1999-02-16 22:20:13 +01:00
|
|
|
GLIB_INTERFACE_AGE=0
|
|
|
|
GLIB_BINARY_AGE=0
|
1998-06-11 01:21:14 +02:00
|
|
|
GLIB_VERSION=$GLIB_MAJOR_VERSION.$GLIB_MINOR_VERSION.$GLIB_MICRO_VERSION
|
2000-10-09 23:06:01 +02:00
|
|
|
])dnl
|
1999-02-15 07:50:15 +01:00
|
|
|
|
1999-05-06 19:33:15 +02:00
|
|
|
AC_SUBST(GLIB_MAJOR_VERSION)
|
|
|
|
AC_SUBST(GLIB_MINOR_VERSION)
|
1999-07-24 20:50:58 +02:00
|
|
|
AC_SUBST(GLIB_MICRO_VERSION)
|
1998-06-11 01:21:14 +02:00
|
|
|
AC_SUBST(GLIB_VERSION)
|
1999-05-06 19:33:15 +02:00
|
|
|
AC_SUBST(GLIB_INTERFACE_AGE)
|
|
|
|
AC_SUBST(GLIB_BINARY_AGE)
|
1998-06-11 01:21:14 +02:00
|
|
|
|
|
|
|
# libtool versioning
|
|
|
|
LT_RELEASE=$GLIB_MAJOR_VERSION.$GLIB_MINOR_VERSION
|
|
|
|
LT_CURRENT=`expr $GLIB_MICRO_VERSION - $GLIB_INTERFACE_AGE`
|
|
|
|
LT_REVISION=$GLIB_INTERFACE_AGE
|
|
|
|
LT_AGE=`expr $GLIB_BINARY_AGE - $GLIB_INTERFACE_AGE`
|
|
|
|
AC_SUBST(LT_RELEASE)
|
|
|
|
AC_SUBST(LT_CURRENT)
|
|
|
|
AC_SUBST(LT_REVISION)
|
|
|
|
AC_SUBST(LT_AGE)
|
|
|
|
|
|
|
|
VERSION=$GLIB_VERSION
|
|
|
|
PACKAGE=glib
|
|
|
|
|
|
|
|
AM_INIT_AUTOMAKE($PACKAGE, $VERSION, no-define)
|
|
|
|
|
|
|
|
# Specify a configuration file
|
1998-11-01 02:32:59 +01:00
|
|
|
AM_CONFIG_HEADER(config.h)
|
1998-06-11 01:21:14 +02:00
|
|
|
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_DEFINE_UNQUOTED(GLIB_MAJOR_VERSION, $GLIB_MAJOR_VERSION,
|
|
|
|
[Define to the GLIB major version])
|
|
|
|
AC_DEFINE_UNQUOTED(GLIB_MINOR_VERSION, $GLIB_MINOR_VERSION,
|
|
|
|
[Define to the GLIB minor version])
|
|
|
|
AC_DEFINE_UNQUOTED(GLIB_MICRO_VERSION, $GLIB_MICRO_VERSION,
|
|
|
|
[Define to the GLIB micro version])
|
|
|
|
AC_DEFINE_UNQUOTED(GLIB_INTERFACE_AGE, $GLIB_INTERFACE_AGE,
|
|
|
|
[Define to the GLIB interface age])
|
|
|
|
AC_DEFINE_UNQUOTED(GLIB_BINARY_AGE, $GLIB_BINARY_AGE,
|
|
|
|
[Define to the GLIB binary age])
|
1998-06-11 01:21:14 +02:00
|
|
|
|
|
|
|
dnl Initialize maintainer mode
|
|
|
|
AM_MAINTAINER_MODE
|
|
|
|
|
|
|
|
AC_CANONICAL_HOST
|
|
|
|
|
1999-05-08 09:40:44 +02:00
|
|
|
AC_MSG_CHECKING(for the BeOS)
|
|
|
|
case $host in
|
|
|
|
*-*-beos*)
|
|
|
|
glib_native_beos="yes"
|
|
|
|
;;
|
1999-10-04 04:32:50 +02:00
|
|
|
*)
|
1999-05-08 09:40:44 +02:00
|
|
|
glib_native_beos="no"
|
|
|
|
;;
|
|
|
|
esac
|
1999-10-04 04:32:50 +02:00
|
|
|
AC_MSG_RESULT([$glib_native_beos])
|
1999-05-08 09:40:44 +02:00
|
|
|
|
1999-02-15 07:50:15 +01:00
|
|
|
dnl
|
2000-10-09 23:06:01 +02:00
|
|
|
|
2000-12-08 23:48:45 +01:00
|
|
|
GLIB_AC_DIVERT_BEFORE_HELP([
|
2000-10-09 23:06:01 +02:00
|
|
|
# figure debugging default, prior to $ac_help setup
|
2000-12-08 23:48:45 +01:00
|
|
|
case $GLIB_MINOR_VERSION in
|
|
|
|
*[[13579]]) debug_default=yes ;;
|
|
|
|
*) debug_default=minimum ;;
|
|
|
|
esac[]dnl
|
2000-10-09 23:06:01 +02:00
|
|
|
])
|
1999-02-15 07:50:15 +01:00
|
|
|
|
|
|
|
dnl declare --enable-* args and collect ac_help strings
|
|
|
|
AC_ARG_ENABLE(debug, [ --enable-debug=[no/minimum/yes] turn on debugging [default=$debug_default]],,enable_debug=$debug_default)
|
1999-08-15 02:58:48 +02:00
|
|
|
AC_ARG_ENABLE(msg-prefix, [ --enable-msg-prefix turn on program name and PID prefixing of messages and warnings],,enable_msg_prefix=no)
|
Add configure test for garbage collector friendliness for GLib. If
2000-04-17 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in, acconfig.h: Add configure test for garbage
collector friendliness for GLib. If enabled, ENABLE_GC_FRIENDLY
will be defined.
* garray.c, ghash.c, glist.c, gmain.c, gmem.c, gnode.c, gqueue.c,
gslist.c, gtree.c: If ENABLE_GC_FRIENDLY is defined, NULLify all
memory released by the user, but cached by GLib. This lets a
garbage collector have a more correct view of the actually used
memory.
2000-04-17 15:23:27 +02:00
|
|
|
AC_ARG_ENABLE(gc_friendly, [ --enable-gc-friendly turn on garbage collector friendliness [default=no]],,enable_gc_friendly=no)
|
2000-12-19 10:35:44 +01:00
|
|
|
AC_ARG_ENABLE(mem_pools, [ --disable-mem-pools disable all glib memory pools],,disable_mem_pools=no)
|
1998-06-11 01:21:14 +02:00
|
|
|
AC_ARG_ENABLE(ansi, [ --enable-ansi turn on strict ansi [default=no]],
|
|
|
|
, enable_ansi=no)
|
1998-12-16 06:38:35 +01:00
|
|
|
AC_ARG_ENABLE(threads, [ --enable-threads turn on basic thread support [default=yes]
|
|
|
|
([=no] will override --with-threads)],,enable_threads=yes)
|
fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000 Tim Janik <timj@gtk.org>
* gboxed.c: fixed dealing with collection/lcopy of NULL values.
* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
convenience macro.
* Makefile.am: cleanups, marshaller generation rules.
* gmarshal.[hc]: new files with GRuntime standard marshallers.
* glib-genmarshal.c: fix log domain, support gruntime standard
marshallers, suport G_TYPE_PARAM, come with extern "C" and
#include gmarshal.h.
* glib-genmarshal.1: reflect glib-genmarshal.c updates.
* gobject.[hc]: implement object constructor. rework parameter
changed notification queueing, we support queue freezes now and
don't dispatch from an idle handler anymore.
parameter->property rename hassle.
implemented ::properties_changed and ::notify::* signals for
property change notification (the later supports property names
as details). added signal connection and named data properties.
(g_signal_connect_object): new function to setup while_alive
connections.
(g_object_class_install_property): sink properties now, since they
are initially floating.
(g_object_steal_data):
(g_object_set_data_full):
(g_object_set_data):
(g_object_get_data): set/get data by using g_datalist_*() functions
directly.
(g_object_queue_param_changed): nuked.
(g_object_freeze_notify): start queueing of property changes (freeze/
thaw calls stack).
(g_object_notify): announce changes of a certain property directly.
(g_object_thaw_notify): process queue of property changes, therefore
emitting GObject::notify::detail with detail being the changed
properties names.
(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
G_WARN_INVALID_PARAM_ID().
* gparam.[hc]: param specs are now initially floating and need to be
sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
required by GObjectClass.constructor().
* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
and G_TYPE_CCALLBACK respectively.
* gsignal.[hc]: cleanups.
(signal_id_lookup): after walking the anchestry, try interfaces as well.
(g_signal_new): new function to create signals from varargs type list.
(g_signal_connect_closure): closure connection variant that works from
signal name+detail.
(g_signal_connect_data): c handler connection variant that works from
signal name+detail.
(g_signal_emit_valist): emit signal for an instance with paraneters
collected from a va_list.
(g_signal_emit): emit signal, taking parameters from varargs list.
(g_signal_emit_by_name): same as g_signal_emit, working from
signal name+detail.
(signal_emit_R): return whether return_value needs to be altered.
* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
the points that need to reflect the upcoming rename.
melt g_type_conforms_to() functionality into g_type_is_a(), as that
is what we really want (liskov substitution principle).
assorted changes to other files due to conforms_to->is_a.
* gvalue.[hc]: implemented g_value_set_instance() that sets a value
from an instantiatable type via the value_table's collect_value()
function (based on an idea from James Henstridge <james@daa.com.au>).
cleanups/fixes.
* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
2000-12-12 08:32:00 +01:00
|
|
|
AC_ARG_ENABLE(rebuilds, [ --disable-rebuilds disable all source autogeneration rules],,enable_rebuilds=yes)
|
1998-12-16 06:38:35 +01:00
|
|
|
|
|
|
|
if test "x$enable_threads" != "xyes"; then
|
|
|
|
enable_threads=no
|
|
|
|
fi
|
1998-06-11 01:21:14 +02:00
|
|
|
|
2000-12-29 03:16:51 +01:00
|
|
|
AC_DEFINE_UNQUOTED(G_COMPILED_WITH_DEBUGGING, "${enable_debug}",
|
|
|
|
[Whether glib was compiled with debugging enabled])
|
Add configure test for garbage collector friendliness for GLib. If
2000-04-17 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in, acconfig.h: Add configure test for garbage
collector friendliness for GLib. If enabled, ENABLE_GC_FRIENDLY
will be defined.
* garray.c, ghash.c, glist.c, gmain.c, gmem.c, gnode.c, gqueue.c,
gslist.c, gtree.c: If ENABLE_GC_FRIENDLY is defined, NULLify all
memory released by the user, but cached by GLib. This lets a
garbage collector have a more correct view of the actually used
memory.
2000-04-17 15:23:27 +02:00
|
|
|
|
|
|
|
AC_MSG_CHECKING(whether to enable garbage collector friendliness)
|
|
|
|
if test "x$enable_gc_friendly" = "xyes"; then
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_DEFINE(ENABLE_GC_FRIENDLY, 1, [Whether to enable GC friendliness])
|
Add configure test for garbage collector friendliness for GLib. If
2000-04-17 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in, acconfig.h: Add configure test for garbage
collector friendliness for GLib. If enabled, ENABLE_GC_FRIENDLY
will be defined.
* garray.c, ghash.c, glist.c, gmain.c, gmem.c, gnode.c, gqueue.c,
gslist.c, gtree.c: If ENABLE_GC_FRIENDLY is defined, NULLify all
memory released by the user, but cached by GLib. This lets a
garbage collector have a more correct view of the actually used
memory.
2000-04-17 15:23:27 +02:00
|
|
|
AC_SUBST(ENABLE_GC_FRIENDLY)
|
|
|
|
AC_MSG_RESULT(yes)
|
|
|
|
else
|
|
|
|
AC_MSG_RESULT(no)
|
|
|
|
fi
|
2000-02-13 08:18:23 +01:00
|
|
|
|
2000-12-19 10:35:44 +01:00
|
|
|
AC_MSG_CHECKING(whether to disable memory pools)
|
|
|
|
if test "x$disable_mem_pools" = "xno"; then
|
|
|
|
AC_MSG_RESULT(no)
|
|
|
|
else
|
|
|
|
AC_DEFINE(DISABLE_MEM_POOLS, 1, [Whether to disable memory pools])
|
|
|
|
AC_SUBST(DISABLE_MEM_POOLS)
|
|
|
|
AC_MSG_RESULT(yes)
|
|
|
|
fi
|
|
|
|
|
2000-02-13 08:18:23 +01:00
|
|
|
if test "x$enable_msg_prefix" = "xyes"; then
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_DEFINE_UNQUOTED(G_ENABLE_MSG_PREFIX, 1,
|
|
|
|
[Enable prefixing of error messages with program names])
|
2000-02-13 08:18:23 +01:00
|
|
|
fi
|
|
|
|
|
2001-01-16 03:24:24 +01:00
|
|
|
dnl Checks for programs.
|
2000-02-13 08:18:23 +01:00
|
|
|
AC_PROG_CC
|
2001-01-16 03:24:24 +01:00
|
|
|
|
2000-02-13 08:18:23 +01:00
|
|
|
AM_PROG_CC_STDC
|
|
|
|
AC_PROG_INSTALL
|
|
|
|
|
2001-01-05 22:22:47 +01:00
|
|
|
if test "x$enable_debug" = "xyes"; then
|
|
|
|
if test x$cflags_set != xset ; then
|
|
|
|
case " $CFLAGS " in
|
|
|
|
*[[\ \ ]]-g[[\ \ ]]*) ;;
|
|
|
|
*) CFLAGS="$CFLAGS -g" ;;
|
|
|
|
esac
|
|
|
|
fi
|
|
|
|
|
|
|
|
GLIB_DEBUG_FLAGS="-DG_ENABLE_DEBUG"
|
|
|
|
else
|
|
|
|
if test "x$enable_debug" = "xno"; then
|
|
|
|
GLIB_DEBUG_FLAGS="-DG_DISABLE_ASSERT -DG_DISABLE_CHECKS"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000 Tim Janik <timj@gtk.org>
* gboxed.c: fixed dealing with collection/lcopy of NULL values.
* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
convenience macro.
* Makefile.am: cleanups, marshaller generation rules.
* gmarshal.[hc]: new files with GRuntime standard marshallers.
* glib-genmarshal.c: fix log domain, support gruntime standard
marshallers, suport G_TYPE_PARAM, come with extern "C" and
#include gmarshal.h.
* glib-genmarshal.1: reflect glib-genmarshal.c updates.
* gobject.[hc]: implement object constructor. rework parameter
changed notification queueing, we support queue freezes now and
don't dispatch from an idle handler anymore.
parameter->property rename hassle.
implemented ::properties_changed and ::notify::* signals for
property change notification (the later supports property names
as details). added signal connection and named data properties.
(g_signal_connect_object): new function to setup while_alive
connections.
(g_object_class_install_property): sink properties now, since they
are initially floating.
(g_object_steal_data):
(g_object_set_data_full):
(g_object_set_data):
(g_object_get_data): set/get data by using g_datalist_*() functions
directly.
(g_object_queue_param_changed): nuked.
(g_object_freeze_notify): start queueing of property changes (freeze/
thaw calls stack).
(g_object_notify): announce changes of a certain property directly.
(g_object_thaw_notify): process queue of property changes, therefore
emitting GObject::notify::detail with detail being the changed
properties names.
(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
G_WARN_INVALID_PARAM_ID().
* gparam.[hc]: param specs are now initially floating and need to be
sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
required by GObjectClass.constructor().
* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
and G_TYPE_CCALLBACK respectively.
* gsignal.[hc]: cleanups.
(signal_id_lookup): after walking the anchestry, try interfaces as well.
(g_signal_new): new function to create signals from varargs type list.
(g_signal_connect_closure): closure connection variant that works from
signal name+detail.
(g_signal_connect_data): c handler connection variant that works from
signal name+detail.
(g_signal_emit_valist): emit signal for an instance with paraneters
collected from a va_list.
(g_signal_emit): emit signal, taking parameters from varargs list.
(g_signal_emit_by_name): same as g_signal_emit, working from
signal name+detail.
(signal_emit_R): return whether return_value needs to be altered.
* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
the points that need to reflect the upcoming rename.
melt g_type_conforms_to() functionality into g_type_is_a(), as that
is what we really want (liskov substitution principle).
assorted changes to other files due to conforms_to->is_a.
* gvalue.[hc]: implemented g_value_set_instance() that sets a value
from an instantiatable type via the value_table's collect_value()
function (based on an idea from James Henstridge <james@daa.com.au>).
cleanups/fixes.
* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
2000-12-12 08:32:00 +01:00
|
|
|
# define a MAINT-like variable REBUILD which is set if Perl
|
|
|
|
# and awk are found, so autogenerated sources can be rebuilt
|
|
|
|
AC_PROG_AWK
|
|
|
|
AC_CHECK_PROGS(PERL, perl5 perl)
|
|
|
|
# We would like indent, but don't require it.
|
|
|
|
AC_CHECK_PROG(INDENT, indent, indent)
|
|
|
|
REBUILD=\#
|
|
|
|
if test "x$enable_rebuilds" = "xyes" && \
|
|
|
|
test -n "$PERL" && \
|
|
|
|
$PERL -e 'exit !($] >= 5.002)' > /dev/null 2>&1 && \
|
|
|
|
test -n "$AWK" ; then
|
|
|
|
REBUILD=
|
|
|
|
fi
|
|
|
|
AC_SUBST(REBUILD)
|
|
|
|
|
2001-01-16 03:24:24 +01:00
|
|
|
|
|
|
|
dnl
|
|
|
|
dnl gettext support
|
|
|
|
dnl
|
|
|
|
|
2001-02-17 15:49:40 +01:00
|
|
|
ALL_LINGUAS="no sl tr uk"
|
2001-01-16 03:24:24 +01:00
|
|
|
AM_GLIB_GNU_GETTEXT
|
|
|
|
LIBS="$LIBS $INTLLIBS"
|
|
|
|
|
|
|
|
GETTEXT_PACKAGE=glib20
|
|
|
|
AC_SUBST(GETTEXT_PACKAGE)
|
|
|
|
AC_DEFINE_UNQUOTED(GETTEXT_PACKAGE,"$GETTEXT_PACKAGE")
|
|
|
|
|
|
|
|
# AM_GLIB_GNU_GETTEXT above substs $DATADIRNAME
|
|
|
|
# this is the directory where the *.{mo,gmo} files are installed
|
|
|
|
GLIB_LOCALE_DIR="${prefix}/${DATADIRNAME}/locale"
|
|
|
|
AC_DEFINE_UNQUOTED(GLIB_LOCALE_DIR,"$GLIB_LOCALE_DIR")
|
|
|
|
|
|
|
|
|
2000-10-16 03:02:19 +02:00
|
|
|
dnl Initialize libtool
|
|
|
|
AM_PROG_LIBTOOL
|
|
|
|
|
2000-02-13 08:18:23 +01:00
|
|
|
if test "x$GCC" = "xyes"; then
|
|
|
|
case " $CFLAGS " in
|
2000-10-16 03:02:19 +02:00
|
|
|
*[[\ \ ]]-Wall[[\ \ ]]*) ;;
|
2000-02-13 08:18:23 +01:00
|
|
|
*) CFLAGS="$CFLAGS -Wall" ;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
if test "x$enable_ansi" = "xyes"; then
|
|
|
|
case " $CFLAGS " in
|
2000-10-16 03:02:19 +02:00
|
|
|
*[[\ \ ]]-ansi[[\ \ ]]*) ;;
|
2000-02-13 08:18:23 +01:00
|
|
|
*) CFLAGS="$CFLAGS -ansi" ;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
case " $CFLAGS " in
|
2000-10-16 03:02:19 +02:00
|
|
|
*[[\ \ ]]-pedantic[[\ \ ]]*) ;;
|
2000-02-13 08:18:23 +01:00
|
|
|
*) CFLAGS="$CFLAGS -pedantic" ;;
|
|
|
|
esac
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
dnl DU4 native cc currently needs -std1 for ANSI mode (instead of K&R)
|
|
|
|
AC_MSG_CHECKING([for extra flags to get ANSI library prototypes])
|
|
|
|
glib_save_LIBS=$LIBS
|
|
|
|
LIBS="$LIBS -lm"
|
|
|
|
AC_TRY_RUN([#include <math.h>
|
|
|
|
int main (void) { return (log(1) != log(1.)); }],
|
|
|
|
AC_MSG_RESULT(none needed),
|
|
|
|
glib_save_CFLAGS=$CFLAGS
|
|
|
|
CFLAGS="$CFLAGS -std1"
|
|
|
|
AC_TRY_RUN([#include <math.h>
|
|
|
|
int main (void) { return (log(1) != log(1.)); }],
|
|
|
|
AC_MSG_RESULT(-std1),
|
|
|
|
AC_MSG_RESULT()
|
|
|
|
CFLAGS=$glib_save_CFLAGS
|
|
|
|
AC_MSG_WARN(
|
|
|
|
[No ANSI prototypes found in library. (-std1 didn't work.)])
|
|
|
|
)
|
|
|
|
)
|
|
|
|
LIBS=$glib_save_LIBS
|
|
|
|
|
|
|
|
dnl NeXTStep cc seems to need this
|
|
|
|
AC_MSG_CHECKING([for extra flags for POSIX compliance])
|
|
|
|
AC_TRY_COMPILE([#include <dirent.h>], [DIR *dir;],
|
|
|
|
AC_MSG_RESULT(none needed),
|
|
|
|
glib_save_CFLAGS=$CFLAGS
|
|
|
|
CFLAGS="$CFLAGS -posix"
|
|
|
|
AC_TRY_COMPILE([#include <dirent.h>], [DIR *dir;],
|
|
|
|
AC_MSG_RESULT(-posix),
|
|
|
|
AC_MSG_RESULT()
|
|
|
|
CFLAGS=$glib_save_CFLAGS
|
|
|
|
AC_MSG_WARN([Could not determine POSIX flag. (-posix didn't work.)])))
|
|
|
|
|
|
|
|
# Checks for header files.
|
|
|
|
AC_HEADER_STDC
|
|
|
|
|
|
|
|
# Checks for library functions.
|
|
|
|
AC_FUNC_VPRINTF
|
|
|
|
|
2000-09-18 00:18:48 +02:00
|
|
|
AC_FUNC_ALLOCA
|
|
|
|
|
2000-02-13 08:18:23 +01:00
|
|
|
AC_CHECK_FUNCS(atexit on_exit)
|
|
|
|
|
|
|
|
AC_CHECK_SIZEOF(char)
|
|
|
|
AC_CHECK_SIZEOF(short)
|
|
|
|
AC_CHECK_SIZEOF(long)
|
|
|
|
AC_CHECK_SIZEOF(int)
|
|
|
|
AC_CHECK_SIZEOF(void *)
|
|
|
|
AC_CHECK_SIZEOF(long long)
|
|
|
|
|
|
|
|
if test x$ac_cv_sizeof_long_long = x8; then
|
|
|
|
# long long is a 64 bit integer.
|
|
|
|
AC_MSG_CHECKING(for format to printf and scanf a gint64)
|
|
|
|
AC_CACHE_VAL(glib_cv_long_long_format,[
|
2000-09-28 09:45:04 +02:00
|
|
|
for format in ll q; do
|
2000-09-28 09:54:40 +02:00
|
|
|
AC_TRY_RUN([#include <stdio.h>
|
2000-02-13 08:18:23 +01:00
|
|
|
int main()
|
|
|
|
{
|
|
|
|
long long b, a = -0x3AFAFAFAFAFAFAFALL;
|
|
|
|
char buffer[1000];
|
2000-09-28 09:45:04 +02:00
|
|
|
sprintf (buffer, "%${format}u", a);
|
|
|
|
sscanf (buffer, "%${format}u", &b);
|
2000-02-13 08:18:23 +01:00
|
|
|
exit (b!=a);
|
|
|
|
}
|
|
|
|
],
|
2000-09-28 09:45:04 +02:00
|
|
|
glib_cv_long_long_format=${format}
|
|
|
|
break)
|
|
|
|
done])
|
|
|
|
if test -n "$glib_cv_long_long_format"; then
|
2000-09-28 09:54:40 +02:00
|
|
|
AC_MSG_RESULT(%${glib_cv_long_long_format}i)
|
2000-09-28 09:45:04 +02:00
|
|
|
else
|
|
|
|
AC_MSG_RESULT(none)
|
|
|
|
fi
|
2000-02-13 08:18:23 +01:00
|
|
|
fi
|
|
|
|
|
|
|
|
dnl long doubles were not used, and a portability problem
|
|
|
|
dnl AC_C_LONG_DOUBLE
|
|
|
|
AC_C_CONST
|
|
|
|
|
2000-12-29 03:16:51 +01:00
|
|
|
dnl ok, here we try to check whether the systems prototypes for
|
|
|
|
dnl malloc and friends actually match the prototypes provided
|
|
|
|
dnl by gmem.h (keep in sync). i currently only know how to check
|
|
|
|
dnl this reliably with gcc (-Werror), improvements for other
|
|
|
|
dnl compilers are apprechiated.
|
|
|
|
SANE_MALLOC_PROTOS=no
|
|
|
|
AC_MSG_CHECKING([if malloc() and friends prototypes are gmem.h compatible])
|
|
|
|
glib_save_CFLAGS=$CFLAGS
|
|
|
|
if test "x$GCC" = "xyes"; then
|
|
|
|
CFLAGS="$CFLAGS -Werror"
|
|
|
|
AC_TRY_COMPILE([#include <stdlib.h>], [
|
|
|
|
void* (*my_calloc_p) (size_t, size_t) = calloc;
|
|
|
|
void* (*my_malloc_p) (size_t) = malloc;
|
|
|
|
void (*my_free_p) (void*) = free;
|
|
|
|
void* (*my_realloc_p) (void*, size_t) = realloc;
|
|
|
|
my_calloc_p = 0;
|
|
|
|
my_malloc_p = 0;
|
|
|
|
my_free_p = 0;
|
|
|
|
my_realloc_p = 0;
|
|
|
|
],
|
|
|
|
AC_DEFINE(SANE_MALLOC_PROTOS)
|
|
|
|
SANE_MALLOC_PROTOS=yes)
|
|
|
|
fi
|
|
|
|
AC_MSG_RESULT($SANE_MALLOC_PROTOS)
|
|
|
|
CFLAGS=$glib_save_CFLAGS
|
|
|
|
|
|
|
|
|
2000-02-13 08:18:23 +01:00
|
|
|
dnl AC_C_INLINE is useless to us since it bails out too early, we need to
|
|
|
|
dnl truely know which ones of `inline', `__inline' and `__inline__' are
|
|
|
|
dnl actually supported.
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_CACHE_CHECK([for __inline],glib_cv_has__inline,[
|
2000-02-13 08:18:23 +01:00
|
|
|
AC_TRY_RUN([
|
|
|
|
__inline int foo () { return 0; }
|
|
|
|
int main () { return foo (); }
|
|
|
|
],
|
|
|
|
glib_cv_has__inline=yes
|
|
|
|
,
|
|
|
|
glib_cv_has__inline=no
|
|
|
|
,)
|
|
|
|
])
|
|
|
|
case x$glib_cv_has__inline in
|
2000-10-16 03:02:19 +02:00
|
|
|
xyes) AC_DEFINE(G_HAVE___INLINE,1,[Have __inline keyword])
|
2000-02-13 08:18:23 +01:00
|
|
|
esac
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_CACHE_CHECK([for __inline__],glib_cv_has__inline__,[
|
2000-02-13 08:18:23 +01:00
|
|
|
AC_TRY_RUN([
|
|
|
|
__inline__ int foo () { return 0; }
|
|
|
|
int main () { return foo (); }
|
|
|
|
],
|
|
|
|
glib_cv_has__inline__=yes
|
|
|
|
,
|
|
|
|
glib_cv_has__inline__=no
|
|
|
|
,)
|
|
|
|
])
|
|
|
|
case x$glib_cv_has__inline__ in
|
2000-10-16 03:02:19 +02:00
|
|
|
xyes) AC_DEFINE(G_HAVE___INLINE__,1,[Have __inline__ keyword])
|
2000-02-13 08:18:23 +01:00
|
|
|
esac
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_CACHE_CHECK([for inline], glib_cv_hasinline,[
|
2000-02-13 08:18:23 +01:00
|
|
|
AC_TRY_RUN([
|
|
|
|
inline int foo () { return 0; }
|
|
|
|
int main () { return foo (); }
|
|
|
|
],
|
|
|
|
glib_cv_hasinline=yes
|
|
|
|
,
|
|
|
|
glib_cv_hasinline=no
|
|
|
|
,)
|
|
|
|
])
|
|
|
|
case x$glib_cv_hasinline in
|
2000-10-16 03:02:19 +02:00
|
|
|
xyes) AC_DEFINE(G_HAVE_INLINE,1,[Have inline keyword])
|
2000-02-13 08:18:23 +01:00
|
|
|
esac
|
|
|
|
|
|
|
|
# check for bytesex stuff
|
|
|
|
AC_C_BIGENDIAN
|
|
|
|
|
2000-05-12 17:23:16 +02:00
|
|
|
# check for header files
|
2000-10-09 23:06:01 +02:00
|
|
|
AC_CHECK_HEADERS([float.h limits.h pwd.h sys/param.h sys/poll.h sys/select.h])
|
2000-11-15 18:48:43 +01:00
|
|
|
AC_CHECK_HEADERS([sys/time.h sys/times.h unistd.h values.h stdint.h sched.h])
|
2000-02-13 08:18:23 +01:00
|
|
|
|
2000-05-12 17:23:16 +02:00
|
|
|
AC_MSG_CHECKING(whether make is GNU Make)
|
|
|
|
STRIP_BEGIN=
|
|
|
|
STRIP_END=
|
|
|
|
if $ac_make --version 2>/dev/null | grep '^GNU Make ' >/dev/null ; then
|
|
|
|
STRIP_BEGIN='$(strip $(STRIP_DUMMY)'
|
|
|
|
STRIP_END=')'
|
|
|
|
AC_MSG_RESULT(yes)
|
|
|
|
else
|
|
|
|
AC_MSG_RESULT(no)
|
|
|
|
fi
|
|
|
|
STRIP_DUMMY=
|
|
|
|
AC_SUBST(STRIP_DUMMY)
|
|
|
|
AC_SUBST(STRIP_BEGIN)
|
|
|
|
AC_SUBST(STRIP_END)
|
|
|
|
|
2000-02-13 08:18:23 +01:00
|
|
|
# check additional type sizes
|
|
|
|
size_includes=["
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <ctype.h>
|
|
|
|
#include <string.h>
|
|
|
|
"]
|
|
|
|
if test "x$ac_cv_header_stdint_h" = "xyes"; then
|
|
|
|
size_includes=["$size_includes
|
|
|
|
#include <stdint.h>
|
|
|
|
"]
|
|
|
|
fi
|
|
|
|
if test "x$ac_cv_header_unistd_h" = "xyes"; then
|
|
|
|
size_includes=["$size_includes
|
|
|
|
#include <unistd.h>
|
|
|
|
"]
|
|
|
|
fi
|
|
|
|
GLIB_SIZEOF([$size_includes], size_t, size_t)
|
|
|
|
GLIB_SIZEOF([$size_includes], ptrdiff_t, ptrdiff_t)
|
|
|
|
GLIB_SIZEOF([$size_includes], intmax_t, intmax_t)
|
|
|
|
|
|
|
|
# Check for some functions
|
2000-10-30 22:55:21 +01:00
|
|
|
AC_CHECK_FUNCS(lstat strerror strsignal memmove mkstemp vsnprintf strcasecmp strncasecmp poll getcwd)
|
2000-02-13 08:18:23 +01:00
|
|
|
|
|
|
|
# Check if bcopy can be used for overlapping copies, if memmove isn't found.
|
|
|
|
# The check is borrowed from the PERL Configure script.
|
|
|
|
if test "$ac_cv_func_memmove" != "yes"; then
|
|
|
|
AC_CACHE_CHECK(whether bcopy can handle overlapping copies,
|
|
|
|
glib_cv_working_bcopy,[AC_TRY_RUN([
|
|
|
|
int main() {
|
|
|
|
char buf[128], abc[128], *b;
|
|
|
|
int len, off, align;
|
|
|
|
bcopy("abcdefghijklmnopqrstuvwxyz0123456789", abc, 36);
|
|
|
|
for (align = 7; align >= 0; align--) {
|
|
|
|
for (len = 36; len; len--) {
|
|
|
|
b = buf+align; bcopy(abc, b, len);
|
|
|
|
for (off = 1; off <= len; off++) {
|
|
|
|
bcopy(b, b+off, len); bcopy(b+off, b, len);
|
|
|
|
if (bcmp(b, abc, len)) return(1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return(0);
|
|
|
|
}],glib_cv_working_bcopy=yes,glib_cv_working_bcopy=no)])
|
2000-10-23 16:15:22 +02:00
|
|
|
if test "$glib_cv_working_bcopy" = "yes"; then
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_DEFINE(HAVE_WORKING_BCOPY,1,[Have a working bcopy])
|
2000-02-13 08:18:23 +01:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Check for sys_errlist
|
|
|
|
AC_MSG_CHECKING(for sys_errlist)
|
|
|
|
AC_TRY_LINK(, [
|
|
|
|
extern char *sys_errlist[];
|
|
|
|
extern int sys_nerr;
|
|
|
|
sys_errlist[sys_nerr-1][0] = 0;
|
|
|
|
], glib_ok=yes, glib_ok=no)
|
|
|
|
AC_MSG_RESULT($glib_ok)
|
|
|
|
if test $glib_ok = no; then
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_DEFINE(NO_SYS_ERRLIST,1,[global 'sys_errlist' not found])
|
2000-02-13 08:18:23 +01:00
|
|
|
fi
|
|
|
|
|
|
|
|
# Check for sys_siglist
|
|
|
|
AC_MSG_CHECKING(for sys_siglist)
|
|
|
|
AC_TRY_LINK(, [
|
|
|
|
extern char *sys_siglist[];
|
2000-07-19 16:01:22 +02:00
|
|
|
exit (sys_siglist[0]);
|
2000-02-13 08:18:23 +01:00
|
|
|
], glib_ok=yes, glib_ok=no)
|
|
|
|
AC_MSG_RESULT($glib_ok)
|
|
|
|
if test $glib_ok = no; then
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_DEFINE(NO_SYS_SIGLIST,1,[global 'sys_siglist' not found])
|
2000-02-13 08:18:23 +01:00
|
|
|
fi
|
|
|
|
|
|
|
|
# Check for sys_siglist decl (see Tue Jan 19 00:44:24 1999 in changelog)
|
|
|
|
AC_MSG_CHECKING(for sys_siglist declaration)
|
|
|
|
AC_TRY_COMPILE([#include <signal.h>], [
|
|
|
|
strlen (sys_siglist[0]);
|
|
|
|
], glib_ok=yes, glib_ok=no)
|
|
|
|
AC_MSG_RESULT($glib_ok)
|
|
|
|
if test $glib_ok = no; then
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_DEFINE(NO_SYS_SIGLIST_DECL,1,[global 'sys_siglist' not declared])
|
2000-02-13 08:18:23 +01:00
|
|
|
fi
|
|
|
|
|
|
|
|
# Check if <sys/select.h> needs to be included for fd_set
|
|
|
|
AC_MSG_CHECKING([for fd_set])
|
|
|
|
AC_TRY_COMPILE([#include <sys/types.h>],
|
|
|
|
[fd_set readMask, writeMask;], gtk_ok=yes, gtk_ok=no)
|
|
|
|
if test $gtk_ok = yes; then
|
|
|
|
AC_MSG_RESULT([yes, found in sys/types.h])
|
|
|
|
else
|
2000-12-08 23:48:45 +01:00
|
|
|
AC_EGREP_HEADER(fd_set, sys/select.h, gtk_ok=yes)
|
2000-02-13 08:18:23 +01:00
|
|
|
if test $gtk_ok = yes; then
|
2000-10-16 03:02:19 +02:00
|
|
|
# *** FIXME: give it a different name
|
|
|
|
AC_DEFINE(HAVE_SYS_SELECT_H,1,[found fd_set in sys/select.h])
|
2000-02-13 08:18:23 +01:00
|
|
|
AC_MSG_RESULT([yes, found in sys/select.h])
|
|
|
|
else
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_DEFINE(NO_FD_SET,1,[didn't find fd_set])
|
2000-02-13 08:18:23 +01:00
|
|
|
AC_MSG_RESULT(no)
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
dnl *** check for sane realloc() ***
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_CACHE_CHECK([whether realloc (NULL,) will work],glib_cv_sane_realloc,[
|
2000-02-13 08:18:23 +01:00
|
|
|
AC_TRY_RUN([
|
|
|
|
#include <stdlib.h>
|
|
|
|
int main() {
|
|
|
|
return realloc (0, sizeof (int)) == 0;
|
|
|
|
}],
|
2000-10-16 03:02:19 +02:00
|
|
|
[glib_cv_sane_realloc=yes],
|
|
|
|
[glib_cv_sane_realloc=no],
|
|
|
|
[])
|
2000-02-13 08:18:23 +01:00
|
|
|
])
|
2000-10-09 23:06:01 +02:00
|
|
|
if test x$glib_cv_sane_realloc = xyes; then
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_DEFINE(REALLOC_0_WORKS,1,[whether realloc (NULL,) works])
|
2000-10-09 23:06:01 +02:00
|
|
|
fi
|
2000-02-13 08:18:23 +01:00
|
|
|
|
2000-05-29 20:48:29 +02:00
|
|
|
dnl Check for nl_langinfo and CODESET
|
|
|
|
|
|
|
|
AC_MSG_CHECKING([for nl_langinfo (CODESET)])
|
|
|
|
AC_TRY_COMPILE([#include <langinfo.h>],
|
|
|
|
[char *codeset = nl_langinfo (CODESET);],
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_DEFINE(HAVE_CODESET,1,[Have nl_langinfo (CODESET)])
|
2000-05-29 20:48:29 +02:00
|
|
|
have_codeset=yes,
|
|
|
|
have_codeset=no)
|
|
|
|
AC_MSG_RESULT($have_codeset)
|
added g_strlcat() and g_strlcpy() wrappers, supplied by David Wheeler
Wed Jul 26 05:47:48 2000 Tim Janik <timj@gtk.org>
* configure.in:
* testglib.c:
* gstrfuncs.c:
* glib.h: added g_strlcat() and g_strlcpy() wrappers, supplied by
David Wheeler <dwheeler@ida.org>:
* glib.h, gstrfuncs.c: added g_strlcpy and g_strlcat to support
safe manipulation of fixed-length string buffers.
These functions were originally developed by Todd Miller to simplify
development of security-related programs, and
are available on many (but not all) Unix-like systems,
including OpenBSD, FreeBSD, and Solaris. See
ftp://ftp.openbsd.org/pub/OpenBSD/src/lib/libc/string/strlcpy.3
and http://www.openbsd.org/security.html.
If there's a strlcpy/strlcat on the system, it's called, otherwise
an implementation is provided.
* testglib.c: Added tests for g_strlcpy, g_strlcat.
2000-07-26 05:51:07 +02:00
|
|
|
|
|
|
|
|
|
|
|
dnl ****************************************
|
|
|
|
dnl *** strlcpy/strlcat ***
|
|
|
|
dnl ****************************************
|
|
|
|
# Check for strlcpy
|
|
|
|
AC_MSG_CHECKING(for strlcpy/strlcat)
|
|
|
|
AC_TRY_LINK([#include <stdlib.h>
|
|
|
|
#include <string.h>], [
|
|
|
|
char *p = malloc(10);
|
|
|
|
(void) strlcpy(p, "hi", 10);
|
|
|
|
(void) strlcat(p, "bye", 10);
|
|
|
|
], glib_ok=yes, glib_ok=no)
|
|
|
|
AC_MSG_RESULT($glib_ok)
|
|
|
|
if test $glib_ok = yes; then
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_DEFINE(HAVE_STRLCPY,1,[Have functions strlcpy and strlcat])
|
added g_strlcat() and g_strlcpy() wrappers, supplied by David Wheeler
Wed Jul 26 05:47:48 2000 Tim Janik <timj@gtk.org>
* configure.in:
* testglib.c:
* gstrfuncs.c:
* glib.h: added g_strlcat() and g_strlcpy() wrappers, supplied by
David Wheeler <dwheeler@ida.org>:
* glib.h, gstrfuncs.c: added g_strlcpy and g_strlcat to support
safe manipulation of fixed-length string buffers.
These functions were originally developed by Todd Miller to simplify
development of security-related programs, and
are available on many (but not all) Unix-like systems,
including OpenBSD, FreeBSD, and Solaris. See
ftp://ftp.openbsd.org/pub/OpenBSD/src/lib/libc/string/strlcpy.3
and http://www.openbsd.org/security.html.
If there's a strlcpy/strlcat on the system, it's called, otherwise
an implementation is provided.
* testglib.c: Added tests for g_strlcpy, g_strlcat.
2000-07-26 05:51:07 +02:00
|
|
|
fi
|
2000-05-29 20:48:29 +02:00
|
|
|
|
2000-02-13 08:18:23 +01:00
|
|
|
|
|
|
|
dnl **********************
|
|
|
|
dnl *** va_copy checks ***
|
|
|
|
dnl **********************
|
|
|
|
dnl we currently check for all three va_copy possibilities, so we get
|
|
|
|
dnl all results in config.log for bug reports.
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_CACHE_CHECK([for an implementation of va_copy()],glib_cv_va_copy,[
|
2000-02-13 08:18:23 +01:00
|
|
|
AC_TRY_RUN([
|
|
|
|
#include <stdarg.h>
|
|
|
|
void f (int i, ...) {
|
|
|
|
va_list args1, args2;
|
|
|
|
va_start (args1, i);
|
|
|
|
va_copy (args2, args1);
|
|
|
|
if (va_arg (args2, int) != 42 || va_arg (args1, int) != 42)
|
|
|
|
exit (1);
|
|
|
|
va_end (args1); va_end (args2);
|
|
|
|
}
|
|
|
|
int main() {
|
|
|
|
f (0, 42);
|
|
|
|
return 0;
|
|
|
|
}],
|
2000-10-16 03:02:19 +02:00
|
|
|
[glib_cv_va_copy=yes],
|
|
|
|
[glib_cv_va_copy=no],
|
|
|
|
[])
|
2000-02-13 08:18:23 +01:00
|
|
|
])
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_CACHE_CHECK([for an implementation of __va_copy()],glib_cv___va_copy,[
|
2000-02-13 08:18:23 +01:00
|
|
|
AC_TRY_RUN([
|
|
|
|
#include <stdarg.h>
|
|
|
|
void f (int i, ...) {
|
|
|
|
va_list args1, args2;
|
|
|
|
va_start (args1, i);
|
|
|
|
__va_copy (args2, args1);
|
|
|
|
if (va_arg (args2, int) != 42 || va_arg (args1, int) != 42)
|
|
|
|
exit (1);
|
|
|
|
va_end (args1); va_end (args2);
|
|
|
|
}
|
|
|
|
int main() {
|
|
|
|
f (0, 42);
|
|
|
|
return 0;
|
|
|
|
}],
|
2000-10-16 03:02:19 +02:00
|
|
|
[glib_cv___va_copy=yes],
|
|
|
|
[glib_cv___va_copy=no],
|
|
|
|
[])
|
2000-02-13 08:18:23 +01:00
|
|
|
])
|
2000-10-16 03:02:19 +02:00
|
|
|
|
|
|
|
if test "x$glib_cv_va_copy" = "xyes"; then
|
|
|
|
g_va_copy_func=va_copy
|
|
|
|
else if test "x$glib_cv___va_copy" = "xyes"; then
|
|
|
|
g_va_copy_func=__va_copy
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
if test -n "$g_va_copy_func"; then
|
|
|
|
AC_DEFINE_UNQUOTED(G_VA_COPY,$g_va_copy_func,[A 'va_copy' style function])
|
|
|
|
fi
|
|
|
|
|
|
|
|
AC_CACHE_CHECK([whether va_lists can be copied by value],glib_cv_va_val_copy,[
|
2000-02-13 08:18:23 +01:00
|
|
|
AC_TRY_RUN([
|
|
|
|
#include <stdarg.h>
|
|
|
|
void f (int i, ...) {
|
|
|
|
va_list args1, args2;
|
|
|
|
va_start (args1, i);
|
|
|
|
args2 = args1;
|
|
|
|
if (va_arg (args2, int) != 42 || va_arg (args1, int) != 42)
|
|
|
|
exit (1);
|
|
|
|
va_end (args1); va_end (args2);
|
|
|
|
}
|
|
|
|
int main() {
|
|
|
|
f (0, 42);
|
|
|
|
return 0;
|
|
|
|
}],
|
2000-10-16 03:02:19 +02:00
|
|
|
[glib_cv_va_val_copy=yes],
|
|
|
|
[glib_cv_va_val_copy=no],
|
|
|
|
[])
|
2000-02-13 08:18:23 +01:00
|
|
|
])
|
2000-10-16 03:02:19 +02:00
|
|
|
|
2000-02-13 08:18:23 +01:00
|
|
|
if test "x$glib_cv_va_val_copy" = "xno"; then
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_DEFINE(G_VA_COPY_AS_ARRAY,1, ['va_lists' cannot be copies as values])
|
2000-02-13 08:18:23 +01:00
|
|
|
fi
|
|
|
|
|
|
|
|
dnl ***********************
|
|
|
|
dnl *** g_module checks ***
|
|
|
|
dnl ***********************
|
|
|
|
G_MODULE_LIBS=
|
|
|
|
G_MODULE_LIBS_EXTRA=
|
|
|
|
G_MODULE_PLUGIN_LIBS=
|
|
|
|
G_MODULE_LDFLAGS=
|
|
|
|
dnl G_MODULE_IMPL= don't reset, so cmd-line can override
|
|
|
|
G_MODULE_NEED_USCORE=0
|
2001-02-17 07:32:30 +01:00
|
|
|
G_MODULE_BROKEN_RTLD_GLOBAL=0
|
2000-02-13 08:18:23 +01:00
|
|
|
G_MODULE_HAVE_DLERROR=0
|
|
|
|
dnl *** dlopen() and dlsym() in system libraries
|
|
|
|
if test -z "$G_MODULE_IMPL"; then
|
|
|
|
AC_CHECK_FUNC(dlopen,
|
2000-10-09 23:06:01 +02:00
|
|
|
[AC_CHECK_FUNC(dlsym,
|
|
|
|
[G_MODULE_IMPL=G_MODULE_IMPL_DL],[])],
|
|
|
|
[])
|
2000-02-13 08:18:23 +01:00
|
|
|
fi
|
|
|
|
dnl *** load_image (BeOS)
|
|
|
|
if test -z "$G_MODULE_IMPL" -a "x$glib_native_beos" = "xyes"; then
|
|
|
|
AC_CHECK_LIB(root, load_image,
|
2000-10-16 03:02:19 +02:00
|
|
|
[G_MODULE_LIBS="-lbe -lroot -lglib"
|
2000-02-13 08:18:23 +01:00
|
|
|
G_MODULE_LIBS_EXTRA="-L\$(top_builddir_full)/.libs"
|
|
|
|
G_MODULE_PLUGIN_LIBS="-L\$(top_builddir_full)/gmodule/.libs -lgmodule"
|
2000-10-16 03:02:19 +02:00
|
|
|
G_MODULE_IMPL=G_MODULE_IMPL_BEOS],
|
|
|
|
[])
|
2000-02-13 08:18:23 +01:00
|
|
|
fi
|
2000-10-09 23:06:01 +02:00
|
|
|
# *** dlopen() and dlsym() in libdl
|
2000-02-13 08:18:23 +01:00
|
|
|
if test -z "$G_MODULE_IMPL"; then
|
|
|
|
AC_CHECK_LIB(dl, dlopen,
|
2000-10-09 23:06:01 +02:00
|
|
|
[AC_CHECK_LIB(dl, dlsym,
|
|
|
|
[G_MODULE_LIBS=-ldl
|
|
|
|
G_MODULE_IMPL=G_MODULE_IMPL_DL],[])],
|
|
|
|
[])
|
2000-02-13 08:18:23 +01:00
|
|
|
fi
|
|
|
|
dnl *** shl_load() in libdld (HP-UX)
|
|
|
|
if test -z "$G_MODULE_IMPL"; then
|
|
|
|
AC_MSG_CHECKING(how to export all symbols)
|
|
|
|
SAVED_LDFLAGS=$LDFLAGS
|
|
|
|
LDFLAGS="$LDFLAGS -Wl,-E"
|
|
|
|
AC_TRY_LINK(,[ return 0; ],
|
|
|
|
[ G_MODULE_LDFLAGS="-Wl,-E" ],[
|
|
|
|
LDFLAGS="$SAVED_LDFLAGS -bexpall"
|
|
|
|
AC_TRY_LINK(,[ return 0; ],
|
2000-10-16 03:02:19 +02:00
|
|
|
[G_MODULE_LDFLAGS="-bexpall"],
|
|
|
|
[G_MODULE_LDFLAGS="none"])
|
2000-02-13 08:18:23 +01:00
|
|
|
])
|
|
|
|
LDFLAGS=$SAVED_LDFLAGS
|
|
|
|
AC_MSG_RESULT($G_MODULE_LDFLAGS)
|
|
|
|
if test "x$G_MODULE_LDFLAGS" = "xnone"; then
|
|
|
|
G_MODULE_LDFLAGS=
|
|
|
|
fi
|
|
|
|
AC_CHECK_LIB(dld, shl_load,
|
2000-10-16 03:02:19 +02:00
|
|
|
[G_MODULE_LIBS=-ldld
|
|
|
|
G_MODULE_IMPL=G_MODULE_IMPL_DLD],
|
|
|
|
[])
|
2000-02-13 08:18:23 +01:00
|
|
|
fi
|
|
|
|
dnl *** additional checks for G_MODULE_IMPL_DL
|
|
|
|
if test "$G_MODULE_IMPL" = "G_MODULE_IMPL_DL"; then
|
|
|
|
case "$host_os" in
|
|
|
|
linux*)
|
|
|
|
G_MODULE_LDFLAGS='-rdynamic'
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
LIBS_orig="$LIBS"
|
|
|
|
LDFLAGS_orig="$LDFLAGS"
|
|
|
|
LIBS="$LIBS $G_MODULE_LIBS"
|
|
|
|
LDFLAGS="$LDFLAGS $G_MODULE_LDFLAGS"
|
2001-02-17 07:28:07 +01:00
|
|
|
dnl *** check for OSF1/5.0 RTLD_GLOBAL brokenness
|
|
|
|
AC_CACHE_CHECK([for RTLD_GLOBAL brokenness],
|
|
|
|
glib_cv_rtldglobal_broken,[
|
|
|
|
AC_TRY_RUN([
|
|
|
|
#include <dlfcn.h>
|
|
|
|
#ifndef RTLD_GLOBAL
|
|
|
|
#define RTLD_GLOBAL 0
|
|
|
|
#endif
|
|
|
|
#ifndef RTLD_LAZY
|
|
|
|
#define RTLD_LAZY 0
|
|
|
|
#endif
|
|
|
|
int pthread_create;
|
|
|
|
int main () {
|
|
|
|
void *handle, *global, *local;
|
|
|
|
global = &pthread_create;
|
|
|
|
handle = dlopen ("libpthread.so", RTLD_GLOBAL | RTLD_LAZY);
|
|
|
|
if (!handle) return 0;
|
|
|
|
local = dlsym (handle, "pthread_create");
|
|
|
|
return global == local;
|
|
|
|
}],
|
|
|
|
[glib_cv_rtldglobal_broken=no],
|
|
|
|
[glib_cv_rtldglobal_broken=yes],
|
|
|
|
[])
|
|
|
|
rm -f plugin.c plugin.o plugin.lo
|
|
|
|
])
|
|
|
|
if test "x$glib_cv_rtldglobal_broken" = "xyes"; then
|
|
|
|
G_MODULE_BROKEN_RTLD_GLOBAL=1
|
|
|
|
else
|
|
|
|
G_MODULE_BROKEN_RTLD_GLOBAL=0
|
|
|
|
fi
|
2000-02-13 08:18:23 +01:00
|
|
|
dnl *** check whether we need preceeding underscores
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_CACHE_CHECK([for preceeding underscore in symbols],
|
|
|
|
glib_cv_uscore,[
|
2000-02-13 08:18:23 +01:00
|
|
|
AC_TRY_RUN([
|
|
|
|
#include <dlfcn.h>
|
|
|
|
int glib_underscore_test (void) { return 42; }
|
|
|
|
int main() {
|
|
|
|
void *f1 = (void*)0, *f2 = (void*)0, *handle;
|
|
|
|
handle = dlopen ((void*)0, 0);
|
|
|
|
if (handle) {
|
|
|
|
f1 = dlsym (handle, "glib_underscore_test");
|
|
|
|
f2 = dlsym (handle, "_glib_underscore_test");
|
|
|
|
} return (!f2 || f1);
|
|
|
|
}],
|
2000-10-16 03:02:19 +02:00
|
|
|
[glib_cv_uscore=yes],
|
|
|
|
[glib_cv_uscore=no],
|
|
|
|
[])
|
2000-02-13 08:18:23 +01:00
|
|
|
rm -f plugin.c plugin.o plugin.lo
|
|
|
|
])
|
|
|
|
if test "x$glib_cv_uscore" = "xyes"; then
|
|
|
|
G_MODULE_NEED_USCORE=1
|
|
|
|
else
|
|
|
|
G_MODULE_NEED_USCORE=0
|
|
|
|
fi
|
|
|
|
|
|
|
|
LDFLAGS="$LDFLAGS_orig"
|
|
|
|
dnl *** check for having dlerror()
|
|
|
|
AC_CHECK_FUNC(dlerror,
|
2000-10-16 03:02:19 +02:00
|
|
|
[G_MODULE_HAVE_DLERROR=1],
|
|
|
|
[G_MODULE_HAVE_DLERROR=0])
|
2000-02-13 08:18:23 +01:00
|
|
|
LIBS="$LIBS_orig"
|
|
|
|
fi
|
2001-02-17 07:28:07 +01:00
|
|
|
dnl *** done, have we got an implementation?
|
2000-02-13 08:18:23 +01:00
|
|
|
if test -z "$G_MODULE_IMPL"; then
|
|
|
|
G_MODULE_IMPL=0
|
|
|
|
fi
|
Determine the suffix of the shared librarries for this system. This is
2000-12-22 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in: Determine the suffix of the shared librarries for
this system. This is done analogous to
ltconfig.sh. G_MODULE_SUFFIX in glibconfig.h is set to either
"sl", "dll", or (most often) "so".
* tests/Makefile.am, tests/module-test.c,
tests/libmoduletestplugin_a.c, tests/libmoduletestplugin_b.c:
Added new testcase for gmodule. This is mostly copied from
gmodule/testgmodule.c, but unlike that is is quiet. (Why BTW are
some tests that verbose, not to say loquacious...)
* gmodule.c: Make g_module_open more tolerant wrt to the module
name. First it tries to open the module as named, if that fails,
it checks, whether it is a libtool archive and parses it, if that
fails it appends the systems shared library suffix
(i.e. ".so") (if not already found) and tries again and if that
fails it tries to append the ".la" libtool suffix (if not already
found) and parses it.
* gmodule.c: Lock recursive mutex during most module functions for
safety.
* gmodule-dl.c: Return an error from _g_module_symbol only, if
dlerror says so. All other functions return an error as well, if
dlerror returns NULL.
* testgmodule.c: Thanks to the above change the #ifdefs have
vanished.
* glib/glib-sections.txt: Added G_MODULE_SUFFIX.
* glib/tmpl/modules.sgml: Updated.
2000-12-22 14:44:25 +01:00
|
|
|
|
|
|
|
AC_MSG_CHECKING(for the suffix of shared libraries)
|
|
|
|
case "$host_os" in
|
|
|
|
hpux9* | hpux10* | hpux11*) # taken from ltconfig
|
|
|
|
glib_gmodule_suffix='sl'
|
|
|
|
;;
|
|
|
|
cygwin* | mingw*)
|
|
|
|
glib_gmodule_suffix='dll'
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
glib_gmodule_suffix='so'
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
AC_MSG_RESULT(.$glib_gmodule_suffix)
|
|
|
|
|
2000-02-13 08:18:23 +01:00
|
|
|
AC_SUBST(G_MODULE_IMPL)
|
|
|
|
AC_SUBST(G_MODULE_LIBS)
|
|
|
|
AC_SUBST(G_MODULE_LIBS_EXTRA)
|
|
|
|
AC_SUBST(G_MODULE_PLUGIN_LIBS)
|
|
|
|
AC_SUBST(G_MODULE_LDFLAGS)
|
|
|
|
AC_SUBST(G_MODULE_HAVE_DLERROR)
|
2001-02-17 07:28:07 +01:00
|
|
|
AC_SUBST(G_MODULE_BROKEN_RTLD_GLOBAL)
|
2000-02-13 08:18:23 +01:00
|
|
|
AC_SUBST(G_MODULE_NEED_USCORE)
|
|
|
|
AC_SUBST(GLIB_DEBUG_FLAGS)
|
|
|
|
|
|
|
|
|
|
|
|
dnl ***********************
|
|
|
|
dnl *** g_thread checks ***
|
|
|
|
dnl ***********************
|
|
|
|
|
|
|
|
AC_ARG_WITH(threads, [ --with-threads=[none/posix/dce/solaris] specify a thread implementation to use],
|
|
|
|
if test "x$with_threads" = x; then
|
|
|
|
want_threads=yes
|
|
|
|
else
|
|
|
|
want_threads=$with_threads
|
|
|
|
fi,
|
|
|
|
want_threads=yes)
|
|
|
|
if test "x$enable_threads" = "xno"; then
|
|
|
|
want_threads=no
|
|
|
|
fi
|
|
|
|
if test "x$want_threads" = "xnone"; then
|
|
|
|
want_threads=no
|
|
|
|
fi
|
|
|
|
|
|
|
|
dnl error and warning message
|
|
|
|
dnl *************************
|
|
|
|
|
|
|
|
THREAD_NO_IMPLEMENTATION="You do not have any known thread system on your
|
|
|
|
computer. GLib will not have a default thread implementation."
|
|
|
|
|
Added the missing POSIX_NO_YIELD and POSIX_NO_PRIORITIES warning messages.
2000-03-17 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in: Added the missing POSIX_NO_YIELD and
POSIX_NO_PRIORITIES warning messages.
* configure.in: Use AC_TRY_RUN instead of AC_TRY_LINK, to test for
real thread support. On solaris pthread_create can be linked to
even in -lc, but it doesn't work then.
* configure.in: Don't use priorities for threads, when the
minimal/maximal priorities couldn't be determined at configure
time.
* configure.in, gthread.c: Always define GSystemThread in
glibconfig.h to represent a system thread.
* configure.in: Do not use native recursive threads, when
possibe. We use some features, that they do not expose (namely the
depth counter).
* glib.h, gthread.c: Redefined GStaticRecMutex. The functions are
now implemented in a different way, which should be way
faster. Alsothere are now functions g_static_rec_mutex_unlock_full
and g_static_rec_mutex_lock_full to leave/enter a recursive mutex
completly.
* gthread.c (g_thread_self): Do not test the system_thread to be
non-zero to speed things up.
* gthread.c (g_mutex_init): Therefore set the system_thread of the
main thread here.
* tests/thread-test.c: Rerun all tests once again, but this time
we fool the system into thinking, that the available thread system
is not native, but userprovided.
* gthread/gthread-posix.c: Don't use priorities for threads,
when the minimal/maximal priorities couldn't be determined at
configure time.
* gthread/gthread-posix.c: Don't check for errors, when
setting the scope of a tread to system, as some posix
implementations can't do that and we don't want the thing to
fail because of that.
2000-03-17 15:49:59 +01:00
|
|
|
FLAG_DOES_NOT_WORK="I can't find the MACRO to enable thread safety on your
|
2000-02-13 08:18:23 +01:00
|
|
|
platform (normaly it's "_REENTRANT"). I'll not use any flag on
|
|
|
|
compilation now, but then your programs might not work.
|
|
|
|
Please provide information on how it is done on your system."
|
|
|
|
|
|
|
|
LIBS_NOT_FOUND_1="I can't find the libraries for the thread implementation
|
|
|
|
"
|
|
|
|
|
|
|
|
LIBS_NOT_FOUND_2=". Please choose another thread implementation or
|
|
|
|
provide information on your thread implementation.
|
|
|
|
You can also run 'configure --disable-threads'
|
|
|
|
to compile without thread support."
|
|
|
|
|
|
|
|
FUNC_NO_GETPWUID_R="the 'g_get_(user_name|real_name|home_dir|tmp_dir)'
|
|
|
|
functions will not be MT-safe during their first call because
|
|
|
|
there is no working 'getpwuid_r' on your system."
|
|
|
|
|
|
|
|
FUNC_NO_LOCALTIME_R="the 'g_date_set_time' function will not be MT-safe
|
|
|
|
because there is no 'localtime_r' on your system."
|
|
|
|
|
Added the missing POSIX_NO_YIELD and POSIX_NO_PRIORITIES warning messages.
2000-03-17 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in: Added the missing POSIX_NO_YIELD and
POSIX_NO_PRIORITIES warning messages.
* configure.in: Use AC_TRY_RUN instead of AC_TRY_LINK, to test for
real thread support. On solaris pthread_create can be linked to
even in -lc, but it doesn't work then.
* configure.in: Don't use priorities for threads, when the
minimal/maximal priorities couldn't be determined at configure
time.
* configure.in, gthread.c: Always define GSystemThread in
glibconfig.h to represent a system thread.
* configure.in: Do not use native recursive threads, when
possibe. We use some features, that they do not expose (namely the
depth counter).
* glib.h, gthread.c: Redefined GStaticRecMutex. The functions are
now implemented in a different way, which should be way
faster. Alsothere are now functions g_static_rec_mutex_unlock_full
and g_static_rec_mutex_lock_full to leave/enter a recursive mutex
completly.
* gthread.c (g_thread_self): Do not test the system_thread to be
non-zero to speed things up.
* gthread.c (g_mutex_init): Therefore set the system_thread of the
main thread here.
* tests/thread-test.c: Rerun all tests once again, but this time
we fool the system into thinking, that the available thread system
is not native, but userprovided.
* gthread/gthread-posix.c: Don't use priorities for threads,
when the minimal/maximal priorities couldn't be determined at
configure time.
* gthread/gthread-posix.c: Don't check for errors, when
setting the scope of a tread to system, as some posix
implementations can't do that and we don't want the thing to
fail because of that.
2000-03-17 15:49:59 +01:00
|
|
|
POSIX_NO_YIELD="I can not find a yield functions for your platform. A rather
|
|
|
|
crude surrogate will be used. If you happen to know a
|
|
|
|
yield function for your system, please inform the GLib
|
|
|
|
developers."
|
|
|
|
|
|
|
|
POSIX_NO_PRIORITIES="I can not find the minimal and maximal priorities for
|
|
|
|
threads on your system. Thus threads can only have the default
|
|
|
|
priority. If you happen to know these main/max
|
|
|
|
priorities, please inform the GLib developers."
|
|
|
|
|
|
|
|
|
2000-02-13 08:18:23 +01:00
|
|
|
dnl determination of thread implementation
|
|
|
|
dnl ***************************************
|
|
|
|
|
|
|
|
have_threads=none
|
|
|
|
if test "x$want_threads" = xyes || test "x$want_threads" = xsolaris; then
|
|
|
|
case $host in
|
|
|
|
*-*-solaris*)
|
|
|
|
AC_CHECK_LIB(thread, cond_init, have_threads=solaris)
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
fi
|
|
|
|
if test "x$want_threads" = xyes || test "x$want_threads" = xposix \
|
|
|
|
|| test "x$want_threads" = xdce; then
|
2000-11-15 18:48:43 +01:00
|
|
|
# -D_POSIX4_DRAFT_SOURCE -D_POSIX4A_DRAFT10_SOURCE is for DG/UX
|
Added the missing POSIX_NO_YIELD and POSIX_NO_PRIORITIES warning messages.
2000-03-17 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in: Added the missing POSIX_NO_YIELD and
POSIX_NO_PRIORITIES warning messages.
* configure.in: Use AC_TRY_RUN instead of AC_TRY_LINK, to test for
real thread support. On solaris pthread_create can be linked to
even in -lc, but it doesn't work then.
* configure.in: Don't use priorities for threads, when the
minimal/maximal priorities couldn't be determined at configure
time.
* configure.in, gthread.c: Always define GSystemThread in
glibconfig.h to represent a system thread.
* configure.in: Do not use native recursive threads, when
possibe. We use some features, that they do not expose (namely the
depth counter).
* glib.h, gthread.c: Redefined GStaticRecMutex. The functions are
now implemented in a different way, which should be way
faster. Alsothere are now functions g_static_rec_mutex_unlock_full
and g_static_rec_mutex_lock_full to leave/enter a recursive mutex
completly.
* gthread.c (g_thread_self): Do not test the system_thread to be
non-zero to speed things up.
* gthread.c (g_mutex_init): Therefore set the system_thread of the
main thread here.
* tests/thread-test.c: Rerun all tests once again, but this time
we fool the system into thinking, that the available thread system
is not native, but userprovided.
* gthread/gthread-posix.c: Don't use priorities for threads,
when the minimal/maximal priorities couldn't be determined at
configure time.
* gthread/gthread-posix.c: Don't check for errors, when
setting the scope of a tread to system, as some posix
implementations can't do that and we don't want the thing to
fail because of that.
2000-03-17 15:49:59 +01:00
|
|
|
# -U_OSF_SOURCE is for Digital UNIX 4.0d
|
2000-11-15 18:48:43 +01:00
|
|
|
GTHREAD_COMPILE_IMPL_DEFINES="-D_POSIX4_DRAFT_SOURCE -D_POSIX4A_DRAFT10_SOURCE -U_OSF_SOURCE"
|
2000-02-13 08:18:23 +01:00
|
|
|
glib_save_CPPFLAGS="$CPPFLAGS"
|
|
|
|
CPPFLAGS="$CPPFLAGS $GTHREAD_COMPILE_IMPL_DEFINES"
|
|
|
|
if test "x$have_threads" = xnone; then
|
2000-11-15 18:48:43 +01:00
|
|
|
AC_TRY_COMPILE([#include <pthread.h>],
|
|
|
|
[pthread_attr_t attr; pthread_attr_init(&attr);],
|
2000-02-13 08:18:23 +01:00
|
|
|
have_threads=posix)
|
|
|
|
fi
|
|
|
|
if test "x$have_threads" = xnone; then
|
2000-11-15 18:48:43 +01:00
|
|
|
AC_TRY_COMPILE([#include <pthread.h>],
|
|
|
|
[pthread_attr_t attr; pthread_attr_create(&attr);],
|
|
|
|
have_threads=posix)
|
2000-02-13 08:18:23 +01:00
|
|
|
fi
|
|
|
|
CPPFLAGS="$glib_save_CPPFLAGS"
|
|
|
|
fi
|
|
|
|
|
|
|
|
AC_MSG_CHECKING(for thread implementation)
|
|
|
|
|
|
|
|
if test "x$have_threads" = xnone && test "x$want_threads" != xno; then
|
|
|
|
AC_MSG_RESULT(none available)
|
|
|
|
AC_MSG_WARN($THREAD_NO_IMPLEMENTATION)
|
|
|
|
else
|
|
|
|
AC_MSG_RESULT($have_threads)
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
2000-09-28 09:54:40 +02:00
|
|
|
dnl determination of G_THREAD_CFLAGS
|
|
|
|
dnl ********************************
|
2000-02-13 08:18:23 +01:00
|
|
|
|
|
|
|
G_THREAD_LIBS=
|
|
|
|
G_THREAD_LIBS_EXTRA=
|
|
|
|
G_THREAD_CFLAGS=
|
|
|
|
|
2000-09-28 09:54:40 +02:00
|
|
|
if test x"$have_threads" != xnone; then
|
|
|
|
|
|
|
|
G_THREAD_CFLAGS="-D_REENTRANT" # good default guess
|
|
|
|
|
|
|
|
case $host in
|
|
|
|
*-aix*)
|
|
|
|
G_THREAD_CFLAGS="$G_THREAD_CFLAGS -D_THREAD_SAFE"
|
|
|
|
if test x"$GCC" = xyes; then
|
|
|
|
G_THREAD_CFLAGS="$G_THREAD_CFLAGS -mthreads"
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
*-freebsd2.2*)
|
|
|
|
G_THREAD_CFLAGS="$G_THREAD_CFLAGS -D_THREAD_SAFE"
|
|
|
|
|
|
|
|
# FreeBSD 2.2.x shiped with gcc 2.7.2.x, which doesn't support
|
|
|
|
# -mthreads flag.
|
|
|
|
;;
|
|
|
|
*-sysv5uw7*) # UnixWare 7
|
|
|
|
if test "$GCC" != "yes"; then
|
|
|
|
G_THREAD_CFLAGS="$G_THREAD_CFLAGS -Kthread"
|
|
|
|
else
|
|
|
|
G_THREAD_CFLAGS="$G_THREAD_CFLAGS -pthread"
|
|
|
|
fi
|
|
|
|
;;
|
2000-11-15 18:48:43 +01:00
|
|
|
*-dg-dgux*) # DG/UX
|
|
|
|
G_THREAD_CFLAGS="$G_THREAD_CFLAGS -D_POSIX4A_DRAFT10_SOURCE"
|
2000-09-28 09:54:40 +02:00
|
|
|
esac
|
|
|
|
|
|
|
|
# if we are not finding the ctime_r function, then we probably are
|
|
|
|
# not using the proper multithread flag
|
|
|
|
|
|
|
|
glib_save_CPPFLAGS="$CPPFLAGS"
|
|
|
|
CPPFLAGS="$CPPFLAGS $G_THREAD_CFLAGS"
|
|
|
|
|
2000-11-15 18:48:43 +01:00
|
|
|
AC_TRY_COMPILE([#include <time.h>],
|
|
|
|
[time_t t; char b[30]; ctime_r (&t, b);], ,
|
|
|
|
[AC_TRY_COMPILE([#include <time.h>],
|
|
|
|
[time_t t; char b[30]; ctime_r (&t, b, 30);], ,
|
|
|
|
AC_MSG_WARN($FLAG_DOES_NOT_WORK))])
|
2000-09-28 09:54:40 +02:00
|
|
|
|
|
|
|
CPPFLAGS="$glib_save_CPPFLAGS"
|
|
|
|
|
|
|
|
AC_MSG_CHECKING(thread related cflags)
|
|
|
|
AC_MSG_RESULT($G_THREAD_CFLAGS)
|
|
|
|
CFLAGS="$CFLAGS $G_THREAD_CFLAGS"
|
|
|
|
fi
|
|
|
|
|
|
|
|
dnl determination of G_THREAD_LIBS
|
|
|
|
dnl ******************************
|
|
|
|
|
2000-02-13 08:18:23 +01:00
|
|
|
mutex_has_default=no
|
|
|
|
case $have_threads in
|
|
|
|
posix|dce)
|
2000-11-15 18:48:43 +01:00
|
|
|
glib_save_CPPFLAGS="$CPPFLAGS"
|
|
|
|
CPPFLAGS="$CPPFLAGS $GTHREAD_COMPILE_IMPL_DEFINES"
|
|
|
|
G_THREAD_LIBS=error
|
2000-09-28 09:54:40 +02:00
|
|
|
glib_save_LIBS="$LIBS"
|
|
|
|
case $host in
|
|
|
|
*-sysv5uw7*) # UnixWare 7
|
|
|
|
if test "$GCC" != "yes"; then
|
|
|
|
G_THREAD_LIBS="-Kthread"
|
|
|
|
else
|
|
|
|
G_THREAD_LIBS="-pthread"
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
*)
|
2000-02-13 08:18:23 +01:00
|
|
|
for thread_lib in "" pthread pthreads c_r thread dce; do
|
|
|
|
if test x"$thread_lib" = x; then
|
|
|
|
add_thread_lib=""
|
|
|
|
IN=""
|
|
|
|
else
|
|
|
|
add_thread_lib="-l$thread_lib"
|
|
|
|
IN=" in -l$thread_lib"
|
|
|
|
fi
|
Added the missing POSIX_NO_YIELD and POSIX_NO_PRIORITIES warning messages.
2000-03-17 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in: Added the missing POSIX_NO_YIELD and
POSIX_NO_PRIORITIES warning messages.
* configure.in: Use AC_TRY_RUN instead of AC_TRY_LINK, to test for
real thread support. On solaris pthread_create can be linked to
even in -lc, but it doesn't work then.
* configure.in: Don't use priorities for threads, when the
minimal/maximal priorities couldn't be determined at configure
time.
* configure.in, gthread.c: Always define GSystemThread in
glibconfig.h to represent a system thread.
* configure.in: Do not use native recursive threads, when
possibe. We use some features, that they do not expose (namely the
depth counter).
* glib.h, gthread.c: Redefined GStaticRecMutex. The functions are
now implemented in a different way, which should be way
faster. Alsothere are now functions g_static_rec_mutex_unlock_full
and g_static_rec_mutex_lock_full to leave/enter a recursive mutex
completly.
* gthread.c (g_thread_self): Do not test the system_thread to be
non-zero to speed things up.
* gthread.c (g_mutex_init): Therefore set the system_thread of the
main thread here.
* tests/thread-test.c: Rerun all tests once again, but this time
we fool the system into thinking, that the available thread system
is not native, but userprovided.
* gthread/gthread-posix.c: Don't use priorities for threads,
when the minimal/maximal priorities couldn't be determined at
configure time.
* gthread/gthread-posix.c: Don't check for errors, when
setting the scope of a tread to system, as some posix
implementations can't do that and we don't want the thing to
fail because of that.
2000-03-17 15:49:59 +01:00
|
|
|
if test x"$have_threads" = xposix; then
|
2000-11-15 18:48:43 +01:00
|
|
|
defattr=0
|
Added the missing POSIX_NO_YIELD and POSIX_NO_PRIORITIES warning messages.
2000-03-17 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in: Added the missing POSIX_NO_YIELD and
POSIX_NO_PRIORITIES warning messages.
* configure.in: Use AC_TRY_RUN instead of AC_TRY_LINK, to test for
real thread support. On solaris pthread_create can be linked to
even in -lc, but it doesn't work then.
* configure.in: Don't use priorities for threads, when the
minimal/maximal priorities couldn't be determined at configure
time.
* configure.in, gthread.c: Always define GSystemThread in
glibconfig.h to represent a system thread.
* configure.in: Do not use native recursive threads, when
possibe. We use some features, that they do not expose (namely the
depth counter).
* glib.h, gthread.c: Redefined GStaticRecMutex. The functions are
now implemented in a different way, which should be way
faster. Alsothere are now functions g_static_rec_mutex_unlock_full
and g_static_rec_mutex_lock_full to leave/enter a recursive mutex
completly.
* gthread.c (g_thread_self): Do not test the system_thread to be
non-zero to speed things up.
* gthread.c (g_mutex_init): Therefore set the system_thread of the
main thread here.
* tests/thread-test.c: Rerun all tests once again, but this time
we fool the system into thinking, that the available thread system
is not native, but userprovided.
* gthread/gthread-posix.c: Don't use priorities for threads,
when the minimal/maximal priorities couldn't be determined at
configure time.
* gthread/gthread-posix.c: Don't check for errors, when
setting the scope of a tread to system, as some posix
implementations can't do that and we don't want the thing to
fail because of that.
2000-03-17 15:49:59 +01:00
|
|
|
else
|
|
|
|
defattr=pthread_attr_default
|
|
|
|
fi
|
2000-02-13 08:18:23 +01:00
|
|
|
|
|
|
|
LIBS="$glib_save_LIBS $add_thread_lib"
|
|
|
|
|
2000-04-26 15:03:49 +02:00
|
|
|
AC_MSG_CHECKING(for pthread_create/pthread_join$IN)
|
Added the missing POSIX_NO_YIELD and POSIX_NO_PRIORITIES warning messages.
2000-03-17 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in: Added the missing POSIX_NO_YIELD and
POSIX_NO_PRIORITIES warning messages.
* configure.in: Use AC_TRY_RUN instead of AC_TRY_LINK, to test for
real thread support. On solaris pthread_create can be linked to
even in -lc, but it doesn't work then.
* configure.in: Don't use priorities for threads, when the
minimal/maximal priorities couldn't be determined at configure
time.
* configure.in, gthread.c: Always define GSystemThread in
glibconfig.h to represent a system thread.
* configure.in: Do not use native recursive threads, when
possibe. We use some features, that they do not expose (namely the
depth counter).
* glib.h, gthread.c: Redefined GStaticRecMutex. The functions are
now implemented in a different way, which should be way
faster. Alsothere are now functions g_static_rec_mutex_unlock_full
and g_static_rec_mutex_lock_full to leave/enter a recursive mutex
completly.
* gthread.c (g_thread_self): Do not test the system_thread to be
non-zero to speed things up.
* gthread.c (g_mutex_init): Therefore set the system_thread of the
main thread here.
* tests/thread-test.c: Rerun all tests once again, but this time
we fool the system into thinking, that the available thread system
is not native, but userprovided.
* gthread/gthread-posix.c: Don't use priorities for threads,
when the minimal/maximal priorities couldn't be determined at
configure time.
* gthread/gthread-posix.c: Don't check for errors, when
setting the scope of a tread to system, as some posix
implementations can't do that and we don't want the thing to
fail because of that.
2000-03-17 15:49:59 +01:00
|
|
|
AC_TRY_RUN([#include <pthread.h>
|
2000-04-26 15:03:49 +02:00
|
|
|
int check_me = 0;
|
|
|
|
void* func(void* data) {check_me = 42;}
|
Added the missing POSIX_NO_YIELD and POSIX_NO_PRIORITIES warning messages.
2000-03-17 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in: Added the missing POSIX_NO_YIELD and
POSIX_NO_PRIORITIES warning messages.
* configure.in: Use AC_TRY_RUN instead of AC_TRY_LINK, to test for
real thread support. On solaris pthread_create can be linked to
even in -lc, but it doesn't work then.
* configure.in: Don't use priorities for threads, when the
minimal/maximal priorities couldn't be determined at configure
time.
* configure.in, gthread.c: Always define GSystemThread in
glibconfig.h to represent a system thread.
* configure.in: Do not use native recursive threads, when
possibe. We use some features, that they do not expose (namely the
depth counter).
* glib.h, gthread.c: Redefined GStaticRecMutex. The functions are
now implemented in a different way, which should be way
faster. Alsothere are now functions g_static_rec_mutex_unlock_full
and g_static_rec_mutex_lock_full to leave/enter a recursive mutex
completly.
* gthread.c (g_thread_self): Do not test the system_thread to be
non-zero to speed things up.
* gthread.c (g_mutex_init): Therefore set the system_thread of the
main thread here.
* tests/thread-test.c: Rerun all tests once again, but this time
we fool the system into thinking, that the available thread system
is not native, but userprovided.
* gthread/gthread-posix.c: Don't use priorities for threads,
when the minimal/maximal priorities couldn't be determined at
configure time.
* gthread/gthread-posix.c: Don't check for errors, when
setting the scope of a tread to system, as some posix
implementations can't do that and we don't want the thing to
fail because of that.
2000-03-17 15:49:59 +01:00
|
|
|
main()
|
|
|
|
{ pthread_t t;
|
2000-04-26 15:03:49 +02:00
|
|
|
void *ret;
|
2000-11-15 18:48:43 +01:00
|
|
|
pthread_create (&t, $defattr, func, 0);
|
2000-04-26 15:03:49 +02:00
|
|
|
pthread_join (t, &ret);
|
|
|
|
exit (check_me != 42);
|
Added the missing POSIX_NO_YIELD and POSIX_NO_PRIORITIES warning messages.
2000-03-17 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in: Added the missing POSIX_NO_YIELD and
POSIX_NO_PRIORITIES warning messages.
* configure.in: Use AC_TRY_RUN instead of AC_TRY_LINK, to test for
real thread support. On solaris pthread_create can be linked to
even in -lc, but it doesn't work then.
* configure.in: Don't use priorities for threads, when the
minimal/maximal priorities couldn't be determined at configure
time.
* configure.in, gthread.c: Always define GSystemThread in
glibconfig.h to represent a system thread.
* configure.in: Do not use native recursive threads, when
possibe. We use some features, that they do not expose (namely the
depth counter).
* glib.h, gthread.c: Redefined GStaticRecMutex. The functions are
now implemented in a different way, which should be way
faster. Alsothere are now functions g_static_rec_mutex_unlock_full
and g_static_rec_mutex_lock_full to leave/enter a recursive mutex
completly.
* gthread.c (g_thread_self): Do not test the system_thread to be
non-zero to speed things up.
* gthread.c (g_mutex_init): Therefore set the system_thread of the
main thread here.
* tests/thread-test.c: Rerun all tests once again, but this time
we fool the system into thinking, that the available thread system
is not native, but userprovided.
* gthread/gthread-posix.c: Don't use priorities for threads,
when the minimal/maximal priorities couldn't be determined at
configure time.
* gthread/gthread-posix.c: Don't check for errors, when
setting the scope of a tread to system, as some posix
implementations can't do that and we don't want the thing to
fail because of that.
2000-03-17 15:49:59 +01:00
|
|
|
}],
|
2000-02-13 08:18:23 +01:00
|
|
|
[AC_MSG_RESULT(yes)
|
|
|
|
G_THREAD_LIBS="$add_thread_lib"
|
|
|
|
break],
|
|
|
|
[AC_MSG_RESULT(no)])
|
|
|
|
done
|
2000-09-28 09:54:40 +02:00
|
|
|
if test "x$G_THREAD_LIBS" = xerror; then
|
|
|
|
AC_MSG_ERROR($LIBS_NOT_FOUND_1$have_threads$LIBS_NOT_FOUND_2)
|
|
|
|
fi
|
2000-11-15 18:48:43 +01:00
|
|
|
for thread_lib in "" rt rte; do
|
2000-03-23 17:23:50 +01:00
|
|
|
if test x"$thread_lib" = x; then
|
|
|
|
add_thread_lib=""
|
|
|
|
IN=""
|
|
|
|
else
|
|
|
|
add_thread_lib="-l$thread_lib"
|
|
|
|
IN=" in -l$thread_lib"
|
|
|
|
fi
|
|
|
|
LIBS="$glib_save_LIBS $add_thread_lib"
|
|
|
|
|
|
|
|
AC_MSG_CHECKING(for sched_get_priority_min$IN)
|
|
|
|
AC_TRY_RUN([#include <sched.h>
|
|
|
|
#include <errno.h>
|
|
|
|
int main() {
|
|
|
|
errno = 0;
|
|
|
|
return sched_get_priority_min(SCHED_OTHER)==-1
|
|
|
|
&& errno != 0;
|
|
|
|
}],
|
|
|
|
[AC_MSG_RESULT(yes)
|
|
|
|
G_THREAD_LIBS="$G_THREAD_LIBS $add_thread_lib"
|
|
|
|
posix_priority_min="sched_get_priority_min(SCHED_OTHER)"
|
|
|
|
posix_priority_max="sched_get_priority_max(SCHED_OTHER)"
|
|
|
|
break],
|
|
|
|
[AC_MSG_RESULT(no)])
|
|
|
|
done
|
2000-02-13 08:18:23 +01:00
|
|
|
LIBS="$glib_save_LIBS"
|
2000-09-28 09:54:40 +02:00
|
|
|
;;
|
|
|
|
esac
|
|
|
|
mutex_has_default=yes
|
|
|
|
mutex_default_type='pthread_mutex_t'
|
|
|
|
mutex_default_init='PTHREAD_MUTEX_INITIALIZER'
|
|
|
|
mutex_header_file='pthread.h'
|
|
|
|
if test "x$have_threads" = "xposix"; then
|
|
|
|
g_threads_impl="POSIX"
|
|
|
|
else
|
|
|
|
g_threads_impl="DCE"
|
|
|
|
have_threads="posix"
|
|
|
|
fi
|
|
|
|
AC_SUBST(GTHREAD_COMPILE_IMPL_DEFINES)
|
2000-11-15 18:48:43 +01:00
|
|
|
CPPFLAGS="$glib_save_CPPFLAGS"
|
2000-09-28 09:54:40 +02:00
|
|
|
;;
|
2000-02-13 08:18:23 +01:00
|
|
|
solaris)
|
2000-09-28 09:54:40 +02:00
|
|
|
G_THREAD_LIBS=error
|
|
|
|
AC_CHECK_LIB(thread, cond_init, G_THREAD_LIBS="-lthread")
|
|
|
|
mutex_has_default=yes
|
|
|
|
mutex_default_type='mutex_t'
|
|
|
|
mutex_default_init="DEFAULTMUTEX"
|
|
|
|
mutex_header_file='thread.h'
|
|
|
|
g_threads_impl="SOLARIS"
|
|
|
|
;;
|
2000-02-13 08:18:23 +01:00
|
|
|
none)
|
2000-09-28 09:54:40 +02:00
|
|
|
g_threads_impl="NONE"
|
|
|
|
;;
|
2000-02-13 08:18:23 +01:00
|
|
|
*)
|
2000-09-28 09:54:40 +02:00
|
|
|
g_threads_impl="NONE"
|
|
|
|
G_THREAD_LIBS=error
|
|
|
|
;;
|
2000-02-13 08:18:23 +01:00
|
|
|
esac
|
|
|
|
|
|
|
|
if test "x$G_THREAD_LIBS" = xerror; then
|
|
|
|
AC_MSG_ERROR($LIBS_NOT_FOUND_1$have_threads$LIBS_NOT_FOUND_2)
|
|
|
|
fi
|
|
|
|
|
|
|
|
case $host in
|
|
|
|
*-*-beos*)
|
|
|
|
G_THREAD_LIBS="-lbe -lroot -lglib "
|
|
|
|
G_THREAD_LIBS_EXTRA="-L\$(top_builddir_full)/.libs"
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
AC_MSG_CHECKING(thread related libraries)
|
|
|
|
AC_MSG_RESULT($G_THREAD_LIBS)
|
|
|
|
|
|
|
|
dnl check for mt safe function variants and some posix functions
|
|
|
|
dnl ************************************************************
|
|
|
|
|
2000-09-28 09:54:40 +02:00
|
|
|
if test x"$have_threads" != xnone; then
|
2000-02-13 08:18:23 +01:00
|
|
|
glib_save_LIBS="$LIBS"
|
|
|
|
# we are not doing the following for now, as this might require glib
|
|
|
|
# to always be linked with the thread libs on some platforms.
|
|
|
|
# LIBS="$LIBS $G_THREAD_LIBS"
|
|
|
|
AC_CHECK_FUNCS(localtime_r)
|
|
|
|
if test "$ac_cv_header_pwd_h" = "yes"; then
|
2000-11-15 18:48:43 +01:00
|
|
|
AC_CACHE_CHECK([for posix getpwuid_r],
|
|
|
|
ac_cv_func_posix_getpwuid_r,
|
2000-02-13 08:18:23 +01:00
|
|
|
[AC_TRY_RUN([#include <errno.h>
|
2000-11-15 18:48:43 +01:00
|
|
|
#include <pwd.h>
|
|
|
|
int main () { char buffer[10000];
|
|
|
|
struct passwd pwd, *pwptr = &pwd;
|
|
|
|
int error;
|
|
|
|
errno = 0;
|
|
|
|
error = getpwuid_r (0, &pwd, buffer,
|
|
|
|
sizeof (buffer), &pwptr);
|
|
|
|
return (error < 0 && errno == ENOSYS)
|
|
|
|
|| error == ENOSYS; }],
|
|
|
|
[ac_cv_func_posix_getpwuid_r=yes],
|
|
|
|
[ac_cv_func_posix_getpwuid_r=no])])
|
|
|
|
if test "$ac_cv_func_posix_getpwuid_r" = yes; then
|
|
|
|
AC_DEFINE(HAVE_POSIX_GETPWUID_R,1,
|
|
|
|
[Have POSIX function getpwuid_r])
|
|
|
|
else
|
|
|
|
AC_CACHE_CHECK([for nonposix getpwuid_r],
|
|
|
|
ac_cv_func_nonposix_getpwuid_r,
|
|
|
|
[AC_TRY_COMPILE([#include <pwd.h>],
|
|
|
|
[char buffer[10000];
|
|
|
|
struct passwd pwd;
|
|
|
|
getpwuid_r (0, &pwd, buffer,
|
|
|
|
sizeof (buffer));],
|
|
|
|
[ac_cv_func_nonposix_getpwuid_r=yes],
|
|
|
|
[ac_cv_func_nonposix_getpwuid_r=no])])
|
|
|
|
if test "$ac_cv_func_nonposix_getpwuid_r" = yes; then
|
|
|
|
AC_DEFINE(HAVE_NONPOSIX_GETPWUID_R,1,
|
|
|
|
[Have non-POSIX function getpwuid_r])
|
|
|
|
fi
|
2000-02-13 08:18:23 +01:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
LIBS="$LIBS $G_THREAD_LIBS"
|
|
|
|
if test x"$have_threads" = xposix; then
|
Added the missing POSIX_NO_YIELD and POSIX_NO_PRIORITIES warning messages.
2000-03-17 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in: Added the missing POSIX_NO_YIELD and
POSIX_NO_PRIORITIES warning messages.
* configure.in: Use AC_TRY_RUN instead of AC_TRY_LINK, to test for
real thread support. On solaris pthread_create can be linked to
even in -lc, but it doesn't work then.
* configure.in: Don't use priorities for threads, when the
minimal/maximal priorities couldn't be determined at configure
time.
* configure.in, gthread.c: Always define GSystemThread in
glibconfig.h to represent a system thread.
* configure.in: Do not use native recursive threads, when
possibe. We use some features, that they do not expose (namely the
depth counter).
* glib.h, gthread.c: Redefined GStaticRecMutex. The functions are
now implemented in a different way, which should be way
faster. Alsothere are now functions g_static_rec_mutex_unlock_full
and g_static_rec_mutex_lock_full to leave/enter a recursive mutex
completly.
* gthread.c (g_thread_self): Do not test the system_thread to be
non-zero to speed things up.
* gthread.c (g_mutex_init): Therefore set the system_thread of the
main thread here.
* tests/thread-test.c: Rerun all tests once again, but this time
we fool the system into thinking, that the available thread system
is not native, but userprovided.
* gthread/gthread-posix.c: Don't use priorities for threads,
when the minimal/maximal priorities couldn't be determined at
configure time.
* gthread/gthread-posix.c: Don't check for errors, when
setting the scope of a tread to system, as some posix
implementations can't do that and we don't want the thing to
fail because of that.
2000-03-17 15:49:59 +01:00
|
|
|
glib_save_CPPFLAGS="$CPPFLAGS"
|
|
|
|
CPPFLAGS="$CPPFLAGS $GTHREAD_COMPILE_IMPL_DEFINES"
|
2000-12-29 16:11:03 +01:00
|
|
|
dnl we might grow sizeof(pthread_t) later on, so use a dummy name here
|
2001-02-15 17:43:02 +01:00
|
|
|
GLIB_SIZEOF([#include <pthread.h>], pthread_t, system_thread)
|
2000-02-13 08:18:23 +01:00
|
|
|
# This is not AC_CHECK_FUNC to also work with function
|
|
|
|
# name mangling in header files.
|
|
|
|
AC_MSG_CHECKING(for pthread_attr_setstacksize)
|
|
|
|
AC_TRY_LINK([#include <pthread.h>],
|
|
|
|
[pthread_attr_t t; pthread_attr_setstacksize(&t,0)],
|
|
|
|
[AC_MSG_RESULT(yes)
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_DEFINE(HAVE_PTHREAD_ATTR_SETSTACKSIZE,1,
|
|
|
|
[Have function pthread_attr_setstacksize])],
|
2000-02-13 08:18:23 +01:00
|
|
|
[AC_MSG_RESULT(no)])
|
|
|
|
AC_MSG_CHECKING(for minimal/maximal thread priority)
|
|
|
|
if test x"$posix_priority_min" = xnone; then
|
|
|
|
AC_EGREP_CPP(PX_PRIO_MIN,[#include <pthread.h>
|
|
|
|
PX_PRIO_MIN],,[
|
|
|
|
posix_priority_min=PX_PRIO_MIN
|
|
|
|
posix_priority_max=PX_PRIO_MAX])
|
|
|
|
fi
|
|
|
|
if test x"$posix_priority_min" = xnone; then
|
|
|
|
AC_EGREP_CPP(PRI_OTHER_MIN,[#include <pthread.h>
|
|
|
|
PRI_OTHER_MIN],,[
|
|
|
|
posix_priority_min=PRI_OTHER_MIN
|
|
|
|
posix_priority_max=PRI_OTHER_MAX])
|
|
|
|
fi
|
2000-03-23 17:23:50 +01:00
|
|
|
if test x"$posix_priority_min" = x; then
|
2000-02-13 08:18:23 +01:00
|
|
|
AC_MSG_RESULT(none found)
|
|
|
|
AC_MSG_WARN($POSIX_NO_PRIORITIES)
|
Added the missing POSIX_NO_YIELD and POSIX_NO_PRIORITIES warning messages.
2000-03-17 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in: Added the missing POSIX_NO_YIELD and
POSIX_NO_PRIORITIES warning messages.
* configure.in: Use AC_TRY_RUN instead of AC_TRY_LINK, to test for
real thread support. On solaris pthread_create can be linked to
even in -lc, but it doesn't work then.
* configure.in: Don't use priorities for threads, when the
minimal/maximal priorities couldn't be determined at configure
time.
* configure.in, gthread.c: Always define GSystemThread in
glibconfig.h to represent a system thread.
* configure.in: Do not use native recursive threads, when
possibe. We use some features, that they do not expose (namely the
depth counter).
* glib.h, gthread.c: Redefined GStaticRecMutex. The functions are
now implemented in a different way, which should be way
faster. Alsothere are now functions g_static_rec_mutex_unlock_full
and g_static_rec_mutex_lock_full to leave/enter a recursive mutex
completly.
* gthread.c (g_thread_self): Do not test the system_thread to be
non-zero to speed things up.
* gthread.c (g_mutex_init): Therefore set the system_thread of the
main thread here.
* tests/thread-test.c: Rerun all tests once again, but this time
we fool the system into thinking, that the available thread system
is not native, but userprovided.
* gthread/gthread-posix.c: Don't use priorities for threads,
when the minimal/maximal priorities couldn't be determined at
configure time.
* gthread/gthread-posix.c: Don't check for errors, when
setting the scope of a tread to system, as some posix
implementations can't do that and we don't want the thing to
fail because of that.
2000-03-17 15:49:59 +01:00
|
|
|
posix_priority_min=-1
|
|
|
|
posix_priority_max=-1
|
2000-02-13 08:18:23 +01:00
|
|
|
else
|
|
|
|
AC_MSG_RESULT($posix_priority_min/$posix_priority_max)
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_DEFINE_UNQUOTED(POSIX_MIN_PRIORITY,$posix_priority_min,[Minimum POSIX RT priority])
|
|
|
|
AC_DEFINE_UNQUOTED(POSIX_MAX_PRIORITY,$posix_priority_max,[Maximum POSIX RT priority])
|
2000-02-13 08:18:23 +01:00
|
|
|
fi
|
|
|
|
posix_yield_func=none
|
|
|
|
AC_MSG_CHECKING(for posix yield function)
|
2000-03-22 11:04:29 +01:00
|
|
|
for yield_func in sched_yield pthread_yield_np pthread_yield \
|
2000-02-13 08:18:23 +01:00
|
|
|
thr_yield; do
|
|
|
|
AC_TRY_LINK([#include <pthread.h>],
|
|
|
|
[$yield_func()],
|
|
|
|
[posix_yield_func="$yield_func"
|
|
|
|
break])
|
|
|
|
done
|
|
|
|
if test x"$posix_yield_func" = xnone; then
|
|
|
|
AC_MSG_RESULT(none found)
|
|
|
|
AC_MSG_WARN($POSIX_NO_YIELD)
|
2000-03-22 11:04:29 +01:00
|
|
|
posix_yield_func="g_usleep(1000)"
|
2000-02-13 08:18:23 +01:00
|
|
|
else
|
|
|
|
AC_MSG_RESULT($posix_yield_func)
|
|
|
|
posix_yield_func="$posix_yield_func()"
|
|
|
|
fi
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_DEFINE_UNQUOTED(POSIX_YIELD_FUNC,$posix_yield_func,[The POSIX RT yield function])
|
Added the missing POSIX_NO_YIELD and POSIX_NO_PRIORITIES warning messages.
2000-03-17 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in: Added the missing POSIX_NO_YIELD and
POSIX_NO_PRIORITIES warning messages.
* configure.in: Use AC_TRY_RUN instead of AC_TRY_LINK, to test for
real thread support. On solaris pthread_create can be linked to
even in -lc, but it doesn't work then.
* configure.in: Don't use priorities for threads, when the
minimal/maximal priorities couldn't be determined at configure
time.
* configure.in, gthread.c: Always define GSystemThread in
glibconfig.h to represent a system thread.
* configure.in: Do not use native recursive threads, when
possibe. We use some features, that they do not expose (namely the
depth counter).
* glib.h, gthread.c: Redefined GStaticRecMutex. The functions are
now implemented in a different way, which should be way
faster. Alsothere are now functions g_static_rec_mutex_unlock_full
and g_static_rec_mutex_lock_full to leave/enter a recursive mutex
completly.
* gthread.c (g_thread_self): Do not test the system_thread to be
non-zero to speed things up.
* gthread.c (g_mutex_init): Therefore set the system_thread of the
main thread here.
* tests/thread-test.c: Rerun all tests once again, but this time
we fool the system into thinking, that the available thread system
is not native, but userprovided.
* gthread/gthread-posix.c: Don't use priorities for threads,
when the minimal/maximal priorities couldn't be determined at
configure time.
* gthread/gthread-posix.c: Don't check for errors, when
setting the scope of a tread to system, as some posix
implementations can't do that and we don't want the thing to
fail because of that.
2000-03-17 15:49:59 +01:00
|
|
|
CPPFLAGS="$glib_save_CPPFLAGS"
|
2000-11-21 16:27:44 +01:00
|
|
|
|
|
|
|
AC_MSG_CHECKING(whether to use the PID niceness surrogate for thread priorities)
|
|
|
|
AC_TRY_RUN([#include <pthread.h>
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
pid_t other_pid = 0;
|
|
|
|
|
|
|
|
void* func(void* data) {other_pid = getpid();}
|
|
|
|
main()
|
|
|
|
{ pthread_t t;
|
|
|
|
void *ret;
|
|
|
|
pthread_create (&t, $defattr, func, NULL);
|
|
|
|
pthread_join (t, &ret);
|
|
|
|
exit (getpid()==other_pid ||
|
|
|
|
$posix_priority_min != $posix_priority_max);
|
|
|
|
}],
|
|
|
|
[AC_MSG_RESULT(yes),
|
2000-12-29 16:11:03 +01:00
|
|
|
AC_DEFINE(G_THREAD_USE_PID_SURROGATE, 1, [whether to use the PID niceness surrogate for thread priorities])
|
|
|
|
],
|
2000-11-21 16:27:44 +01:00
|
|
|
[AC_MSG_RESULT(no)])
|
Added the missing POSIX_NO_YIELD and POSIX_NO_PRIORITIES warning messages.
2000-03-17 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in: Added the missing POSIX_NO_YIELD and
POSIX_NO_PRIORITIES warning messages.
* configure.in: Use AC_TRY_RUN instead of AC_TRY_LINK, to test for
real thread support. On solaris pthread_create can be linked to
even in -lc, but it doesn't work then.
* configure.in: Don't use priorities for threads, when the
minimal/maximal priorities couldn't be determined at configure
time.
* configure.in, gthread.c: Always define GSystemThread in
glibconfig.h to represent a system thread.
* configure.in: Do not use native recursive threads, when
possibe. We use some features, that they do not expose (namely the
depth counter).
* glib.h, gthread.c: Redefined GStaticRecMutex. The functions are
now implemented in a different way, which should be way
faster. Alsothere are now functions g_static_rec_mutex_unlock_full
and g_static_rec_mutex_lock_full to leave/enter a recursive mutex
completly.
* gthread.c (g_thread_self): Do not test the system_thread to be
non-zero to speed things up.
* gthread.c (g_mutex_init): Therefore set the system_thread of the
main thread here.
* tests/thread-test.c: Rerun all tests once again, but this time
we fool the system into thinking, that the available thread system
is not native, but userprovided.
* gthread/gthread-posix.c: Don't use priorities for threads,
when the minimal/maximal priorities couldn't be determined at
configure time.
* gthread/gthread-posix.c: Don't check for errors, when
setting the scope of a tread to system, as some posix
implementations can't do that and we don't want the thing to
fail because of that.
2000-03-17 15:49:59 +01:00
|
|
|
else # solaris threads
|
2000-12-29 16:11:03 +01:00
|
|
|
GLIB_SIZEOF([#include <thread.h>], thread_t, system_thread)
|
2000-02-13 08:18:23 +01:00
|
|
|
fi
|
|
|
|
|
|
|
|
LIBS="$glib_save_LIBS"
|
|
|
|
|
|
|
|
# now spit out all the warnings.
|
2000-11-15 18:48:43 +01:00
|
|
|
if test "$ac_cv_func_posix_getpwuid_r" != "yes" &&
|
|
|
|
test "$ac_cv_func_nonposix_getpwuid_r" != "yes"; then
|
2000-02-13 08:18:23 +01:00
|
|
|
AC_MSG_WARN($FUNC_NO_GETPWUID_R)
|
|
|
|
fi
|
|
|
|
if test "$ac_cv_func_localtime_r" != "yes"; then
|
|
|
|
AC_MSG_WARN($FUNC_NO_LOCALTIME_R)
|
|
|
|
fi
|
Added the missing POSIX_NO_YIELD and POSIX_NO_PRIORITIES warning messages.
2000-03-17 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in: Added the missing POSIX_NO_YIELD and
POSIX_NO_PRIORITIES warning messages.
* configure.in: Use AC_TRY_RUN instead of AC_TRY_LINK, to test for
real thread support. On solaris pthread_create can be linked to
even in -lc, but it doesn't work then.
* configure.in: Don't use priorities for threads, when the
minimal/maximal priorities couldn't be determined at configure
time.
* configure.in, gthread.c: Always define GSystemThread in
glibconfig.h to represent a system thread.
* configure.in: Do not use native recursive threads, when
possibe. We use some features, that they do not expose (namely the
depth counter).
* glib.h, gthread.c: Redefined GStaticRecMutex. The functions are
now implemented in a different way, which should be way
faster. Alsothere are now functions g_static_rec_mutex_unlock_full
and g_static_rec_mutex_lock_full to leave/enter a recursive mutex
completly.
* gthread.c (g_thread_self): Do not test the system_thread to be
non-zero to speed things up.
* gthread.c (g_mutex_init): Therefore set the system_thread of the
main thread here.
* tests/thread-test.c: Rerun all tests once again, but this time
we fool the system into thinking, that the available thread system
is not native, but userprovided.
* gthread/gthread-posix.c: Don't use priorities for threads,
when the minimal/maximal priorities couldn't be determined at
configure time.
* gthread/gthread-posix.c: Don't check for errors, when
setting the scope of a tread to system, as some posix
implementations can't do that and we don't want the thing to
fail because of that.
2000-03-17 15:49:59 +01:00
|
|
|
else
|
|
|
|
# If no thread implementation exists, we will provide enough
|
|
|
|
# space for a pointer
|
|
|
|
GLIB_SIZEOF(, void*, system_thread)
|
|
|
|
fi
|
2000-02-13 08:18:23 +01:00
|
|
|
|
2000-10-16 03:02:19 +02:00
|
|
|
AC_DEFINE_UNQUOTED(G_THREAD_SOURCE,"gthread-$have_threads.c",
|
|
|
|
[Source file containing theread implementation])
|
2000-02-13 08:18:23 +01:00
|
|
|
AC_SUBST(G_THREAD_CFLAGS)
|
|
|
|
AC_SUBST(G_THREAD_LIBS)
|
|
|
|
AC_SUBST(G_THREAD_LIBS_EXTRA)
|
|
|
|
|
|
|
|
dnl **********************************************
|
|
|
|
dnl *** GDefaultMutex setup and initialization ***
|
|
|
|
dnl **********************************************
|
|
|
|
dnl
|
|
|
|
dnl if mutex_has_default = yes, we also got
|
|
|
|
dnl mutex_default_type, mutex_default_init and mutex_header_file
|
|
|
|
GLIB_IF_VAR_EQ(mutex_has_default, yes,
|
Added the missing POSIX_NO_YIELD and POSIX_NO_PRIORITIES warning messages.
2000-03-17 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in: Added the missing POSIX_NO_YIELD and
POSIX_NO_PRIORITIES warning messages.
* configure.in: Use AC_TRY_RUN instead of AC_TRY_LINK, to test for
real thread support. On solaris pthread_create can be linked to
even in -lc, but it doesn't work then.
* configure.in: Don't use priorities for threads, when the
minimal/maximal priorities couldn't be determined at configure
time.
* configure.in, gthread.c: Always define GSystemThread in
glibconfig.h to represent a system thread.
* configure.in: Do not use native recursive threads, when
possibe. We use some features, that they do not expose (namely the
depth counter).
* glib.h, gthread.c: Redefined GStaticRecMutex. The functions are
now implemented in a different way, which should be way
faster. Alsothere are now functions g_static_rec_mutex_unlock_full
and g_static_rec_mutex_lock_full to leave/enter a recursive mutex
completly.
* gthread.c (g_thread_self): Do not test the system_thread to be
non-zero to speed things up.
* gthread.c (g_mutex_init): Therefore set the system_thread of the
main thread here.
* tests/thread-test.c: Rerun all tests once again, but this time
we fool the system into thinking, that the available thread system
is not native, but userprovided.
* gthread/gthread-posix.c: Don't use priorities for threads,
when the minimal/maximal priorities couldn't be determined at
configure time.
* gthread/gthread-posix.c: Don't check for errors, when
setting the scope of a tread to system, as some posix
implementations can't do that and we don't want the thing to
fail because of that.
2000-03-17 15:49:59 +01:00
|
|
|
glib_save_CPPFLAGS="$CPPFLAGS"
|
|
|
|
glib_save_LIBS="$LIBS"
|
|
|
|
LIBS="$LIBS $G_THREAD_LIBS"
|
|
|
|
CPPFLAGS="$CPPFLAGS $GTHREAD_COMPILE_IMPL_DEFINES"
|
2000-02-13 08:18:23 +01:00
|
|
|
GLIB_SIZEOF([#include <$mutex_header_file>],
|
|
|
|
$mutex_default_type,
|
|
|
|
gmutex,
|
|
|
|
)
|
|
|
|
GLIB_BYTE_CONTENTS([#include <$mutex_header_file>],
|
|
|
|
$mutex_default_type,
|
|
|
|
gmutex,
|
|
|
|
$glib_cv_sizeof_gmutex,
|
|
|
|
$mutex_default_init)
|
|
|
|
if test x"$glib_cv_byte_contents_gmutex" = xno; then
|
|
|
|
mutex_has_default=no
|
|
|
|
fi
|
Added the missing POSIX_NO_YIELD and POSIX_NO_PRIORITIES warning messages.
2000-03-17 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in: Added the missing POSIX_NO_YIELD and
POSIX_NO_PRIORITIES warning messages.
* configure.in: Use AC_TRY_RUN instead of AC_TRY_LINK, to test for
real thread support. On solaris pthread_create can be linked to
even in -lc, but it doesn't work then.
* configure.in: Don't use priorities for threads, when the
minimal/maximal priorities couldn't be determined at configure
time.
* configure.in, gthread.c: Always define GSystemThread in
glibconfig.h to represent a system thread.
* configure.in: Do not use native recursive threads, when
possibe. We use some features, that they do not expose (namely the
depth counter).
* glib.h, gthread.c: Redefined GStaticRecMutex. The functions are
now implemented in a different way, which should be way
faster. Alsothere are now functions g_static_rec_mutex_unlock_full
and g_static_rec_mutex_lock_full to leave/enter a recursive mutex
completly.
* gthread.c (g_thread_self): Do not test the system_thread to be
non-zero to speed things up.
* gthread.c (g_mutex_init): Therefore set the system_thread of the
main thread here.
* tests/thread-test.c: Rerun all tests once again, but this time
we fool the system into thinking, that the available thread system
is not native, but userprovided.
* gthread/gthread-posix.c: Don't use priorities for threads,
when the minimal/maximal priorities couldn't be determined at
configure time.
* gthread/gthread-posix.c: Don't check for errors, when
setting the scope of a tread to system, as some posix
implementations can't do that and we don't want the thing to
fail because of that.
2000-03-17 15:49:59 +01:00
|
|
|
CPPFLAGS="$glib_save_CPPFLAGS"
|
|
|
|
LIBS="$glib_save_LIBS"
|
2000-02-13 08:18:23 +01:00
|
|
|
,
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
dnl ****************************************
|
|
|
|
dnl *** GLib POLL* compatibility defines ***
|
|
|
|
dnl ****************************************
|
|
|
|
GLIB_SYSDEFS(
|
|
|
|
[#include <sys/types.h>
|
|
|
|
#include <sys/poll.h>],
|
|
|
|
POLLIN:1 POLLOUT:4 POLLPRI:2 POLLERR:8 POLLHUP:16 POLLNVAL:32,
|
|
|
|
glibconfig-sysdefs.h,
|
|
|
|
=)
|
|
|
|
|
2000-11-13 00:44:28 +01:00
|
|
|
dnl ***********************
|
|
|
|
dnl *** Tests for iconv ***
|
|
|
|
dnl ***********************
|
|
|
|
|
|
|
|
AC_ARG_WITH(libiconv, [ --with-libiconv Use the libiconv library ],,with_libiconv=maybe)
|
|
|
|
|
|
|
|
found_iconv=no
|
|
|
|
|
|
|
|
if test "x$with_libiconv" != "xyes" ; then
|
|
|
|
#
|
|
|
|
# Check in the C library
|
|
|
|
#
|
|
|
|
AC_CHECK_FUNC(iconv_open, with_libiconv=no; found_iconv=yes)
|
|
|
|
fi
|
|
|
|
|
|
|
|
if test "x$with_libiconv" != "xno" ; then
|
|
|
|
#
|
|
|
|
# Check for libiconv
|
|
|
|
#
|
|
|
|
AC_CHECK_LIB(iconv, libiconv_open, with_libiconv=yes; found_iconv=yes)
|
|
|
|
fi
|
|
|
|
|
|
|
|
if test "x$found_iconv" = "xno" ; then
|
|
|
|
AC_MSG_ERROR([*** No iconv() implementation found in C library or libiconv])
|
|
|
|
fi
|
|
|
|
|
|
|
|
if test "x$with_libiconv" = "xyes" ; then
|
|
|
|
ICONV_LIBS="-liconv"
|
|
|
|
AC_DEFINE(USE_LIBICONV)
|
|
|
|
fi
|
|
|
|
AC_SUBST(ICONV_LIBS)
|
|
|
|
|
|
|
|
dnl If the system doesn't define EILSEQ, we should define EILSEQ ourselves
|
|
|
|
dnl since we need it for g_iconv()
|
|
|
|
|
|
|
|
AC_MSG_CHECKING([for EILSEQ])
|
|
|
|
AC_TRY_COMPILE([
|
|
|
|
#include <errno.h>
|
|
|
|
],
|
|
|
|
[
|
|
|
|
int error = EILSEQ;
|
|
|
|
], have_eilseq=yes, have_eilseq=no);
|
|
|
|
AC_MSG_RESULT($have_eilseq)
|
|
|
|
|
2000-09-06 02:17:41 +02:00
|
|
|
dnl **************************
|
|
|
|
dnl *** Checks for gtk-doc ***
|
|
|
|
dnl **************************
|
|
|
|
|
|
|
|
AC_ARG_WITH(html-dir, [ --with-html-dir=PATH path to installed docs ])
|
|
|
|
|
|
|
|
if test "x$with_html_dir" = "x" ; then
|
|
|
|
HTML_DIR='${datadir}/gtk-doc/html'
|
|
|
|
else
|
|
|
|
HTML_DIR=$with_html_dir
|
|
|
|
fi
|
|
|
|
|
|
|
|
AC_SUBST(HTML_DIR)
|
|
|
|
|
|
|
|
AC_CHECK_PROG(GTKDOC, gtkdoc-mkdb, true, false)
|
2001-02-12 21:25:58 +01:00
|
|
|
|
|
|
|
gtk_doc_min_version=0.6
|
|
|
|
if $GTKDOC ; then
|
|
|
|
gtk_doc_version=`gtkdoc-mkdb --version`
|
|
|
|
AC_MSG_CHECKING([gtk-doc version ($gtk_doc_version) >= $gtk_doc_min_version])
|
|
|
|
if perl <<EOF ; then
|
|
|
|
exit (("$gtk_doc_version" =~ /^[[0-9]]+\.[[0-9]]+$/) &&
|
|
|
|
("$gtk_doc_version" >= "$gtk_doc_min_version") ? 0 : 1);
|
|
|
|
EOF
|
|
|
|
AC_MSG_RESULT(yes)
|
|
|
|
else
|
|
|
|
AC_MSG_RESULT(no)
|
|
|
|
GTKDOC=false
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2000-09-06 02:17:41 +02:00
|
|
|
AM_CONDITIONAL(HAVE_GTK_DOC, $GTKDOC)
|
|
|
|
AC_SUBST(HAVE_GTK_DOC)
|
|
|
|
|
|
|
|
AC_CHECK_PROG(DB2HTML, db2html, true, false)
|
|
|
|
AM_CONDITIONAL(HAVE_DOCBOOK, $DB2HTML)
|
|
|
|
|
|
|
|
dnl Let people disable the gtk-doc stuff.
|
|
|
|
AC_ARG_ENABLE(gtk-doc, [ --enable-gtk-doc Use gtk-doc to build documentation [default=auto]], enable_gtk_doc="$enableval", enable_gtk_doc=auto)
|
|
|
|
|
|
|
|
if test x$enable_gtk_doc = xauto ; then
|
|
|
|
if test x$GTKDOC = xtrue ; then
|
|
|
|
enable_gtk_doc=yes
|
|
|
|
else
|
|
|
|
enable_gtk_doc=no
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
dnl NOTE: We need to use a separate automake conditional for this
|
|
|
|
dnl to make this work with the tarballs.
|
|
|
|
AM_CONDITIONAL(ENABLE_GTK_DOC, test x$enable_gtk_doc = xyes)
|
2000-02-13 08:18:23 +01:00
|
|
|
|
|
|
|
dnl ******************************
|
|
|
|
dnl *** output the whole stuff ***
|
|
|
|
dnl ******************************
|
|
|
|
|
|
|
|
AC_OUTPUT_COMMANDS([
|
|
|
|
|
|
|
|
## Generate `glibconfig.h' in two cases
|
|
|
|
## 1. `config.status' is run either explicitly, or via configure.
|
|
|
|
## Esp. not when it is run in `Makefile' to generate makefiles and
|
|
|
|
## config.h
|
|
|
|
## 2. CONFIG_OTHER is set explicitly
|
|
|
|
##
|
|
|
|
## Case 1 is difficult. We know that `automake' sets one of
|
|
|
|
## CONFIG_FILES or CONFIG_HEADERS to empty. This heuristic works
|
|
|
|
## only when AM_CONFIG_HEADER is set, however.
|
|
|
|
|
|
|
|
if test -n "${CONFIG_FILES}" && test -n "${CONFIG_HEADERS}"; then
|
|
|
|
# Both CONFIG_FILES and CONFIG_HEADERS are non-empty ==> Case 1
|
|
|
|
CONFIG_OTHER=${CONFIG_OTHER:-glibconfig.h}
|
|
|
|
fi
|
|
|
|
case "$CONFIG_OTHER" in
|
|
|
|
*glibconfig.h*)
|
|
|
|
echo creating glibconfig.h
|
|
|
|
outfile=glibconfig.h-tmp
|
|
|
|
cat > $outfile <<\_______EOF
|
|
|
|
/* glibconfig.h
|
|
|
|
*
|
2000-10-09 23:06:01 +02:00
|
|
|
* This is a generated file. Please modify 'configure.in'
|
2000-02-13 08:18:23 +01:00
|
|
|
*/
|
|
|
|
|
Split glib.h into many header files mostly according to the resp.
2000-10-12 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* glib.h, galloca.h, garray.h, gasyncqueue.h, gbacktrace.h,
gcache.h, gcompletion.h, gconvert.h, gdataset.h, gdate.h, ghash.h,
ghook.h, giochannel.h, glist.h , gmacros.h, gmain.h, gmem.h,
gmessages.h, gnode.h, gprimes.h, gquark.h, gqueue.h, grand.h,
grel.h, gscanner.h, gslist.h, gstrfuncs.h, gstring.h, gthread.h,
gthreadpool.h, gtimer.h, gtree.h, gtypes.h, gutils.h: Split glib.h
into many header files mostly according to the resp. *.c-files.
* gmacros.h: Added G_BEGIN_DECLS and G_END_DECLS to mean: 'in case
of C++: extern "C" { ... }' analogous to glibc __BEGIN_DECLS and
__END_DECLS.
* configure.in, gerror.h, gfileutils.h, gshell.h, gspawn.h,
gunicode.h, : Changed guard-macro names to something more
consistent.
* configure.in, *.h: Use G_BEGIN_DECLS and G_END_DECLS.
2000-10-12 13:52:07 +02:00
|
|
|
#ifndef __G_LIBCONFIG_H__
|
|
|
|
#define __G_LIBCONFIG_H__
|
|
|
|
|
|
|
|
#include <gmacros.h>
|
2000-02-13 08:18:23 +01:00
|
|
|
|
|
|
|
_______EOF
|
|
|
|
|
|
|
|
if test x$glib_limits_h = xyes; then
|
|
|
|
echo '#include <limits.h>' >> $outfile
|
|
|
|
fi
|
|
|
|
if test x$glib_float_h = xyes; then
|
|
|
|
echo '#include <float.h>' >> $outfile
|
|
|
|
fi
|
|
|
|
if test x$glib_values_h = xyes; then
|
|
|
|
echo '#include <values.h>' >> $outfile
|
|
|
|
fi
|
2000-09-18 00:18:48 +02:00
|
|
|
if test "$glib_header_alloca_h" = "yes"; then
|
2000-10-12 10:06:16 +02:00
|
|
|
echo '#define GLIB_HAVE_ALLOCA_H' >> $outfile
|
2000-09-18 00:18:48 +02:00
|
|
|
fi
|
2000-02-13 08:18:23 +01:00
|
|
|
if test x$glib_sys_poll_h = xyes; then
|
|
|
|
echo '#define GLIB_HAVE_SYS_POLL_H' >> $outfile
|
|
|
|
fi
|
|
|
|
|
|
|
|
cat >> $outfile <<_______EOF
|
|
|
|
|
Split glib.h into many header files mostly according to the resp.
2000-10-12 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* glib.h, galloca.h, garray.h, gasyncqueue.h, gbacktrace.h,
gcache.h, gcompletion.h, gconvert.h, gdataset.h, gdate.h, ghash.h,
ghook.h, giochannel.h, glist.h , gmacros.h, gmain.h, gmem.h,
gmessages.h, gnode.h, gprimes.h, gquark.h, gqueue.h, grand.h,
grel.h, gscanner.h, gslist.h, gstrfuncs.h, gstring.h, gthread.h,
gthreadpool.h, gtimer.h, gtree.h, gtypes.h, gutils.h: Split glib.h
into many header files mostly according to the resp. *.c-files.
* gmacros.h: Added G_BEGIN_DECLS and G_END_DECLS to mean: 'in case
of C++: extern "C" { ... }' analogous to glibc __BEGIN_DECLS and
__END_DECLS.
* configure.in, gerror.h, gfileutils.h, gshell.h, gspawn.h,
gunicode.h, : Changed guard-macro names to something more
consistent.
* configure.in, *.h: Use G_BEGIN_DECLS and G_END_DECLS.
2000-10-12 13:52:07 +02:00
|
|
|
G_BEGIN_DECLS
|
2000-07-19 16:01:22 +02:00
|
|
|
|
2000-02-13 08:18:23 +01:00
|
|
|
#define G_MINFLOAT $glib_mf
|
|
|
|
#define G_MAXFLOAT $glib_Mf
|
|
|
|
#define G_MINDOUBLE $glib_md
|
|
|
|
#define G_MAXDOUBLE $glib_Md
|
|
|
|
#define G_MINSHORT $glib_ms
|
|
|
|
#define G_MAXSHORT $glib_Ms
|
|
|
|
#define G_MAXUSHORT $glib_Mus
|
|
|
|
#define G_MININT $glib_mi
|
|
|
|
#define G_MAXINT $glib_Mi
|
|
|
|
#define G_MAXUINT $glib_Mui
|
|
|
|
#define G_MINLONG $glib_ml
|
|
|
|
#define G_MAXLONG $glib_Ml
|
|
|
|
#define G_MAXULONG $glib_Mul
|
|
|
|
|
|
|
|
_______EOF
|
|
|
|
|
|
|
|
|
|
|
|
### this should always be true in a modern C/C++ compiler
|
|
|
|
cat >>$outfile <<_______EOF
|
|
|
|
typedef signed char gint8;
|
|
|
|
typedef unsigned char guint8;
|
|
|
|
_______EOF
|
|
|
|
|
|
|
|
|
|
|
|
if test -n "$gint16"; then
|
|
|
|
cat >>$outfile <<_______EOF
|
|
|
|
typedef signed $gint16 gint16;
|
|
|
|
typedef unsigned $gint16 guint16;
|
|
|
|
#define G_GINT16_FORMAT $gint16_format
|
|
|
|
#define G_GUINT16_FORMAT $guint16_format
|
|
|
|
_______EOF
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
if test -n "$gint32"; then
|
|
|
|
cat >>$outfile <<_______EOF
|
|
|
|
typedef signed $gint32 gint32;
|
|
|
|
typedef unsigned $gint32 guint32;
|
|
|
|
#define G_GINT32_FORMAT $gint32_format
|
|
|
|
#define G_GUINT32_FORMAT $guint32_format
|
|
|
|
_______EOF
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
if test -n "$gint64"; then
|
|
|
|
cat >>$outfile <<_______EOF
|
2000-03-21 16:21:41 +01:00
|
|
|
#define G_HAVE_GINT64 1
|
2000-02-13 08:18:23 +01:00
|
|
|
|
|
|
|
${glib_extension}typedef signed $gint64 gint64;
|
|
|
|
${glib_extension}typedef unsigned $gint64 guint64;
|
|
|
|
|
2000-09-28 09:45:04 +02:00
|
|
|
#define G_GINT64_CONSTANT(val) $gint64_constant
|
|
|
|
_______EOF
|
|
|
|
if test -n "$gint64_format"; then
|
|
|
|
cat >>$outfile <<_______EOF
|
2000-02-13 08:18:23 +01:00
|
|
|
#define G_GINT64_FORMAT $gint64_format
|
|
|
|
#define G_GUINT64_FORMAT $guint64_format
|
|
|
|
_______EOF
|
2000-09-28 09:54:40 +02:00
|
|
|
fi
|
2000-09-28 09:45:04 +02:00
|
|
|
fi
|
2000-02-13 08:18:23 +01:00
|
|
|
|
2000-12-29 03:16:51 +01:00
|
|
|
cat >>$outfile <<_______EOF
|
|
|
|
|
|
|
|
#define GLIB_SIZEOF_VOID_P $glib_void_p
|
|
|
|
#define GLIB_SIZEOF_LONG $glib_long
|
|
|
|
|
|
|
|
_______EOF
|
|
|
|
|
2000-07-26 05:18:27 +02:00
|
|
|
case x$glib_size_t in
|
|
|
|
x2) echo "typedef gint16 gssize;" >> $outfile
|
|
|
|
echo "typedef guint16 gsize;" >> $outfile
|
|
|
|
;;
|
|
|
|
x4) echo "typedef gint32 gssize;" >> $outfile
|
|
|
|
echo "typedef guint32 gsize;" >> $outfile
|
|
|
|
;;
|
|
|
|
x8) echo "typedef gint64 gssize;" >> $outfile
|
|
|
|
echo "typedef guint64 gsize;" >> $outfile
|
|
|
|
;;
|
|
|
|
*) echo "#error size of size_t is unknown" >> $outfile
|
|
|
|
;;
|
|
|
|
esac
|
2000-02-13 08:18:23 +01:00
|
|
|
|
|
|
|
if test -z "$glib_unknown_void_p"; then
|
|
|
|
cat >>$outfile <<_______EOF
|
|
|
|
|
|
|
|
#define GPOINTER_TO_INT(p) ((gint) ${glib_gpi_cast} (p))
|
|
|
|
#define GPOINTER_TO_UINT(p) ((guint) ${glib_gpui_cast} (p))
|
|
|
|
|
|
|
|
#define GINT_TO_POINTER(i) ((gpointer) ${glib_gpi_cast} (i))
|
|
|
|
#define GUINT_TO_POINTER(u) ((gpointer) ${glib_gpui_cast} (u))
|
|
|
|
_______EOF
|
|
|
|
else
|
|
|
|
echo '#error SIZEOF_VOID_P unknown - This should never happen' >>$outfile
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
cat >>$outfile <<_______EOF
|
|
|
|
$glib_atexit
|
|
|
|
$glib_memmove
|
|
|
|
$glib_defines
|
|
|
|
$glib_os
|
|
|
|
|
|
|
|
$glib_vacopy
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
#define G_HAVE_INLINE 1
|
|
|
|
#else /* !__cplusplus */
|
|
|
|
$glib_inline
|
|
|
|
#endif /* !__cplusplus */
|
|
|
|
_______EOF
|
|
|
|
|
2000-11-13 00:44:28 +01:00
|
|
|
echo >>$outfile
|
|
|
|
if test x$g_have_eilseq = xno; then
|
|
|
|
cat >>$outfile <<_______EOF
|
|
|
|
#ifndef EILSEQ
|
|
|
|
/* On some systems, like SunOS and NetBSD, EILSEQ is not defined.
|
|
|
|
* The correspondence between this and the corresponding definition
|
|
|
|
* in libiconv is essential.
|
|
|
|
*/
|
|
|
|
# define EILSEQ ENOENT
|
|
|
|
#endif
|
|
|
|
_______EOF
|
|
|
|
|
|
|
|
fi
|
|
|
|
|
2000-02-13 08:18:23 +01:00
|
|
|
echo >>$outfile
|
|
|
|
if test x$g_mutex_has_default = xyes; then
|
|
|
|
cat >>$outfile <<_______EOF
|
|
|
|
$g_enable_threads_def G_THREADS_ENABLED
|
|
|
|
#define G_THREADS_IMPL_$g_threads_impl_def
|
|
|
|
typedef struct _GStaticMutex GStaticMutex;
|
|
|
|
struct _GStaticMutex
|
|
|
|
{
|
|
|
|
struct _GMutex *runtime_mutex;
|
2001-01-30 15:16:56 +01:00
|
|
|
union {
|
|
|
|
char pad[$g_mutex_sizeof];
|
|
|
|
double dummy_double;
|
|
|
|
void *dummy_pointer;
|
|
|
|
long dummy_long;
|
2000-09-29 15:10:41 +02:00
|
|
|
} static_mutex;
|
2000-02-13 08:18:23 +01:00
|
|
|
};
|
2001-01-30 15:16:56 +01:00
|
|
|
#define G_STATIC_MUTEX_INIT { NULL, { { $g_mutex_contents} } }
|
2000-02-13 08:18:23 +01:00
|
|
|
#define g_static_mutex_get_mutex(mutex) \
|
2000-09-29 15:10:41 +02:00
|
|
|
(g_thread_use_default_impl ? ((GMutex*) &((mutex)->static_mutex)) : \
|
2000-02-13 08:18:23 +01:00
|
|
|
g_static_mutex_get_mutex_impl (&((mutex)->runtime_mutex)))
|
|
|
|
_______EOF
|
|
|
|
else
|
|
|
|
cat >>$outfile <<_______EOF
|
|
|
|
$g_enable_threads_def G_THREADS_ENABLED
|
|
|
|
#define G_THREADS_IMPL_$g_threads_impl_def
|
|
|
|
typedef struct _GMutex* GStaticMutex;
|
|
|
|
#define G_STATIC_MUTEX_INIT NULL
|
|
|
|
#define g_static_mutex_get_mutex(mutex) (g_static_mutex_get_mutex_impl (mutex))
|
|
|
|
_______EOF
|
|
|
|
fi
|
Added the missing POSIX_NO_YIELD and POSIX_NO_PRIORITIES warning messages.
2000-03-17 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in: Added the missing POSIX_NO_YIELD and
POSIX_NO_PRIORITIES warning messages.
* configure.in: Use AC_TRY_RUN instead of AC_TRY_LINK, to test for
real thread support. On solaris pthread_create can be linked to
even in -lc, but it doesn't work then.
* configure.in: Don't use priorities for threads, when the
minimal/maximal priorities couldn't be determined at configure
time.
* configure.in, gthread.c: Always define GSystemThread in
glibconfig.h to represent a system thread.
* configure.in: Do not use native recursive threads, when
possibe. We use some features, that they do not expose (namely the
depth counter).
* glib.h, gthread.c: Redefined GStaticRecMutex. The functions are
now implemented in a different way, which should be way
faster. Alsothere are now functions g_static_rec_mutex_unlock_full
and g_static_rec_mutex_lock_full to leave/enter a recursive mutex
completly.
* gthread.c (g_thread_self): Do not test the system_thread to be
non-zero to speed things up.
* gthread.c (g_mutex_init): Therefore set the system_thread of the
main thread here.
* tests/thread-test.c: Rerun all tests once again, but this time
we fool the system into thinking, that the available thread system
is not native, but userprovided.
* gthread/gthread-posix.c: Don't use priorities for threads,
when the minimal/maximal priorities couldn't be determined at
configure time.
* gthread/gthread-posix.c: Don't check for errors, when
setting the scope of a tread to system, as some posix
implementations can't do that and we don't want the thing to
fail because of that.
2000-03-17 15:49:59 +01:00
|
|
|
|
|
|
|
cat >>$outfile <<_______EOF
|
|
|
|
/* This represents a system thread as used by the implementation. An
|
|
|
|
* alien implementaion, as loaded by g_thread_init can only count on
|
|
|
|
* "sizeof (gpointer)" bytes to store their info. We however need more
|
|
|
|
* for some of our native implementations. */
|
|
|
|
typedef union _GSystemThread GSystemThread;
|
|
|
|
union _GSystemThread
|
2000-02-13 08:18:23 +01:00
|
|
|
{
|
Added the missing POSIX_NO_YIELD and POSIX_NO_PRIORITIES warning messages.
2000-03-17 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in: Added the missing POSIX_NO_YIELD and
POSIX_NO_PRIORITIES warning messages.
* configure.in: Use AC_TRY_RUN instead of AC_TRY_LINK, to test for
real thread support. On solaris pthread_create can be linked to
even in -lc, but it doesn't work then.
* configure.in: Don't use priorities for threads, when the
minimal/maximal priorities couldn't be determined at configure
time.
* configure.in, gthread.c: Always define GSystemThread in
glibconfig.h to represent a system thread.
* configure.in: Do not use native recursive threads, when
possibe. We use some features, that they do not expose (namely the
depth counter).
* glib.h, gthread.c: Redefined GStaticRecMutex. The functions are
now implemented in a different way, which should be way
faster. Alsothere are now functions g_static_rec_mutex_unlock_full
and g_static_rec_mutex_lock_full to leave/enter a recursive mutex
completly.
* gthread.c (g_thread_self): Do not test the system_thread to be
non-zero to speed things up.
* gthread.c (g_mutex_init): Therefore set the system_thread of the
main thread here.
* tests/thread-test.c: Rerun all tests once again, but this time
we fool the system into thinking, that the available thread system
is not native, but userprovided.
* gthread/gthread-posix.c: Don't use priorities for threads,
when the minimal/maximal priorities couldn't be determined at
configure time.
* gthread/gthread-posix.c: Don't check for errors, when
setting the scope of a tread to system, as some posix
implementations can't do that and we don't want the thing to
fail because of that.
2000-03-17 15:49:59 +01:00
|
|
|
char data[$g_system_thread_sizeof];
|
|
|
|
double dummy_double;
|
|
|
|
void *dummy_pointer;
|
|
|
|
long dummy_long;
|
2000-02-13 08:18:23 +01:00
|
|
|
};
|
|
|
|
_______EOF
|
|
|
|
|
|
|
|
echo >>$outfile
|
|
|
|
g_bit_sizes="16 32"
|
|
|
|
if test -n "$gint64"; then
|
|
|
|
g_bit_sizes="$g_bit_sizes 64"
|
|
|
|
fi
|
|
|
|
for bits in $g_bit_sizes; do
|
|
|
|
cat >>$outfile <<_______EOF
|
|
|
|
#define GINT${bits}_TO_${g_bs_native}(val) ((gint${bits}) (val))
|
|
|
|
#define GUINT${bits}_TO_${g_bs_native}(val) ((guint${bits}) (val))
|
|
|
|
#define GINT${bits}_TO_${g_bs_alien}(val) ((gint${bits}) GUINT${bits}_SWAP_LE_BE (val))
|
|
|
|
#define GUINT${bits}_TO_${g_bs_alien}(val) (GUINT${bits}_SWAP_LE_BE (val))
|
|
|
|
_______EOF
|
|
|
|
done
|
|
|
|
|
|
|
|
cat >>$outfile <<_______EOF
|
|
|
|
#define GLONG_TO_LE(val) ((glong) GINT${glongbits}_TO_LE (val))
|
|
|
|
#define GULONG_TO_LE(val) ((gulong) GUINT${glongbits}_TO_LE (val))
|
|
|
|
#define GLONG_TO_BE(val) ((glong) GINT${glongbits}_TO_BE (val))
|
|
|
|
#define GULONG_TO_BE(val) ((gulong) GUINT${glongbits}_TO_BE (val))
|
|
|
|
#define GINT_TO_LE(val) ((gint) GINT${gintbits}_TO_LE (val))
|
|
|
|
#define GUINT_TO_LE(val) ((guint) GUINT${gintbits}_TO_LE (val))
|
|
|
|
#define GINT_TO_BE(val) ((gint) GINT${gintbits}_TO_BE (val))
|
|
|
|
#define GUINT_TO_BE(val) ((guint) GUINT${gintbits}_TO_BE (val))
|
|
|
|
#define G_BYTE_ORDER $g_byte_order
|
|
|
|
|
|
|
|
_______EOF
|
|
|
|
|
|
|
|
if test -r glibconfig-sysdefs.h; then
|
|
|
|
cat glibconfig-sysdefs.h >>$outfile
|
|
|
|
fi
|
|
|
|
|
|
|
|
cat >>$outfile <<_______EOF
|
|
|
|
|
Determine the suffix of the shared librarries for this system. This is
2000-12-22 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in: Determine the suffix of the shared librarries for
this system. This is done analogous to
ltconfig.sh. G_MODULE_SUFFIX in glibconfig.h is set to either
"sl", "dll", or (most often) "so".
* tests/Makefile.am, tests/module-test.c,
tests/libmoduletestplugin_a.c, tests/libmoduletestplugin_b.c:
Added new testcase for gmodule. This is mostly copied from
gmodule/testgmodule.c, but unlike that is is quiet. (Why BTW are
some tests that verbose, not to say loquacious...)
* gmodule.c: Make g_module_open more tolerant wrt to the module
name. First it tries to open the module as named, if that fails,
it checks, whether it is a libtool archive and parses it, if that
fails it appends the systems shared library suffix
(i.e. ".so") (if not already found) and tries again and if that
fails it tries to append the ".la" libtool suffix (if not already
found) and parses it.
* gmodule.c: Lock recursive mutex during most module functions for
safety.
* gmodule-dl.c: Return an error from _g_module_symbol only, if
dlerror says so. All other functions return an error as well, if
dlerror returns NULL.
* testgmodule.c: Thanks to the above change the #ifdefs have
vanished.
* glib/glib-sections.txt: Added G_MODULE_SUFFIX.
* glib/tmpl/modules.sgml: Updated.
2000-12-22 14:44:25 +01:00
|
|
|
#define G_MODULE_SUFFIX "$g_module_suffix"
|
|
|
|
|
Split glib.h into many header files mostly according to the resp.
2000-10-12 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* glib.h, galloca.h, garray.h, gasyncqueue.h, gbacktrace.h,
gcache.h, gcompletion.h, gconvert.h, gdataset.h, gdate.h, ghash.h,
ghook.h, giochannel.h, glist.h , gmacros.h, gmain.h, gmem.h,
gmessages.h, gnode.h, gprimes.h, gquark.h, gqueue.h, grand.h,
grel.h, gscanner.h, gslist.h, gstrfuncs.h, gstring.h, gthread.h,
gthreadpool.h, gtimer.h, gtree.h, gtypes.h, gutils.h: Split glib.h
into many header files mostly according to the resp. *.c-files.
* gmacros.h: Added G_BEGIN_DECLS and G_END_DECLS to mean: 'in case
of C++: extern "C" { ... }' analogous to glibc __BEGIN_DECLS and
__END_DECLS.
* configure.in, gerror.h, gfileutils.h, gshell.h, gspawn.h,
gunicode.h, : Changed guard-macro names to something more
consistent.
* configure.in, *.h: Use G_BEGIN_DECLS and G_END_DECLS.
2000-10-12 13:52:07 +02:00
|
|
|
G_END_DECLS
|
2000-02-13 08:18:23 +01:00
|
|
|
|
|
|
|
#endif /* GLIBCONFIG_H */
|
|
|
|
_______EOF
|
|
|
|
|
|
|
|
|
|
|
|
if cmp -s $outfile glibconfig.h; then
|
|
|
|
echo glibconfig.h is unchanged
|
|
|
|
rm -f $outfile
|
|
|
|
else
|
|
|
|
mv $outfile glibconfig.h
|
|
|
|
fi ;;
|
|
|
|
esac
|
|
|
|
],[
|
|
|
|
|
|
|
|
# Note that if two cases are the same, case goes with the first one.
|
|
|
|
# Note also that this is inside an AC_OUTPUT_COMMAND. We do not depend
|
|
|
|
# on variable expansion in case labels. Look at the generated config.status
|
|
|
|
# for a hint.
|
|
|
|
|
2000-09-18 00:18:48 +02:00
|
|
|
glib_header_alloca_h="$ac_cv_header_alloca_h"
|
|
|
|
|
2000-02-13 08:18:23 +01:00
|
|
|
case xyes in
|
|
|
|
x$ac_cv_header_float_h)
|
|
|
|
glib_float_h=yes
|
|
|
|
glib_mf=FLT_MIN glib_Mf=FLT_MAX
|
|
|
|
glib_md=DBL_MIN glib_Md=DBL_MAX
|
|
|
|
;;
|
|
|
|
x$ac_cv_header_values_h)
|
|
|
|
glib_values_h=yes
|
|
|
|
glib_mf=MINFLOAT glib_Mf=MAXFLOAT
|
|
|
|
glib_md=MINDOUBLE glib_Md=MAXDOUBLE
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
case xyes in
|
|
|
|
x$ac_cv_header_limits_h)
|
|
|
|
glib_limits_h=yes
|
|
|
|
glib_ms=SHRT_MIN glib_Ms=SHRT_MAX glib_Mus=USHRT_MAX
|
|
|
|
glib_mi=INT_MIN glib_Mi=INT_MAX glib_Mui=UINT_MAX
|
|
|
|
glib_ml=LONG_MIN glib_Ml=LONG_MAX glib_Mul=ULONG_MAX
|
|
|
|
;;
|
|
|
|
x$ac_cv_header_values_h)
|
|
|
|
glib_values_h=yes
|
|
|
|
glib_ms=MINSHORT glib_Ms=MAXSHORT glib_Mus="(((gushort)G_MAXSHORT)*2+1)"
|
|
|
|
glib_mi=MININT glib_Mi=MAXINT glib_Mui="(((guint)G_MAXINT)*2+1)"
|
|
|
|
glib_ml=MINLONG glib_Ml=MAXLONG glib_Mul="(((gulong)G_MAXLONG)*2+1)"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
if test x$ac_cv_header_sys_poll_h = xyes ; then
|
|
|
|
glib_sys_poll_h=yes
|
|
|
|
fi
|
|
|
|
|
|
|
|
case 2 in
|
|
|
|
$ac_cv_sizeof_short)
|
|
|
|
gint16=short
|
|
|
|
gint16_format='"hi"'
|
|
|
|
guint16_format='"hu"'
|
|
|
|
;;
|
|
|
|
$ac_cv_sizeof_int)
|
|
|
|
gint16=int
|
|
|
|
gint16_format='"i"'
|
|
|
|
guint16_format='"u"'
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
case 4 in
|
|
|
|
$ac_cv_sizeof_short)
|
|
|
|
gint32=short
|
|
|
|
gint32_format='"hi"'
|
|
|
|
guint32_format='"hu"'
|
|
|
|
;;
|
|
|
|
$ac_cv_sizeof_int)
|
|
|
|
gint32=int
|
|
|
|
gint32_format='"i"'
|
|
|
|
guint32_format='"u"'
|
|
|
|
;;
|
|
|
|
$ac_cv_sizeof_long)
|
|
|
|
gint32=long
|
|
|
|
gint32_format='"li"'
|
|
|
|
guint32_format='"lu"'
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
case 8 in
|
|
|
|
$ac_cv_sizeof_int)
|
|
|
|
gint64=int
|
|
|
|
gint64_format='"i"'
|
|
|
|
guint64_format='"u"'
|
|
|
|
glib_extension=
|
|
|
|
gint64_constant='(val)'
|
|
|
|
;;
|
|
|
|
$ac_cv_sizeof_long)
|
|
|
|
gint64=long
|
|
|
|
gint64_format='"li"'
|
|
|
|
guint64_format='"lu"'
|
|
|
|
glib_extension=
|
|
|
|
gint64_constant='(val##L)'
|
|
|
|
;;
|
|
|
|
$ac_cv_sizeof_long_long)
|
|
|
|
gint64='long long'
|
2000-09-28 09:45:04 +02:00
|
|
|
if test -n "$glib_cv_long_long_format"; then
|
2000-09-28 09:54:40 +02:00
|
|
|
gint64_format='"'$glib_cv_long_long_format'i"'
|
|
|
|
guint64_format='"'$glib_cv_long_long_format'u"'
|
2000-09-28 09:45:04 +02:00
|
|
|
fi
|
2000-02-13 08:18:23 +01:00
|
|
|
glib_extension='G_GNUC_EXTENSION '
|
|
|
|
gint64_constant='(G_GNUC_EXTENSION (val##LL))'
|
|
|
|
;;
|
|
|
|
esac
|
2000-07-26 05:18:27 +02:00
|
|
|
glib_size_t=$glib_cv_sizeof_size_t
|
2000-12-29 03:16:51 +01:00
|
|
|
glib_void_p=$ac_cv_sizeof_long
|
|
|
|
glib_long=$ac_cv_sizeof_void_p
|
2000-02-13 08:18:23 +01:00
|
|
|
|
|
|
|
gintbits=`expr $ac_cv_sizeof_int \* 8`
|
|
|
|
glongbits=`expr $ac_cv_sizeof_long \* 8`
|
|
|
|
|
|
|
|
|
|
|
|
case $ac_cv_sizeof_void_p in
|
|
|
|
$ac_cv_sizeof_int) glib_gpi_cast='' glib_gpui_cast='' ;;
|
|
|
|
$ac_cv_sizeof_long) glib_gpi_cast='(glong)' glib_gpui_cast='(gulong)' ;;
|
|
|
|
*) glib_unknown_void_p=yes ;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
|
|
|
|
case xyes in
|
|
|
|
x$ac_cv_func_atexit)
|
|
|
|
glib_atexit="
|
|
|
|
#ifdef NeXT /* @#%@! NeXTStep */
|
|
|
|
# define g_ATEXIT(proc) (!atexit (proc))
|
|
|
|
#else
|
|
|
|
# define g_ATEXIT(proc) (atexit (proc))
|
|
|
|
#endif"
|
|
|
|
;;
|
|
|
|
x$ac_cv_func_on_exit)
|
|
|
|
glib_atexit="
|
|
|
|
#define g_ATEXIT(proc) (on_exit ((void (*)(int, void*))(proc), NULL))"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
case xyes in
|
|
|
|
x$ac_cv_func_memmove)
|
|
|
|
glib_memmove='
|
|
|
|
#define g_memmove(d,s,n) G_STMT_START { memmove ((d), (s), (n)); } G_STMT_END'
|
|
|
|
;;
|
|
|
|
x$glib_cv_working_bcopy)
|
|
|
|
glib_memmove="
|
|
|
|
/* memmove isn't available, but bcopy can copy overlapping memory regions */
|
|
|
|
#define g_memmove(d,s,n) G_STMT_START { bcopy ((s), (d), (n)); } G_STMT_END"
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
glib_memmove="
|
|
|
|
/* memmove isn't found and bcopy can't copy overlapping memory regions,
|
|
|
|
* so we have to roll our own copy routine. */
|
|
|
|
void g_memmove (void* dest, const void * src, unsigned long len);"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
glib_defines="
|
|
|
|
#define GLIB_MAJOR_VERSION $GLIB_MAJOR_VERSION
|
|
|
|
#define GLIB_MINOR_VERSION $GLIB_MINOR_VERSION
|
|
|
|
#define GLIB_MICRO_VERSION $GLIB_MICRO_VERSION
|
|
|
|
"
|
|
|
|
|
|
|
|
case xyes in
|
|
|
|
x$glib_cv_va_copy) glib_vacopy='#define G_VA_COPY va_copy' ;;
|
|
|
|
x$glib_cv___va_copy) glib_vacopy='#define G_VA_COPY __va_copy' ;;
|
|
|
|
*) glib_vacopy=''
|
|
|
|
esac
|
|
|
|
|
|
|
|
if test x$glib_cv_va_val_copy = xno; then
|
|
|
|
glib_vacopy="\$glib_vacopy
|
|
|
|
#define G_VA_COPY_AS_ARRAY 1"
|
|
|
|
fi
|
|
|
|
|
|
|
|
if test x$glib_cv_hasinline = xyes; then
|
|
|
|
glib_inline='#define G_HAVE_INLINE 1'
|
|
|
|
fi
|
|
|
|
if test x$glib_cv_has__inline = xyes; then
|
|
|
|
glib_inline="\$glib_inline
|
|
|
|
#define G_HAVE___INLINE 1"
|
|
|
|
fi
|
|
|
|
if test x$glib_cv_has__inline__ = xyes; then
|
|
|
|
glib_inline="\$glib_inline
|
|
|
|
#define G_HAVE___INLINE__ 1"
|
|
|
|
fi
|
|
|
|
|
|
|
|
case xyes in
|
|
|
|
x$ac_cv_c_bigendian)
|
|
|
|
g_byte_order=G_BIG_ENDIAN
|
|
|
|
g_bs_native=BE
|
|
|
|
g_bs_alien=LE
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
g_byte_order=G_LITTLE_ENDIAN
|
|
|
|
g_bs_native=LE
|
|
|
|
g_bs_alien=BE
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
2000-11-13 00:44:28 +01:00
|
|
|
g_have_eilseq=$have_eilseq
|
|
|
|
|
2000-09-28 09:54:40 +02:00
|
|
|
case x$have_threads in
|
|
|
|
xnone) g_enable_threads_def="#undef";;
|
|
|
|
*) g_enable_threads_def="#define";;
|
2000-02-13 08:18:23 +01:00
|
|
|
esac
|
|
|
|
|
|
|
|
g_threads_impl_def=$g_threads_impl
|
|
|
|
|
|
|
|
g_mutex_has_default="$mutex_has_default"
|
|
|
|
g_mutex_sizeof="$glib_cv_sizeof_gmutex"
|
Added the missing POSIX_NO_YIELD and POSIX_NO_PRIORITIES warning messages.
2000-03-17 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in: Added the missing POSIX_NO_YIELD and
POSIX_NO_PRIORITIES warning messages.
* configure.in: Use AC_TRY_RUN instead of AC_TRY_LINK, to test for
real thread support. On solaris pthread_create can be linked to
even in -lc, but it doesn't work then.
* configure.in: Don't use priorities for threads, when the
minimal/maximal priorities couldn't be determined at configure
time.
* configure.in, gthread.c: Always define GSystemThread in
glibconfig.h to represent a system thread.
* configure.in: Do not use native recursive threads, when
possibe. We use some features, that they do not expose (namely the
depth counter).
* glib.h, gthread.c: Redefined GStaticRecMutex. The functions are
now implemented in a different way, which should be way
faster. Alsothere are now functions g_static_rec_mutex_unlock_full
and g_static_rec_mutex_lock_full to leave/enter a recursive mutex
completly.
* gthread.c (g_thread_self): Do not test the system_thread to be
non-zero to speed things up.
* gthread.c (g_mutex_init): Therefore set the system_thread of the
main thread here.
* tests/thread-test.c: Rerun all tests once again, but this time
we fool the system into thinking, that the available thread system
is not native, but userprovided.
* gthread/gthread-posix.c: Don't use priorities for threads,
when the minimal/maximal priorities couldn't be determined at
configure time.
* gthread/gthread-posix.c: Don't check for errors, when
setting the scope of a tread to system, as some posix
implementations can't do that and we don't want the thing to
fail because of that.
2000-03-17 15:49:59 +01:00
|
|
|
g_system_thread_sizeof="$glib_cv_sizeof_system_thread"
|
2000-02-13 08:18:23 +01:00
|
|
|
g_mutex_contents="$glib_cv_byte_contents_gmutex"
|
|
|
|
|
Determine the suffix of the shared librarries for this system. This is
2000-12-22 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
* configure.in: Determine the suffix of the shared librarries for
this system. This is done analogous to
ltconfig.sh. G_MODULE_SUFFIX in glibconfig.h is set to either
"sl", "dll", or (most often) "so".
* tests/Makefile.am, tests/module-test.c,
tests/libmoduletestplugin_a.c, tests/libmoduletestplugin_b.c:
Added new testcase for gmodule. This is mostly copied from
gmodule/testgmodule.c, but unlike that is is quiet. (Why BTW are
some tests that verbose, not to say loquacious...)
* gmodule.c: Make g_module_open more tolerant wrt to the module
name. First it tries to open the module as named, if that fails,
it checks, whether it is a libtool archive and parses it, if that
fails it appends the systems shared library suffix
(i.e. ".so") (if not already found) and tries again and if that
fails it tries to append the ".la" libtool suffix (if not already
found) and parses it.
* gmodule.c: Lock recursive mutex during most module functions for
safety.
* gmodule-dl.c: Return an error from _g_module_symbol only, if
dlerror says so. All other functions return an error as well, if
dlerror returns NULL.
* testgmodule.c: Thanks to the above change the #ifdefs have
vanished.
* glib/glib-sections.txt: Added G_MODULE_SUFFIX.
* glib/tmpl/modules.sgml: Updated.
2000-12-22 14:44:25 +01:00
|
|
|
g_module_suffix="$glib_gmodule_suffix"
|
|
|
|
|
2000-02-13 08:18:23 +01:00
|
|
|
case $host in
|
|
|
|
*-*-beos*)
|
|
|
|
glib_os="#define G_OS_BEOS"
|
|
|
|
;;
|
|
|
|
*-*-cygwin*)
|
|
|
|
glib_os="#define G_OS_UNIX
|
|
|
|
#define G_WITH_CYGWIN"
|
2001-01-05 20:30:13 +01:00
|
|
|
;;
|
|
|
|
*-*-mingw*)
|
|
|
|
glib_os="#define G_OS_WIN32"
|
|
|
|
;;
|
2000-02-13 08:18:23 +01:00
|
|
|
*)
|
|
|
|
glib_os="#define G_OS_UNIX"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
])
|
|
|
|
|
|
|
|
AC_OUTPUT([
|
2000-07-31 19:10:33 +02:00
|
|
|
glib-2.0.pc
|
2001-02-19 07:50:21 +01:00
|
|
|
glib-config-2.0
|
2000-07-31 19:10:33 +02:00
|
|
|
gmodule-2.0.pc
|
|
|
|
gthread-2.0.pc
|
|
|
|
gobject-2.0.pc
|
2000-02-13 08:18:23 +01:00
|
|
|
glib.spec
|
|
|
|
Makefile
|
2000-07-15 23:59:15 +02:00
|
|
|
build/Makefile
|
|
|
|
build/win32/Makefile
|
2000-02-13 08:18:23 +01:00
|
|
|
gmodule/gmoduleconf.h
|
|
|
|
gmodule/Makefile
|
2000-05-12 17:23:16 +02:00
|
|
|
gobject/Makefile
|
2000-02-13 08:18:23 +01:00
|
|
|
gthread/Makefile
|
2001-01-16 03:24:24 +01:00
|
|
|
po/Makefile.in
|
2000-02-13 08:18:23 +01:00
|
|
|
docs/Makefile
|
|
|
|
docs/glib-config.1
|
2000-09-06 02:17:41 +02:00
|
|
|
docs/reference/Makefile
|
2000-09-06 17:01:07 +02:00
|
|
|
docs/reference/glib/Makefile
|
|
|
|
docs/reference/gobject/Makefile
|
2000-02-13 08:18:23 +01:00
|
|
|
tests/Makefile
|
|
|
|
],[case "$CONFIG_FILES" in
|
2000-07-14 21:22:54 +02:00
|
|
|
*glib-config-2.0*)chmod +x glib-config-2.0;;
|
2000-02-13 08:18:23 +01:00
|
|
|
esac
|
|
|
|
echo ""
|
|
|
|
echo " *** IMPORTANT *** "
|
|
|
|
echo ""
|
|
|
|
echo "This is a development version of GLib. You should be using a stable"
|
|
|
|
echo "version, which is available at ftp://ftp.gtk.org/pub/gtk/v1.2/. The"
|
|
|
|
echo "version you just configured is meant for developers of GLib only:"
|
|
|
|
echo ""
|
|
|
|
echo " * You should not base stable software on this version of GLib."
|
|
|
|
echo " * GNOME developers should use a stable version of GLib."
|
|
|
|
echo ""
|
|
|
|
echo "If you install this version of GLib, we strongly recommend that you"
|
|
|
|
echo "install it in a different prefix than GLib 1.2. Use --prefix as an"
|
|
|
|
echo "argument to configure to do this. Otherwise, you will not be able to"
|
|
|
|
echo "do development with GLib 1.2 any longer."
|
|
|
|
echo ""
|
|
|
|
echo " *** You should be using GLib 1.2 instead. ***"
|
|
|
|
])
|