aboutsummaryrefslogtreecommitdiffstats
path: root/macros/gnome-x-checks.m4
blob: 149d5570308a11bedbad021579b459577b15b261 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
dnl GNOME_X_CHECKS
dnl
dnl Basic X11 related checks for X11.  At the end, the following will be
dnl defined/changed:
dnl   GTK_{CFLAGS,LIBS}      From AM_PATH_GTK
dnl   CPPFLAGS           Will include $X_CFLAGS
dnl   GNOME_HAVE_SM      `true' or `false' depending on whether session
dnl                          management is available.  It is available if
dnl                          both -lSM and X11/SM/SMlib.h exist.  (Some
dnl                          Solaris boxes have the library but not the header)
dnl   XPM_LIBS               -lXpm if Xpm library is present, otherwise ""
dnl
dnl The following configure cache variables are defined (but not used):
dnl   gnome_cv_passdown_{x_libs,X_LIBS,X_CFLAGS}
dnl
AC_DEFUN([GNOME_X_CHECKS],
[
    AM_PATH_GTK(1.0.1,,AC_MSG_ERROR(GTK not installed, or gtk-config not in path))

    dnl Hope that GTK_CFLAGS have only -I and -D.  Otherwise, we could
    dnl   test -z "$x_includes" || CPPFLAGS="$CPPFLAGS -I$x_includes"
    dnl
    dnl Use CPPFLAGS instead of CFLAGS because AC_CHECK_HEADERS uses
    dnl CPPFLAGS, not CFLAGS
        CPPFLAGS="$CPPFLAGS $GTK_CFLAGS"

        saved_ldflags="$LDFLAGS"
        LDFLAGS="$LDFLAGS $GTK_LIBS"

    gnome_cv_passdown_x_libs="$GTK_LIBS"
    gnome_cv_passdown_X_LIBS="$GTK_LIBS"
    gnome_cv_passdown_X_CFLAGS="$GTK_CFLAGS"
    gnome_cv_passdown_GTK_LIBS="$GTK_LIBS"

        LDFLAGS="$saved_ldflags $GTK_LIBS"

    AC_MSG_CHECKING([whether to use features from (unstable) GTK+ 1.1.x])
    AC_EGREP_CPP(answer_affirmatively,
    [#include <gtk/gtkfeatures.h>
    #ifdef GTK_HAVE_FEATURES_1_1_0
       answer_affirmatively
    #endif
    ], dev_gtk=yes, dev_gtk=no)
    if test "$dev_gtk" = "yes"; then
       USE_DEVGTK=true
    fi
    AC_MSG_RESULT("$dev_gtk")

    GNOME_HAVE_SM=true
    case "$GTK_LIBS" in
     *-lSM*)
        dnl Already found it.
        ;;
     *)
        dnl Assume that if we have -lSM then we also have -lICE.
        AC_CHECK_LIB(SM, SmcSaveYourselfDone,
            [GTK_LIBS="-lSM -lICE $GTK_LIBS"],GNOME_HAVE_SM=false,
        $x_libs -lICE)
        ;;
    esac

    if test "$GNOME_HAVE_SM" = true; then
       AC_CHECK_HEADERS(X11/SM/SMlib.h,,GNOME_HAVE_SM=false)
    fi

    if test "$GNOME_HAVE_SM" = true; then
       AC_DEFINE(HAVE_LIBSM)
    fi

    XPM_LIBS=""
    AC_CHECK_LIB(Xpm, XpmFreeXpmImage, [XPM_LIBS="-lXpm"], , $x_libs)
    AC_SUBST(XPM_LIBS)

    AC_REQUIRE([GNOME_PTHREAD_CHECK])
        LDFLAGS="$saved_ldflags"

    AC_PROVIDE([GNOME_X_CHECKS])
])