]> Pileus Git - ~andy/gtk/commitdiff
Add dependency on Atk for accessibility support.
authorOwen Taylor <otaylor@redhat.com>
Thu, 3 May 2001 20:11:14 +0000 (20:11 +0000)
committerOwen Taylor <otaylor@src.gnome.org>
Thu, 3 May 2001 20:11:14 +0000 (20:11 +0000)
Thu May  3 14:13:49 2001  Owen Taylor  <otaylor@redhat.com>

        * INSTALL.in HACKING gtk/gtkaccessible.[ch] gtk/gtk.c: Add
dependency on Atk for accessibility support.

* configure.in **/Makefile.am: Major reworking of substituted
variables for CFLAGS/LIBS to make a lot more sane and
keep the the compile/link lines a bit shorter.

* gdk/x11/gdkkeys-x11.c: Fix #endif with trailing stuff.

34 files changed:
ChangeLog
ChangeLog.pre-2-0
ChangeLog.pre-2-10
ChangeLog.pre-2-2
ChangeLog.pre-2-4
ChangeLog.pre-2-6
ChangeLog.pre-2-8
HACKING
INSTALL
INSTALL.in
configure.in
contrib/gdk-pixbuf-xlib/Makefile.am
demos/Makefile.am
demos/gtk-demo/Makefile.am
docs/reference/gdk-pixbuf/Makefile.am
docs/reference/gtk/Makefile.am
gdk-2.0.pc.in
gdk-pixbuf-2.0.pc.in
gdk-pixbuf/Makefile.am
gdk/Makefile.am
gdk/linux-fb/Makefile.am
gdk/nanox/Makefile.am
gdk/x11/Makefile.am
gdk/x11/gdkkeys-x11.c
gdk/x11/gdkmain-x11.c
gtk+-2.0.pc.in
gtk/Makefile.am
gtk/gtk.h
gtk/gtkaccessible.c [new file with mode: 0644]
gtk/gtkaccessible.h [new file with mode: 0644]
gtk/gtkwidget.c
gtk/gtkwidget.h
modules/input/Makefile.am
tests/Makefile.am

index 0a0b59d46fa96bed10a05be581115fca864cf505..28cd6d631a0e6bae2796cac752961d0996166f51 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,14 @@
+Thu May  3 14:13:49 2001  Owen Taylor  <otaylor@redhat.com>
+
+        * INSTALL.in HACKING gtk/gtkaccessible.[ch] gtk/gtk.c: Add
+       dependency on Atk for accessibility support.
+
+       * configure.in **/Makefile.am: Major reworking of substituted
+       variables for CFLAGS/LIBS to make a lot more sane and 
+       keep the the compile/link lines a bit shorter.
+
+       * gdk/x11/gdkkeys-x11.c: Fix #endif with trailing stuff.
+
 Thu May  3 08:10:54 2001  Owen Taylor  <otaylor@redhat.com>
 
        * gtk/gtktexttag.c (gtk_text_tag_class_init): Fix return
index 0a0b59d46fa96bed10a05be581115fca864cf505..28cd6d631a0e6bae2796cac752961d0996166f51 100644 (file)
@@ -1,3 +1,14 @@
+Thu May  3 14:13:49 2001  Owen Taylor  <otaylor@redhat.com>
+
+        * INSTALL.in HACKING gtk/gtkaccessible.[ch] gtk/gtk.c: Add
+       dependency on Atk for accessibility support.
+
+       * configure.in **/Makefile.am: Major reworking of substituted
+       variables for CFLAGS/LIBS to make a lot more sane and 
+       keep the the compile/link lines a bit shorter.
+
+       * gdk/x11/gdkkeys-x11.c: Fix #endif with trailing stuff.
+
 Thu May  3 08:10:54 2001  Owen Taylor  <otaylor@redhat.com>
 
        * gtk/gtktexttag.c (gtk_text_tag_class_init): Fix return
index 0a0b59d46fa96bed10a05be581115fca864cf505..28cd6d631a0e6bae2796cac752961d0996166f51 100644 (file)
@@ -1,3 +1,14 @@
+Thu May  3 14:13:49 2001  Owen Taylor  <otaylor@redhat.com>
+
+        * INSTALL.in HACKING gtk/gtkaccessible.[ch] gtk/gtk.c: Add
+       dependency on Atk for accessibility support.
+
+       * configure.in **/Makefile.am: Major reworking of substituted
+       variables for CFLAGS/LIBS to make a lot more sane and 
+       keep the the compile/link lines a bit shorter.
+
+       * gdk/x11/gdkkeys-x11.c: Fix #endif with trailing stuff.
+
 Thu May  3 08:10:54 2001  Owen Taylor  <otaylor@redhat.com>
 
        * gtk/gtktexttag.c (gtk_text_tag_class_init): Fix return
index 0a0b59d46fa96bed10a05be581115fca864cf505..28cd6d631a0e6bae2796cac752961d0996166f51 100644 (file)
@@ -1,3 +1,14 @@
+Thu May  3 14:13:49 2001  Owen Taylor  <otaylor@redhat.com>
+
+        * INSTALL.in HACKING gtk/gtkaccessible.[ch] gtk/gtk.c: Add
+       dependency on Atk for accessibility support.
+
+       * configure.in **/Makefile.am: Major reworking of substituted
+       variables for CFLAGS/LIBS to make a lot more sane and 
+       keep the the compile/link lines a bit shorter.
+
+       * gdk/x11/gdkkeys-x11.c: Fix #endif with trailing stuff.
+
 Thu May  3 08:10:54 2001  Owen Taylor  <otaylor@redhat.com>
 
        * gtk/gtktexttag.c (gtk_text_tag_class_init): Fix return
index 0a0b59d46fa96bed10a05be581115fca864cf505..28cd6d631a0e6bae2796cac752961d0996166f51 100644 (file)
@@ -1,3 +1,14 @@
+Thu May  3 14:13:49 2001  Owen Taylor  <otaylor@redhat.com>
+
+        * INSTALL.in HACKING gtk/gtkaccessible.[ch] gtk/gtk.c: Add
+       dependency on Atk for accessibility support.
+
+       * configure.in **/Makefile.am: Major reworking of substituted
+       variables for CFLAGS/LIBS to make a lot more sane and 
+       keep the the compile/link lines a bit shorter.
+
+       * gdk/x11/gdkkeys-x11.c: Fix #endif with trailing stuff.
+
 Thu May  3 08:10:54 2001  Owen Taylor  <otaylor@redhat.com>
 
        * gtk/gtktexttag.c (gtk_text_tag_class_init): Fix return
index 0a0b59d46fa96bed10a05be581115fca864cf505..28cd6d631a0e6bae2796cac752961d0996166f51 100644 (file)
@@ -1,3 +1,14 @@
+Thu May  3 14:13:49 2001  Owen Taylor  <otaylor@redhat.com>
+
+        * INSTALL.in HACKING gtk/gtkaccessible.[ch] gtk/gtk.c: Add
+       dependency on Atk for accessibility support.
+
+       * configure.in **/Makefile.am: Major reworking of substituted
+       variables for CFLAGS/LIBS to make a lot more sane and 
+       keep the the compile/link lines a bit shorter.
+
+       * gdk/x11/gdkkeys-x11.c: Fix #endif with trailing stuff.
+
 Thu May  3 08:10:54 2001  Owen Taylor  <otaylor@redhat.com>
 
        * gtk/gtktexttag.c (gtk_text_tag_class_init): Fix return
index 0a0b59d46fa96bed10a05be581115fca864cf505..28cd6d631a0e6bae2796cac752961d0996166f51 100644 (file)
@@ -1,3 +1,14 @@
+Thu May  3 14:13:49 2001  Owen Taylor  <otaylor@redhat.com>
+
+        * INSTALL.in HACKING gtk/gtkaccessible.[ch] gtk/gtk.c: Add
+       dependency on Atk for accessibility support.
+
+       * configure.in **/Makefile.am: Major reworking of substituted
+       variables for CFLAGS/LIBS to make a lot more sane and 
+       keep the the compile/link lines a bit shorter.
+
+       * gdk/x11/gdkkeys-x11.c: Fix #endif with trailing stuff.
+
 Thu May  3 08:10:54 2001  Owen Taylor  <otaylor@redhat.com>
 
        * gtk/gtktexttag.c (gtk_text_tag_class_init): Fix return
diff --git a/HACKING b/HACKING
index 80d8ea25e473b06d6cabd3c3c70be35624cfd131..85d4be509b1716eaf39fc40a4bad7551acad64f0 100644 (file)
--- a/HACKING
+++ b/HACKING
@@ -13,8 +13,8 @@ These should be available by ftp from ftp.gnu.org or any of the
 fine GNU mirrors.  Beta software can be found at alpha.gnu.org.
 
 In order to get CVS gtk+ installed on your system, you need to have
-the most recent CVS version of glib installed as well.
-The installation process of glib is similar to that of gtk+, but
+the most recent CVS version of glib, pango, and atk installed as well.
+The installation process of these libraries is similar to that of gtk+, but
 needs to be fulfilled prior to installation of gtk+.
 
 To compile a CVS version of gtk+ on your system, you will need to take
@@ -45,6 +45,8 @@ gtk+ and glib.  You can do the following to get glib and gtk+ from cvs:
    $ cvs login
      (there is no password, just hit return)
    $ cvs -z3 checkout glib
+   $ cvs -z3 checkout pango
+   $ cvs -z3 checkout atk
    $ cvs -z3 checkout gtk+
 
 For information about submitting patches and commiting changes
diff --git a/INSTALL b/INSTALL
index 634cc143b2e74a407e34501e1748f951a57b93b5..4683c6acc03106243168e1003be8436f3078b417 100644 (file)
--- a/INSTALL
+++ b/INSTALL
@@ -3,15 +3,7 @@ Prerequisites
 
 GTK+ requires the following packages:
 
- - The GLIB library, available at the same location as GTK+
-
- - The Pango library, available from:
-
-      http://www.pango.org/download.shtml
-
-   Pango also requires the FriBidi library, available from:
-
-      http://imagic.weizmann.ac.il/~dov/freesw/FriBidi/
+ - The GLIB, Pango, and Atk libraries, available at the same location as GTK+
 
  - The TIFF, PNG, and JPEG image loading libraries. You most
    likely have these installed on your system already. If not
index adba883ae136980de42a54e5c985246dedd9cc02..6992b0d70aa033d5ec4149eb456bfcf245d940e6 100644 (file)
@@ -3,15 +3,7 @@ Prerequisites
 
 GTK+ requires the following packages:
 
- - The GLIB library, available at the same location as GTK+
-
- - The Pango library, available from:
-
-      http://www.pango.org/download.shtml
-
-   Pango also requires the FriBidi library, available from:
-
-      http://imagic.weizmann.ac.il/~dov/freesw/FriBidi/
+ - The GLIB, Pango, and Atk libraries, available at the same location as GTK+
 
  - The TIFF, PNG, and JPEG image loading libraries. You most
    likely have these installed on your system already. If not
index 15931e88964e5aa638a27e8bbeb630d142a59167..8fe5613e5c2c9dd2224026f636cc9c0e5f7535dc 100644 (file)
@@ -1,12 +1,15 @@
 # Process this file with autoconf to produce a configure script.
 AC_INIT(gdk/gdktypes.h)
 
-# In the following, there are a the following variants
-# of GLib cflags and libs variables
 #
-# GLIB_CFLAGS:  cflags for compiling libraries and example progs
-# GLIB_LIBS:    libraries for linking example programs
-# GLIB_DEPLIBS: libraries for linking libraries against
+# For each of the libraries we build, we define the following
+# substituted variables:
+#
+# foo_PACKAGES:     pkg-config packages this library requires
+# foo_EXTRA_LIBS:   Libraries this module requires not pulled in by pkg-config
+# foo_EXTRA_CFLAGS: cflags this module requires not pulled in by pkg-config
+# foo_DEP_LIBS:     All libraries this module requires
+# foo_DEP_CFLAGS:   All cflags this module requires
 
 
 ## We could have pkg-config uniquify the ldflags and cflags by calling
@@ -256,20 +259,16 @@ AC_TRY_RUN([#include <math.h>
 LIBS=$gtk_save_LIBS
 
 MATH_LIB=-lm
-GTK_LIBS_EXTRA=
 AC_MSG_CHECKING(for the BeOS)
 case $host in
   *-*-beos*)
     AC_MSG_RESULT(yes)
-    GTK_LIBS_EXTRA="-L\$(top_builddir_full)/gdk/.libs -lgdk"
     MATH_LIB=
   ;;
   *)
     AC_MSG_RESULT(no)
   ;;
 esac
-AC_SUBST(MATH_LIB)
-AC_SUBST(GTK_LIBS_EXTRA)
 
 dnl NeXTStep cc seems to need this
 AC_MSG_CHECKING([for extra flags for POSIX compliance])
@@ -296,15 +295,6 @@ AM_PATH_GLIB_2_0($GLIB_REQUIRED_VERSION, :,
 *** GLIB is always available from ftp://ftp.gtk.org/.]),
   gobject gmodule gthread)
 
-dnl Call pkg-config again since we don't want -lgthread here
-GLIB_LIBS=`$PKG_CONFIG --libs $GLIB_PACKAGES`
-GLIB_DEPLIBS=$GLIB_LIBS
-
-CFLAGS="$CFLAGS $GLIB_CFLAGS"
-AC_SUBST(GLIB_CFLAGS)
-AC_SUBST(GLIB_LIBS)
-AC_SUBST(GLIB_DEPLIBS)
-
 AC_CHECK_HEADERS(dirent.h, AC_DEFINE(HAVE_DIRENT_H))
 AC_CHECK_HEADERS(pwd.h, AC_DEFINE(HAVE_PWD_H))
 AC_CHECK_HEADERS(sys/time.h, AC_DEFINE(HAVE_SYS_TIME_H))
@@ -313,638 +303,674 @@ AC_CHECK_HEADERS(unistd.h, AC_DEFINE(HAVE_UNISTD_H))
 saved_cflags="$CFLAGS"
 saved_ldflags="$LDFLAGS"
 
-if test "x$gdktarget" = "xx11"; then
-  # Find the X11 include and library directories
-  AC_PATH_X
-  AC_PATH_XTRA
-
-  if test "x$x_includes" = "x"; then
-    x_includes="/usr/include"
-  fi
-
-  CFLAGS="$CFLAGS $X_CFLAGS"
-  LDFLAGS="$LDFLAGS $X_LDFLAGS $X_LIBS"
-
-  if test "x$no_x" = "xyes"; then 
-    AC_MSG_ERROR([
-*** X libraries or include files not found. Check 'config.log' for 
-*** more details.])
-  fi
 
-  # Checks for libraries.
-  # Check for the X11 library
-  AC_CHECK_LIB(X11, XOpenDisplay, x_libs="-lX11 $X_EXTRA_LIBS", 
-    AC_MSG_ERROR([*** libX11 not found. Check 'config.log' for more details.]),
-    $X_EXTRA_LIBS)
+# Checks for header files.
+AC_HEADER_STDC
 
-  if test "x$enable_shm" = "xyes"; then
-    # Check for the Xext library (needed for XShm extention)
-    AC_CHECK_LIB(Xext, XShmAttach, 
-        x_libs="-lXext $x_libs", 
-        # On AIX, it is in XextSam instead, but we still need -lXext
-        AC_CHECK_LIB(XextSam, XShmAttach, 
-            x_libs="-lXextSam -lXext $x_libs", 
-            no_xext_lib=yes, $x_libs),
-        $x_libs)
-  fi
+# Checks for typedefs, structures, and compiler characteristics.
+AC_C_CONST
 
-  # Check for shaped window extension
+# Checks for library functions.
+AC_TYPE_SIGNAL
+AC_FUNC_MMAP
 
-  AC_CHECK_LIB(Xext, XShapeCombineMask,
-      if test -z "`echo $x_libs | grep "\-lXext" 2> /dev/null`"; then
-           x_libs="-lXext $x_libs"
-      fi
-      AC_DEFINE(HAVE_SHAPE_EXT),
-      ,
-      $x_libs)
+AC_CHECK_FUNCS(getresuid)
+AC_TYPE_UID_T
 
-  # Check for XConvertCase (X11R6 specific)
+# 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
+    AC_HEADER_EGREP(fd_mask, sys/select.h, gtk_ok=yes)
+    if test $gtk_ok = yes; then
+        AC_DEFINE(HAVE_SYS_SELECT_H)
+        AC_MSG_RESULT([yes, found in sys/select.h])
+    else
+       AC_DEFINE(NO_FD_SET)
+       AC_MSG_RESULT(no)
+    fi
+fi
 
-  AC_CHECK_LIB(X11, XConvertCase,
-      AC_DEFINE(HAVE_XCONVERTCASE),
-      ,
-      $x_libs)
+# `widechar' tests for gdki18n.h
+AC_MSG_CHECKING(for wchar.h)
+AC_TRY_CPP([#include <wchar.h>], gdk_wchar_h=yes, gdk_wchar_h=no)
+if test $gdk_wchar_h = yes; then
+   AC_DEFINE(HAVE_WCHAR_H,1,[Have wchar.h include file])
+fi
+AC_MSG_RESULT($gdk_wchar_h)
 
-  #
-  # Checks for FreeType
-  #
-  FREETYPE_LIBS=
-  FREETYPE_CFLAGS=
-  have_freetype=false
-  AC_PATH_PROG(FREETYPE_CONFIG, freetype-config, no)
-  if test "x$FREETYPE_CONFIG" != "xno" ; then
-    FREETYPE_CFLAGS=`freetype-config --cflags`
-    FREETYPE_LIBS=`freetype-config --libs`
+# Check for wctype.h (for iswalnum)
+AC_MSG_CHECKING(for wctype.h)
+AC_TRY_CPP([#include <wctype.h>], gdk_wctype_h=yes, gdk_wctype_h=no)
+if test $gdk_wctype_h = yes; then
+   AC_DEFINE(HAVE_WCTYPE_H,1,[Have wctype.h include file])
+fi
+AC_MSG_RESULT($gdk_wctype_h)
 
-    AC_CHECK_LIB(freetype, FT_New_Face, have_freetype=true
-                ,:,$FREETYPE_LIBS)
-  fi
-  AC_SUBST(FREETYPE_CFLAGS)
+# in Solaris 2.5, `iswalnum' is in -lw
+GDK_WLIBS=
+AC_CHECK_FUNC(iswalnum,,[AC_CHECK_LIB(w,iswalnum,GDK_WLIBS=-lw)])
 
-  #
-  # Checks for Xft/XRender
-  #
-  have_xft=false
-  XFT_LIBS=""
-  XFT_CFLAGS=""
-  if test $have_freetype = true ; then
-    AC_CHECK_LIB(Xrender, XRenderFindFormat, 
-      AC_CHECK_LIB(Xft, XftFontOpen, have_xft=true, :, -lXrender -lXext $X_LIBS $FREETYPE_LIBS)
-    ,:,-lXext $X_LIBS)
+oLIBS="$LIBS"
+LIBS="$LIBS $GDK_WLIBS"
+# The following is necessary for Linux libc-5.4.38
+AC_MSG_CHECKING(if iswalnum() and friends are properly defined)
+AC_TRY_LINK([#include <stdlib.h>],[
+#if (defined(HAVE_WCTYPE_H) || defined(HAVE_WCHAR_H))
+#  ifdef HAVE_WCTYPE_H
+#    include <wctype.h>
+#  else
+#    ifdef HAVE_WCHAR_H
+#      include <wchar.h>
+#    endif
+#  endif
+#else
+#  define iswalnum(c) ((wchar_t)(c) <= 0xFF && isalnum(c))
+#endif
+iswalnum((wchar_t) 0);
+], gdk_working_wctype=yes, gdk_working_wctype=no)
+LIBS="$oLIBS"
 
-    ## be sure we also have Pango built with xft support
-    if ! $PKG_CONFIG --exists pangoxft ; then
-        have_xft=false
-        AC_MSG_WARN([X render extension found, but Pango lacks Xft support])        
-    fi
+if test $gdk_working_wctype = no; then
+   AC_DEFINE(HAVE_BROKEN_WCTYPE,1,[Is the wctype implementation broken])
+   GDK_WLIBS=
+fi
+AC_MSG_RESULT($gdk_working_wctype)
+AC_SUBST(GDK_WLIBS)
 
-    if $have_xft = 'true' ; then
-      X_LIBS="-lXft -lXrender -lXext $FREETYPE_LIBS $X_LIBS"
-      AC_DEFINE(HAVE_XFT)
-    fi
-  fi
 
-  AC_SUBST(XFT_LIBS)
-  AM_CONDITIONAL(HAVE_XFT, $have_xft)
 
-  # Check for XIM support.
+##################################################
+# Checks for gdk-pixbuf
+##################################################
 
-  AC_CHECK_LIB(X11, XUnregisterIMInstantiateCallback,
-           : ,
-           enable_xim_inst="no",
-           $x_libs)
+AC_MSG_CHECKING(whether to build gmodulized gdk-pixbuf)
 
-  # On Solaris, calling XRegisterIMInstantiateCallback seems to
-  # cause an immediate segfault, so we disable it, unless
-  # the user specifically forces it to be on.
+AC_ARG_ENABLE(modules, [  --disable-modules       Disables dynamic module loading],[
+       if test x$withval = xyes; then 
+           with_modules=yes
+        else
+            with_modules=no
+       fi
+])
 
-  if test x$enable_xim_inst = xmaybe ; then
-    case host in
-         *-*-solaris*)
-            enable_xim_inst="no"
-            ;;
-         *)
-           enable_xim_inst="yes"
-           ;;
-    esac
-  fi
+dynworks=false
+deps=
+if test x$with_modules = xno; then
+    AC_MSG_RESULT(no)
+else
+    AC_MSG_RESULT(yes)
+    AC_MSG_CHECKING(whether dynamic modules work)
+    oLIBS="$LIBS"
+    oCFLAGS="$CFLAGS"
+    CFLAGS="$GLIB_CFLAGS"
+    LIBS="$GLIB_LIBS"
+    AC_TRY_RUN([
+    #include <glib.h>
+    #include <gmodule.h>
+    main ()
+    {
+       if (g_module_supported ())
+           exit (0);
+       else
+           exit (1);
+    }
+    ], dynworks=true)
+    LIBS="$oLIBS"
+    CFLAGS="$oCFLAGS"
+fi
 
-  if test "x$enable_xim" = "xyes"; then
-    GTK_XIM_FLAGS="-DUSE_XIM"
-    if test "x$enable_xim_inst" = "xyes"; then
-      AC_DEFINE(USE_X11R6_XIM)
-    fi
-  fi
+dnl Now we check to see if our libtool supports shared lib deps
+dnl (in a rather ugly way even)
+if $dynworks; then
+   pixbuf_libtool_config="${CONFIG_SHELL-/bin/sh} libtool --config"
+   pixbuf_deplibs_check=`$pixbuf_libtool_config | \
+      grep '^[[a-z_]]*check[[a-z_]]*_method=[['\''"]]' | \
+      sed 's/.*[['\''"]]\(.*\)[['\''"]]$/\1/'`
+   if test "x$pixbuf_deplibs_check" = "xnone" || \
+      test "x$pixbuf_deplibs_check" = "xunknown" || \
+      test "x$pixbuf_deplibs_check" = "x"; then
+      dynworks=false
+   fi
+fi
 
-  # Check for XKB support.
+if $dynworks; then
+   AC_DEFINE(USE_GMODULE)
+   AC_MSG_RESULT(yes)
+else
+   AC_MSG_RESULT(no)
+fi
 
-  if test "x$enable_xkb" = "xyes"; then
-        AC_MSG_WARN(XKB support explicitly enabled)
-        AC_DEFINE(HAVE_XKB)
-  elif test "x$enable_xkb" = "xmaybe"; then
-        AC_CHECK_LIB(X11, XkbQueryExtension,
-                     AC_DEFINE(HAVE_XKB),
-                    ,
-                    $x_libs)
-  else
-        AC_MSG_WARN(XKB support explicitly disabled)
+dnl Test for libtiff
+  if test -z "$LIBTIFF"; then
+    AC_CHECK_LIB(tiff, TIFFReadScanline,
+      AC_CHECK_HEADER(tiffio.h,
+        TIFF='tiff'; LIBTIFF='-ltiff',
+        AC_MSG_WARN(*** TIFF loader will not be built (TIFF header files not found) ***)),
+      AC_CHECK_LIB(tiff, TIFFWriteScanline,
+        AC_CHECK_HEADER(tiffio.h,
+          TIFF='tiff'; LIBTIFF='-ltiff -ljpeg -lz',
+          AC_MSG_WARN(*** TIFF loader will not be built (TIFF header files not found) ***)),
+        AC_CHECK_LIB(tiff34, TIFFFlushData,
+          AC_CHECK_HEADER(tiffio.h,
+            TIFF='tiff'; LIBTIFF='-ltiff34 -ljpeg -lz',
+            AC_MSG_WARN(*** TIFF loader will not be built (TIFF header files not found) ***)),
+        AC_MSG_WARN(*** TIFF plug-in will not be built (TIFF library not found) ***), -ljpeg -lz -lm), -ljpeg -lz -lm), -lm)
   fi
 
-  x_cflags="$X_CFLAGS"
-  x_ldflags="$X_LDFLAGS $X_LIBS"
-
-  # set up things for XInput
-
-  if test "x$with_xinput" = "xgxi" || test "x$with_xinput" = "xyes"; then
-    AC_DEFINE(XINPUT_GXI)
-    xinput_progs=gxid
-    x_libs="-lXi $x_libs"
-  elif test "x$with_xinput" = "xxfree"; then
-    AC_DEFINE(XINPUT_XFREE)
-    x_libs="-lXi $x_libs"
-  else
-    AC_DEFINE(XINPUT_NONE)
+dnl Test for libjpeg
+  if test -z "$LIBJPEG"; then
+    AC_CHECK_LIB(jpeg, jpeg_destroy_decompress,
+      jpeg_ok=yes,
+      jpeg_ok=no
+      AC_MSG_WARN(*** JPEG loader will not be built (JPEG library not found) ***))
+    if test "$jpeg_ok" = yes; then
+      AC_MSG_CHECKING([for jpeglib.h])
+      AC_TRY_CPP(
+[#include <stdio.h>
+#undef PACKAGE
+#undef VERSION
+#include <jpeglib.h>],
+        jpeg_ok=yes,
+        jpeg_ok=no)
+      AC_MSG_RESULT($jpeg_ok)
+      if test "$jpeg_ok" = yes; then
+        LIBJPEG='-ljpeg'
+        AC_CHECK_LIB(jpeg, jpeg_simple_progression,     
+          AC_DEFINE(HAVE_PROGRESSIVE_JPEG),
+          AC_MSG_WARN(JPEG library does not support progressive saving.))
+      else
+          AC_MSG_WARN(*** JPEG loader will not be built (JPEG header file not found) ***)
+      fi
+    fi
   fi
 
-  AM_CONDITIONAL(XINPUT_GXI, test x$with_xinput = xgxi)
-  AM_CONDITIONAL(XINPUT_XFREE, test x$with_xinput = xxfree)
-
-  if test "x$enable_shm" = "xyes"; then
-    # Check for shared memory
-    AC_CHECK_HEADER(sys/ipc.h, AC_DEFINE(HAVE_IPC_H), no_sys_ipc=yes)
-    AC_CHECK_HEADER(sys/shm.h, AC_DEFINE(HAVE_SHM_H), no_sys_shm=yes)
-
-    # Check for the X shared memory extension header file
-    AC_MSG_CHECKING(X11/extensions/XShm.h)
-    if test "x$no_xext_lib" = "xyes"; then
-      AC_MSG_RESULT(no)
-      no_xshm=yes
-    else
-      if test -f "$x_includes/X11/extensions/XShm.h"; then
-        AC_MSG_RESULT(yes)
-        AC_DEFINE(HAVE_XSHM_H)
+dnl Test for libpng
+  if test -z "$LIBPNG"; then
+    AC_CHECK_LIB(png, png_read_info,
+      AC_CHECK_HEADER(png.h,
+        png_ok=yes,
+        png_ok=no),
+      AC_MSG_WARN(*** PNG loader will not be built (PNG library not found) ***), -lz -lm)
+    if test "$png_ok" = yes; then
+      AC_MSG_CHECKING([for png_structp in png.h])
+      AC_TRY_COMPILE([#include <png.h>],
+        [png_structp pp; png_infop info; png_colorp cmap; png_create_read_struct;],
+        png_ok=yes,
+        png_ok=no)
+      AC_MSG_RESULT($png_ok)
+      if test "$png_ok" = yes; then
+        PNG='png'; LIBPNG='-lpng -lz'
       else
-        AC_MSG_RESULT(no)
-        no_xshm=yes
+        AC_MSG_WARN(*** PNG loader will not be built (PNG library is too old) ***)
       fi
+    else
+     AC_MSG_WARN(*** PNG loader will not be built (PNG header file not found) ***)
     fi
   fi
 
-  more_cflags="$x_cflags"
-  more_ldflags="$x_ldflags"
-  more_libs="$x_libs"
-  more_includes="$x_includes"
-
-  # these are already defined above
-  #gdktargetlib = "libgdk-x11-1.3.la"
-  #gtktargetlib = "libgtk-x11-1.3.la"
+AC_SUBST(LIBTIFF)
+AC_SUBST(LIBJPEG)
+AC_SUBST(LIBPNG)
 
-  AM_CONDITIONAL(USE_X11, true)
-else
-  AM_CONDITIONAL(USE_X11, false)
-fi
+AM_CONDITIONAL(BUILD_DYNAMIC_MODULES, $dynworks)
 
-if test "x$gdktarget" = "xnanox"; then
-  AC_CHECK_LIB(nano-X, GrOpen,,AC_MSG_ERROR([nano-X libraries not found.]))
-  # nano-X may require additional libraries
-  more_cflags=
-  more_ldflags=
-  more_libs="-lnano-X"
-  more_includes=
+#
+# Allow building some or all gdk-pixbuf loaders included
+#
+AC_MSG_CHECKING(pixbuf loaders to build)
 
-  gdktargetlib="libgdk-nanox-1.3.la"
-  gtktargetlib="libgtk-nanox-1.3.la"
+AC_ARG_WITH(included_loaders, [  --with-included-loaders=LOADER1,LOADER2,... Build the specified loaders into gdk-pixbuf (only used if module loading disabled)])
 
-  with_xinput=no
-  AC_DEFINE(XINPUT_NONE)
-  x_cflags=
-  x_includes=
-  x_ldflags=
-  x_libs=
-  xinput_progs=
-  AM_CONDITIONAL(USE_NANOX, true)
+all_loaders="png,bmp,wbmp,gif,ico,jpeg,pnm,ras,tiff,xpm"
+included_loaders=""
+# If no loaders specified, include all
+if test "x$with_included_loaders" = xyes ; then
+  included_loaders="$all_loaders"
 else
-  AM_CONDITIONAL(USE_NANOX, false)
+  included_loaders="$with_included_loaders"
 fi
 
-if test "x$gdktarget" = "xlinux-fb"; then
-  more_cflags=
-  more_ldflags=
-  more_libs=
-  more_includes=
+AC_MSG_RESULT($included_loaders)
 
-  gdktargetlib="libgdk-linux-fb-1.3.la"
-  gtktargetlib="libgtk-linux-fb-1.3.la"
+INCLUDED_LOADER_OBJ=
+INCLUDED_LOADER_DEFINE=
 
-  with_xinput=no
-  AC_DEFINE(XINPUT_NONE)
-  x_cflags=
-  x_includes=
-  x_ldflags=
-  x_libs=
-  xinput_progs=
+IFS="${IFS=    }"; gtk_save_ifs="$IFS"; IFS=","
+for loader in $included_loaders; do
+ if echo "$all_loaders" | grep "\(^\|\,\)$loader\(\$\|\,\)" > /dev/null; then
+   :
+ else
+   AC_MSG_ERROR([the specified loader $loader does not exist])
+ fi
 
-  AC_PATH_PROG(FREETYPE_CONFIG, freetype-config, no)
-  if test x$FREETYPE_CONFIG = xno ; then
-    AC_MSG_ERROR([*** freetype-config not found])
-  fi
+ INCLUDED_LOADER_OBJ="$INCLUDED_LOADER_OBJ libpixbufloader-static-$loader.la"
+ INCLUDED_LOADER_DEFINE="$INCLUDED_LOADER_DEFINE -DINCLUDE_$loader"
+done
+IFS="$gtk_save_ifs"
+AC_SUBST(INCLUDED_LOADER_OBJ)
+AC_SUBST(INCLUDED_LOADER_DEFINE)
 
-  FREETYPE_CFLAGS="`$FREETYPE_CONFIG --cflags`"
-  FREETYPE_LIBS="`$FREETYPE_CONFIG --libs`"
-  CFLAGS="$CFLAGS $FREETYPE_CFLAGS"
+AC_HEADER_DIRENT
+AC_HEADER_SYS_WAIT
 
-  if test x$enable_shadowfb = xyes ; then
-    AC_DEFINE(ENABLE_SHADOW_FB)
-  fi
-  
-  AM_CONDITIONAL(USE_LINUX_FB, true)
+AC_TYPE_SIGNAL
+
+AM_CONDITIONAL(HAVE_TIFF, test "x$LIBTIFF" != x)
+AM_CONDITIONAL(HAVE_PNG, test "x$LIBPNG" != x)
+AM_CONDITIONAL(HAVE_JPEG, test "x$LIBJPEG" != x)
+
+if test $dynworks = no ; then
+  STATIC_LIB_DEPS="$LIBTIFF $LIBJPEG $LIBPNG"
 else
-  AM_CONDITIONAL(USE_LINUX_FB, false)
+  STATIC_LIB_DEPS=
+  if echo "$included_loaders" | grep "\(^\|\,\)tiff\(\$\|\,\)" > /dev/null; then
+    STATIC_LIB_DEPS="STATIC_LIB_DEPS $LIBTIFF"
+  fi
+  if echo "$included_loaders" | grep "\(^\|\,\)jpeg\(\$\|\,\)" > /dev/null; then
+    STATIC_LIB_DEPS="STATIC_LIB_DEPS $LIBJPEG"
+  fi
+  if echo "$included_loaders" | grep "\(^\|\,\)png\(\$\|\,\)" > /dev/null; then
+    STATIC_LIB_DEPS="STATIC_LIB_DEPS $LIBPNG"
+  fi
 fi
-AC_SUBST(ENABLE_SHADOW_FB)     
-AC_SUBST(FREETYPE_LIBS)
-AC_SUBST(FREETYPE_CFLAGS)
 
+# Checks to see if we should compile in MMX support (there will be
+# a runtime test when the code is actually run to see if it should
+# be used - this just checks if we can compile it.)
 #
-# Pick correct Pango packages to use
+# This code is partially taken from Mesa
 #
+AC_MSG_CHECKING(for x86 platform)
+case $host_cpu in
+  i386|i486|i586|i686|i786|k6|k7)
+       use_x86_asm=yes
+        ;;
+   *)
+       use_x86_asm=no
+esac
+AC_MSG_RESULT($use_x86_asm)
 
-if test "x$gdktarget" = "xx11"; then
-       if $have_xft = true ; then
-            PANGO_PACKAGES="pangox pangoxft"
-        else
-            PANGO_PACKAGES=pangox
-        fi
-elif test "x$gdktarget" = "xlinux-fb"; then
-        PANGO_PACKAGES=pangoft2
-else
-        PANGO_PACKAGES=pango
+use_mmx_asm=no
+if test $use_x86_asm = yes; then
+    save_ac_ext=$ac_ext
+    ac_ext=S
+    
+    AC_MSG_CHECKING(compiler support for MMX)
+    cp $srcdir/gdk-pixbuf/pixops/scale_line_22_33_mmx.S conftest.S
+    if AC_TRY_EVAL(ac_compile); then
+        use_mmx_asm=yes
+    fi
+
+    rm -rf conftest*
+
+    ac_ext=$save_ac_ext
+    if test $use_mmx_asm = yes; then
+      AC_DEFINE(USE_MMX)
+      AC_MSG_RESULT(yes)
+    else
+      AC_MSG_RESULT(no)
+    fi
 fi
 
-AC_SUBST(PANGO_PACKAGES)
+AM_CONDITIONAL(USE_MMX, test x$use_mmx_asm = xyes)
 
-# Check for Pango flags
 
-AC_MSG_CHECKING(Pango flags)
-if $PKG_CONFIG --exists $PANGO_PACKAGES ; then
-        PANGO_CFLAGS=`$PKG_CONFIG --cflags $PANGO_PACKAGES`
-        PANGO_LIBS=`$PKG_CONFIG --libs $PANGO_PACKAGES`
+GDK_PIXBUF_PACKAGES=gmodule-2.0
+GDK_PIXBUF_EXTRA_LIBS="$STATIC_LIB_DEPS $MATH_LIB"
+GDK_PIXBUF_EXTRA_CFLAGS= 
+GDK_PIXBUF_DEP_LIBS="`pkg-config --libs $GDK_PIXBUF_PACKAGES` $GDK_PIXBUF_EXTRA_LIBS"
+GDK_PIXBUF_DEP_CFLAGS="`pkg-config --cflags $GDK_PIXBUF_PACKAGES` $GDK_PIXBUF_EXTRA_CFLAGS"
 
-        AC_MSG_RESULT($PANGO_CFLAGS $PANGO_LIBS)
-else
-        AC_MSG_ERROR([
-*** Pango not found. Pango is required to build GTK+.
-*** See http://www.pango.org for Pango information.
-*** For the framebuffer target, you will need to build 
-*** Pango with freetype support.
-])
-fi
+AC_SUBST(GDK_PIXBUF_PACKAGES)
+AC_SUBST(GDK_PIXBUF_EXTRA_LIBS)
+AC_SUBST(GDK_PIXBUF_EXTRA_CFLAGS)
+AC_SUBST(GDK_PIXBUF_DEP_LIBS)
+AC_SUBST(GDK_PIXBUF_DEP_CFLAGS)
 
-CFLAGS="$CFLAGS $PANGO_CFLAGS"
-AC_SUBST(PANGO_LIBS)
-AC_SUBST(PANGO_CFLAGS)
 
-AC_CHECK_LIB(pango, pango_context_new, :, AC_MSG_ERROR([
-*** Can't link to Pango. Pango is required to build
-*** GTK+. For more information see http://www.pango.org]), $PANGO_LIBS $x_ldflags $x_libs)
+########################################
+# Windowing system checks
+########################################
 
-CFLAGS="$saved_cflags"
-LDFLAGS="$saved_ldflags"
+GDK_EXTRA_LIBS=$GDK_WLIBS
+GDK_EXTRA_CFLAGS= 
 
-AC_SUBST(x_cflags)
-AC_SUBST(x_includes)
-AC_SUBST(x_ldflags)
-AC_SUBST(x_libs)
-AC_SUBST(xinput_progs)
+if test "x$gdktarget" = "xx11"; then
+  # Find the X11 include and library directories
+  AC_PATH_X
+  AC_PATH_XTRA
 
-AC_SUBST(more_cflags)
-AC_SUBST(more_includes)
-AC_SUBST(more_ldflags)
-AC_SUBST(more_libs)
-AC_SUBST(gdktargetlib)
-AC_SUBST(gtktargetlib)
+  if test "x$x_includes" = "x"; then
+    x_includes="/usr/include"
+  fi
+
+  CFLAGS="$CFLAGS $X_CFLAGS"
+  LDFLAGS="$LDFLAGS $X_LDFLAGS $X_LIBS"
 
+  if test "x$no_x" = "xyes"; then 
+    AC_MSG_ERROR([
+*** X libraries or include files not found. Check 'config.log' for 
+*** more details.])
+  fi
 
-# Checks for header files.
-AC_HEADER_STDC
+  # Checks for libraries.
+  # Check for the X11 library
+  AC_CHECK_LIB(X11, XOpenDisplay, x_libs="-lX11 $X_EXTRA_LIBS", 
+    AC_MSG_ERROR([*** libX11 not found. Check 'config.log' for more details.]),
+    $X_EXTRA_LIBS)
 
-# Checks for typedefs, structures, and compiler characteristics.
-AC_C_CONST
+  if test "x$enable_shm" = "xyes"; then
+    # Check for the Xext library (needed for XShm extention)
+    AC_CHECK_LIB(Xext, XShmAttach, 
+        x_libs="-lXext $x_libs", 
+        # On AIX, it is in XextSam instead, but we still need -lXext
+        AC_CHECK_LIB(XextSam, XShmAttach, 
+            x_libs="-lXextSam -lXext $x_libs", 
+            no_xext_lib=yes, $x_libs),
+        $x_libs)
+  fi
 
-# Checks for library functions.
-AC_TYPE_SIGNAL
-AC_FUNC_MMAP
+  GDK_PIXBUF_XLIB_EXTRA_CFLAGS="$x_cflags"
+  GDK_PIXBUF_XLIB_EXTRA_LIBS="$x_ldflags $x_libs"
 
-AC_CHECK_FUNCS(getresuid)
-AC_TYPE_UID_T
+  # Check for shaped window extension
 
-# 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
-    AC_HEADER_EGREP(fd_mask, sys/select.h, gtk_ok=yes)
-    if test $gtk_ok = yes; then
-        AC_DEFINE(HAVE_SYS_SELECT_H)
-        AC_MSG_RESULT([yes, found in sys/select.h])
-    else
-       AC_DEFINE(NO_FD_SET)
-       AC_MSG_RESULT(no)
+  AC_CHECK_LIB(Xext, XShapeCombineMask,
+      if test -z "`echo $x_libs | grep "\-lXext" 2> /dev/null`"; then
+           x_libs="-lXext $x_libs"
+      fi
+      AC_DEFINE(HAVE_SHAPE_EXT),
+      ,
+      $x_libs)
+
+  # Check for XConvertCase (X11R6 specific)
+
+  AC_CHECK_LIB(X11, XConvertCase,
+      AC_DEFINE(HAVE_XCONVERTCASE),
+      ,
+      $x_libs)
+
+  #
+  # Checks for FreeType
+  #
+  FREETYPE_LIBS=
+  FREETYPE_CFLAGS=
+  have_freetype=false
+  AC_PATH_PROG(FREETYPE_CONFIG, freetype-config, no)
+  if test "x$FREETYPE_CONFIG" != "xno" ; then
+    FREETYPE_CFLAGS=`freetype-config --cflags`
+    FREETYPE_LIBS=`freetype-config --libs`
+
+    AC_CHECK_LIB(freetype, FT_New_Face, have_freetype=true
+                ,:,$FREETYPE_LIBS)
+  fi
+
+  #
+  # Checks for Xft/XRender
+  #
+  have_xft=false
+  if test $have_freetype = true ; then
+    AC_CHECK_LIB(Xrender, XRenderFindFormat, 
+      AC_CHECK_LIB(Xft, XftFontOpen, have_xft=true, :, -lXrender -lXext $X_LIBS $FREETYPE_LIBS)
+    ,:,-lXext $X_LIBS)
+
+    ## be sure we also have Pango built with xft support
+    if ! $PKG_CONFIG --exists pangoxft ; then
+        have_xft=false
+        AC_MSG_WARN([X render extension found, but Pango lacks Xft support])        
     fi
-fi
 
-# `widechar' tests for gdki18n.h
-AC_MSG_CHECKING(for wchar.h)
-AC_TRY_CPP([#include <wchar.h>], gdk_wchar_h=yes, gdk_wchar_h=no)
-if test $gdk_wchar_h = yes; then
-   AC_DEFINE(HAVE_WCHAR_H,1,[Have wchar.h include file])
-fi
-AC_MSG_RESULT($gdk_wchar_h)
+    if $have_xft = 'true' ; then
+      X_LIBS="-lXft -lXrender -lXext $FREETYPE_LIBS $X_LIBS"
+      AC_DEFINE(HAVE_XFT)
+    fi
+  fi
 
-# Check for wctype.h (for iswalnum)
-AC_MSG_CHECKING(for wctype.h)
-AC_TRY_CPP([#include <wctype.h>], gdk_wctype_h=yes, gdk_wctype_h=no)
-if test $gdk_wctype_h = yes; then
-   AC_DEFINE(HAVE_WCTYPE_H,1,[Have wctype.h include file])
-fi
-AC_MSG_RESULT($gdk_wctype_h)
+  AM_CONDITIONAL(HAVE_XFT, $have_xft)
 
-# in Solaris 2.5, `iswalnum' is in -lw
-GDK_WLIBS=
-AC_CHECK_FUNC(iswalnum,,[AC_CHECK_LIB(w,iswalnum,GDK_WLIBS=-lw)])
+  # Check for XIM support.
 
-oLIBS="$LIBS"
-LIBS="$LIBS $GDK_WLIBS"
-# The following is necessary for Linux libc-5.4.38
-AC_MSG_CHECKING(if iswalnum() and friends are properly defined)
-AC_TRY_LINK([#include <stdlib.h>],[
-#if (defined(HAVE_WCTYPE_H) || defined(HAVE_WCHAR_H))
-#  ifdef HAVE_WCTYPE_H
-#    include <wctype.h>
-#  else
-#    ifdef HAVE_WCHAR_H
-#      include <wchar.h>
-#    endif
-#  endif
-#else
-#  define iswalnum(c) ((wchar_t)(c) <= 0xFF && isalnum(c))
-#endif
-iswalnum((wchar_t) 0);
-], gdk_working_wctype=yes, gdk_working_wctype=no)
-LIBS="$oLIBS"
+  AC_CHECK_LIB(X11, XUnregisterIMInstantiateCallback,
+           : ,
+           enable_xim_inst="no",
+           $x_libs)
 
-if test $gdk_working_wctype = no; then
-   AC_DEFINE(HAVE_BROKEN_WCTYPE,1,[Is the wctype implementation broken])
-   GDK_WLIBS=
-fi
-AC_MSG_RESULT($gdk_working_wctype)
-AC_SUBST(GDK_WLIBS)
+  # On Solaris, calling XRegisterIMInstantiateCallback seems to
+  # cause an immediate segfault, so we disable it, unless
+  # the user specifically forces it to be on.
 
-AC_SUBST(GTK_DEBUG_FLAGS)
-AC_SUBST(GTK_XIM_FLAGS)
-AC_SUBST(GTK_LOCALE_FLAGS)
+  if test x$enable_xim_inst = xmaybe ; then
+    case host in
+         *-*-solaris*)
+            enable_xim_inst="no"
+            ;;
+         *)
+           enable_xim_inst="yes"
+           ;;
+    esac
+  fi
 
-##################################################
-# Checks for gdk-pixbuf
-##################################################
+  if test "x$enable_xim" = "xyes"; then
+    GTK_XIM_FLAGS="-DUSE_XIM"
+    if test "x$enable_xim_inst" = "xyes"; then
+      AC_DEFINE(USE_X11R6_XIM)
+    fi
+  fi
+
+  # Check for XKB support.
+
+  if test "x$enable_xkb" = "xyes"; then
+        AC_MSG_WARN(XKB support explicitly enabled)
+        AC_DEFINE(HAVE_XKB)
+  elif test "x$enable_xkb" = "xmaybe"; then
+        AC_CHECK_LIB(X11, XkbQueryExtension,
+                     AC_DEFINE(HAVE_XKB),
+                    ,
+                    $x_libs)
+  else
+        AC_MSG_WARN(XKB support explicitly disabled)
+  fi
+
+  x_cflags="$X_CFLAGS"
+  x_ldflags="$X_LDFLAGS"
+
+  # set up things for XInput
+
+  if test "x$with_xinput" = "xgxi" || test "x$with_xinput" = "xyes"; then
+    AC_DEFINE(XINPUT_GXI)
+    xinput_progs=gxid
+    x_libs="-lXi $x_libs"
+  elif test "x$with_xinput" = "xxfree"; then
+    AC_DEFINE(XINPUT_XFREE)
+    x_libs="-lXi $x_libs"
+  else
+    AC_DEFINE(XINPUT_NONE)
+  fi
+
+  AM_CONDITIONAL(XINPUT_GXI, test x$with_xinput = xgxi)
+  AM_CONDITIONAL(XINPUT_XFREE, test x$with_xinput = xxfree)
+
+  if test "x$enable_shm" = "xyes"; then
+    # Check for shared memory
+    AC_CHECK_HEADER(sys/ipc.h, AC_DEFINE(HAVE_IPC_H), no_sys_ipc=yes)
+    AC_CHECK_HEADER(sys/shm.h, AC_DEFINE(HAVE_SHM_H), no_sys_shm=yes)
+
+    # Check for the X shared memory extension header file
+    AC_MSG_CHECKING(X11/extensions/XShm.h)
+    if test "x$no_xext_lib" = "xyes"; then
+      AC_MSG_RESULT(no)
+      no_xshm=yes
+    else
+      if test -f "$x_includes/X11/extensions/XShm.h"; then
+        AC_MSG_RESULT(yes)
+        AC_DEFINE(HAVE_XSHM_H)
+      else
+        AC_MSG_RESULT(no)
+        no_xshm=yes
+      fi
+    fi
+  fi
 
-AC_MSG_CHECKING(whether to build gmodulized gdk-pixbuf)
+  GDK_EXTRA_CFLAGS="$GDK_EXTRA_CFLAGS $x_cflags"
+  GDK_EXTRA_LIBS="$x_ldflags $x_libs $GDK_EXTRA_LIBS"
 
-AC_ARG_ENABLE(modules, [  --disable-modules       Disables dynamic module loading],[
-       if test x$withval = xyes; then 
-           with_modules=yes
-        else
-            with_modules=no
-       fi
-])
+  # these are already defined above
+  #gdktargetlib = "libgdk-x11-1.3.la"
+  #gtktargetlib = "libgtk-x11-1.3.la"
 
-dynworks=false
-deps=
-if test x$with_modules = xno; then
-    AC_MSG_RESULT(no)
+  AM_CONDITIONAL(USE_X11, true)
 else
-    AC_MSG_RESULT(yes)
-    AC_MSG_CHECKING(whether dynamic modules work)
-    oLIBS="$LIBS"
-    oCFLAGS="$CFLAGS"
-    CFLAGS="$GLIB_CFLAGS"
-    LIBS="$GLIB_LIBS"
-    AC_TRY_RUN([
-    #include <glib.h>
-    #include <gmodule.h>
-    main ()
-    {
-       if (g_module_supported ())
-           exit (0);
-       else
-           exit (1);
-    }
-    ], dynworks=true)
-    LIBS="$oLIBS"
-    CFLAGS="$oCFLAGS"
+  AM_CONDITIONAL(USE_X11, false)
 fi
 
-dnl Now we check to see if our libtool supports shared lib deps
-dnl (in a rather ugly way even)
-if $dynworks; then
-   pixbuf_libtool_config="${CONFIG_SHELL-/bin/sh} libtool --config"
-   pixbuf_deplibs_check=`$pixbuf_libtool_config | \
-      grep '^[[a-z_]]*check[[a-z_]]*_method=[['\''"]]' | \
-      sed 's/.*[['\''"]]\(.*\)[['\''"]]$/\1/'`
-   if test "x$pixbuf_deplibs_check" = "xnone" || \
-      test "x$pixbuf_deplibs_check" = "xunknown" || \
-      test "x$pixbuf_deplibs_check" = "x"; then
-      dynworks=false
-   fi
-fi
+AC_SUBST(xinput_progs)
 
-if $dynworks; then
-   AC_DEFINE(USE_GMODULE)
-   AC_MSG_RESULT(yes)
+GDK_PIXBUF_XLIB_PACKAGES=
+GDK_PIXBUF_XLIB_DEP_LIBS="`pkg-config --libs $GDK_PIXBUF_PACKAGES $GDK_PIXBUF_XLIB_PACKAGES` $GDK_PIXBUF_XLIB_EXTRA_LIBS $GDK_PIXBUF_EXTRA_LIBS"
+GDK_PIXBUF_XLIB_DEP_CFLAGS="`pkg-config --cflags  $GDK_PIXBUF_PACKAGES $GDK_PIXBUF_XLIB_PACKAGES` $GDK_PIXBUF_EXTRA_CFLAGS $GDK_PIXBUF_XLIB_EXTRA_CFLAGS"
+
+AC_SUBST(GDK_PIXBUF_XLIB_PACKAGES)
+AC_SUBST(GDK_PIXBUF_XLIB_EXTRA_LIBS)
+AC_SUBST(GDK_PIXBUF_XLIB_EXTRA_CFLAGS)
+AC_SUBST(GDK_PIXBUF_XLIB_DEP_LIBS)
+AC_SUBST(GDK_PIXBUF_XLIB_DEP_CFLAGS)
+
+if test "x$gdktarget" = "xnanox"; then
+  AC_CHECK_LIB(nano-X, GrOpen,,AC_MSG_ERROR([nano-X libraries not found.]))
+  # nano-X may require additional libraries
+  GDK_EXTRA_LIBS="-lnano-X $GDK_EXTRA_LIBS"
+
+  gdktargetlib="libgdk-nanox-1.3.la"
+  gtktargetlib="libgtk-nanox-1.3.la"
+
+  AM_CONDITIONAL(USE_NANOX, true)
 else
-   AC_MSG_RESULT(no)
+  AM_CONDITIONAL(USE_NANOX, false)
 fi
 
-dnl Test for libtiff
-  if test -z "$LIBTIFF"; then
-    AC_CHECK_LIB(tiff, TIFFReadScanline,
-      AC_CHECK_HEADER(tiffio.h,
-        TIFF='tiff'; LIBTIFF='-ltiff',
-        AC_MSG_WARN(*** TIFF loader will not be built (TIFF header files not found) ***)),
-      AC_CHECK_LIB(tiff, TIFFWriteScanline,
-        AC_CHECK_HEADER(tiffio.h,
-          TIFF='tiff'; LIBTIFF='-ltiff -ljpeg -lz',
-          AC_MSG_WARN(*** TIFF loader will not be built (TIFF header files not found) ***)),
-        AC_CHECK_LIB(tiff34, TIFFFlushData,
-          AC_CHECK_HEADER(tiffio.h,
-            TIFF='tiff'; LIBTIFF='-ltiff34 -ljpeg -lz',
-            AC_MSG_WARN(*** TIFF loader will not be built (TIFF header files not found) ***)),
-        AC_MSG_WARN(*** TIFF plug-in will not be built (TIFF library not found) ***), -ljpeg -lz -lm), -ljpeg -lz -lm), -lm)
-  fi
+if test "x$gdktarget" = "xlinux-fb"; then
+  gdktargetlib="libgdk-linux-fb-1.3.la"
+  gtktargetlib="libgtk-linux-fb-1.3.la"
 
-dnl Test for libjpeg
-  if test -z "$LIBJPEG"; then
-    AC_CHECK_LIB(jpeg, jpeg_destroy_decompress,
-      jpeg_ok=yes,
-      jpeg_ok=no
-      AC_MSG_WARN(*** JPEG loader will not be built (JPEG library not found) ***))
-    if test "$jpeg_ok" = yes; then
-      AC_MSG_CHECKING([for jpeglib.h])
-      AC_TRY_CPP(
-[#include <stdio.h>
-#undef PACKAGE
-#undef VERSION
-#include <jpeglib.h>],
-        jpeg_ok=yes,
-        jpeg_ok=no)
-      AC_MSG_RESULT($jpeg_ok)
-      if test "$jpeg_ok" = yes; then
-        LIBJPEG='-ljpeg'
-        AC_CHECK_LIB(jpeg, jpeg_simple_progression,     
-          AC_DEFINE(HAVE_PROGRESSIVE_JPEG),
-          AC_MSG_WARN(JPEG library does not support progressive saving.))
-      else
-          AC_MSG_WARN(*** JPEG loader will not be built (JPEG header file not found) ***)
-      fi
-    fi
+  AC_PATH_PROG(FREETYPE_CONFIG, freetype-config, no)
+  if test x$FREETYPE_CONFIG = xno ; then
+    AC_MSG_ERROR([*** freetype-config not found])
   fi
 
-dnl Test for libpng
-  if test -z "$LIBPNG"; then
-    AC_CHECK_LIB(png, png_read_info,
-      AC_CHECK_HEADER(png.h,
-        png_ok=yes,
-        png_ok=no),
-      AC_MSG_WARN(*** PNG loader will not be built (PNG library not found) ***), -lz -lm)
-    if test "$png_ok" = yes; then
-      AC_MSG_CHECKING([for png_structp in png.h])
-      AC_TRY_COMPILE([#include <png.h>],
-        [png_structp pp; png_infop info; png_colorp cmap; png_create_read_struct;],
-        png_ok=yes,
-        png_ok=no)
-      AC_MSG_RESULT($png_ok)
-      if test "$png_ok" = yes; then
-        PNG='png'; LIBPNG='-lpng -lz'
-      else
-        AC_MSG_WARN(*** PNG loader will not be built (PNG library is too old) ***)
-      fi
-    else
-     AC_MSG_WARN(*** PNG loader will not be built (PNG header file not found) ***)
-    fi
-  fi
+  FREETYPE_CFLAGS="`$FREETYPE_CONFIG --cflags`"
+  FREETYPE_LIBS="`$FREETYPE_CONFIG --libs`"
+  CFLAGS="$CFLAGS $FREETYPE_CFLAGS"
 
-deps="$LIBTIFF $LIBJPEG $LIBPNG"
+  if test x$enable_shadowfb = xyes ; then
+    AC_DEFINE(ENABLE_SHADOW_FB)
+  fi
+  
+  GDK_EXTRA_CFLAGS="$FREETYPE_CFLAGS"
+  GDK_EXTRA_LIBS="$FREETYPE_LIBS $GDK_EXTRA_LIBS"
 
-AC_SUBST(LIBTIFF)
-AC_SUBST(LIBJPEG)
-AC_SUBST(LIBPNG)
+  AM_CONDITIONAL(USE_LINUX_FB, true)
+else
+  AM_CONDITIONAL(USE_LINUX_FB, false)
+fi
 
-AM_CONDITIONAL(BUILD_DYNAMIC_MODULES, $dynworks)
+AC_SUBST(gdktargetlib)
+AC_SUBST(gtktargetlib)
 
 #
-# Allow building some or all gdk-pixbuf loaders included
+# Pick correct Pango packages to use
 #
-AC_MSG_CHECKING(pixbuf loaders to build)
-
-AC_ARG_WITH(included_loaders, [  --with-included-loaders=LOADER1,LOADER2,... Build the specified loaders into gdk-pixbuf (only used if module loading disabled)])
 
-all_loaders="png,bmp,wbmp,gif,ico,jpeg,pnm,ras,tiff,xpm"
-included_loaders=""
-# If no loaders specified, include all
-if test "x$with_included_loaders" = xyes ; then
-  included_loaders="$all_loaders"
+if test "x$gdktarget" = "xx11"; then
+       if $have_xft = true ; then
+            PANGO_PACKAGES="pangox pangoxft"
+        else
+            PANGO_PACKAGES=pangox
+        fi
+elif test "x$gdktarget" = "xlinux-fb"; then
+        PANGO_PACKAGES=pangoft2
 else
-  included_loaders="$with_included_loaders"
+        PANGO_PACKAGES=pango
 fi
 
-AC_MSG_RESULT($included_loaders)
+# Check for Pango flags
 
-INCLUDED_LOADER_OBJ=
-INCLUDED_LOADER_DEFINE=
+AC_MSG_CHECKING(Pango flags)
+if $PKG_CONFIG --exists $PANGO_PACKAGES ; then
+        PANGO_CFLAGS=`$PKG_CONFIG --cflags $PANGO_PACKAGES`
+        PANGO_LIBS=`$PKG_CONFIG --libs $PANGO_PACKAGES`
 
-IFS="${IFS=    }"; gtk_save_ifs="$IFS"; IFS=","
-for loader in $included_loaders; do
- if ! echo "$all_loaders" | grep "\(^\|\,\)$loader\(\$\|\,\)" > /dev/null; then
-   AC_MSG_ERROR([the specified loader $loader does not exist])
- fi
+        AC_MSG_RESULT($PANGO_CFLAGS $PANGO_LIBS)
+else
+        AC_MSG_ERROR([
+*** Pango not found. Pango is required to build GTK+.
+*** See http://www.pango.org for Pango information.
+*** For the framebuffer target, you will need to build 
+*** Pango with freetype support.
+])
+fi
 
- INCLUDED_LOADER_OBJ="$INCLUDED_LOADER_OBJ libpixbufloader-static-$loader.la"
- INCLUDED_LOADER_DEFINE="$INCLUDED_LOADER_DEFINE -DINCLUDE_$loader"
-done
-IFS="$gtk_save_ifs"
-AC_SUBST(INCLUDED_LOADER_OBJ)
-AC_SUBST(INCLUDED_LOADER_DEFINE)
+CFLAGS="$CFLAGS $PANGO_CFLAGS"
 
-AC_HEADER_STDC
-AC_HEADER_DIRENT
-AC_HEADER_SYS_WAIT
+AC_CHECK_LIB(pango, pango_context_new, :, AC_MSG_ERROR([
+*** Can't link to Pango. Pango is required to build
+*** GTK+. For more information see http://www.pango.org]), $PANGO_LIBS $x_ldflags $x_libs)
 
-AC_TYPE_SIGNAL
+CFLAGS="$saved_cflags"
+LDFLAGS="$saved_ldflags"
 
-AM_CONDITIONAL(HAVE_TIFF, test "x$LIBTIFF" != x)
-AM_CONDITIONAL(HAVE_PNG, test "x$LIBPNG" != x)
-AM_CONDITIONAL(HAVE_JPEG, test "x$LIBJPEG" != x)
+GDK_PACKAGES=$PANGO_PACKAGES
+GDK_DEP_LIBS="`pkg-config --libs $GDK_PIXBUF_PACKAGES $GDK_PACKAGES` $GDK_EXTRA_LIBS $GDK_PIXBUF_EXTRA_LIBS"
+GDK_DEP_CFLAGS="`pkg-config --cflags  $GDK_PIXBUF_PACKAGES $GDK_PACKAGES` $GDK_PIXBUF_EXTRA_CFLAGS $GDK_EXTRA_CFLAGS"
 
-GDK_PIXBUF_LIBDIR='-L${libdir}'
-GDK_PIXBUF_INCLUDEDIR="-I${includedir} $GTK_CFLAGS"
-GDK_PIXBUF_LIBS="$GLIB_LIBS -lgdk_pixbuf $deps $GTK_LIBS"
-AC_SUBST(STATIC_LIB_DEPS)
-STATIC_LIB_DEPS="$deps"
+AC_SUBST(GDK_PACKAGES)
+AC_SUBST(GDK_EXTRA_LIBS)
+AC_SUBST(GDK_EXTRA_CFLAGS)
+AC_SUBST(GDK_DEP_LIBS)
+AC_SUBST(GDK_DEP_CFLAGS)
 
-AC_SUBST(GDK_PIXBUF_LIBDIR)
-AC_SUBST(GDK_PIXBUF_INCLUDEDIR)
-AC_SUBST(GDK_PIXBUF_LIBS)
 
-GDK_PIXBUF_XLIB_LIBDIR=$GDK_PIXBUF_LIBDIR
-GDK_PIXBUF_XLIB_INCLUDEDIR=$GDK_PIXBUF_INCLUDEDIR
-GDK_PIXBUF_XLIB_LIBS="$GLIB_LIBS -lgdk_pixbuf_xlib $deps $X11_LIBS"
+########################################
+# Check for Accessibility Toolkit flags
+########################################
 
-AC_SUBST(GDK_PIXBUF_XLIB_LIBDIR)
-AC_SUBST(GDK_PIXBUF_XLIB_INCLUDEDIR)
-AC_SUBST(GDK_PIXBUF_XLIB_LIBS)
+ATK_PACKAGES=atk
+AC_MSG_CHECKING(ATK flags)
+if $PKG_CONFIG --exists $ATK_PACKAGES ; then
+        ATK_CFLAGS=`$PKG_CONFIG --cflags $ATK_PACKAGES`
+        ATK_LIBS=`$PKG_CONFIG --libs $ATK_PACKAGES`
 
-# Checks to see if we should compile in MMX support (there will be
-# a runtime test when the code is actually run to see if it should
-# be used - this just checks if we can compile it.)
-#
-# This code is partially taken from Mesa
-#
-AC_MSG_CHECKING(for x86 platform)
-case $host_cpu in
-  i386|i486|i586|i686|i786|k6|k7)
-       use_x86_asm=yes
-        ;;
-   *)
-       use_x86_asm=no
-esac
-AC_MSG_RESULT($use_x86_asm)
+        AC_MSG_RESULT($ATK_CFLAGS $ATK_LIBS)
+else
+        AC_MSG_ERROR([
+*** Accessibility Toolkit not found. Accessibility Toolkit is required
+*** to build GTK+.
+])
+fi
 
-use_mmx_asm=no
-if test $use_x86_asm = yes; then
-    save_ac_ext=$ac_ext
-    ac_ext=S
-    
-    AC_MSG_CHECKING(compiler support for MMX)
-    cp $srcdir/gdk-pixbuf/pixops/scale_line_22_33_mmx.S conftest.S
-    if AC_TRY_EVAL(ac_compile); then
-        use_mmx_asm=yes
-    fi
+AC_CHECK_LIB(atk, atk_object_get_type, : , AC_MSG_ERROR([
+*** Cannot link to Accessibility Toolkit. Accessibility Toolkit is required
+*** to build GTK+]), $ATK_LIBS $GLIB_LIBS)
 
-    rm -rf conftest*
 
-    ac_ext=$save_ac_ext
-    if test $use_mmx_asm = yes; then
-      AC_DEFINE(USE_MMX)
-      AC_MSG_RESULT(yes)
-    else
-      AC_MSG_RESULT(no)
-    fi
-fi
+GTK_PACKAGES=atk
+GTK_EXTRA_LIBS=
+GTK_EXTRA_CFLAGS= 
+GTK_DEP_LIBS="`pkg-config --libs $GTK_PIXBUF_PACKAGES $GDK_PACKAGES $GTK_PACKAGES` $GTK_EXTRA_LIBS $GDK_EXTRA_LIBS $GDK_PIXBUF_EXTRA_LIBS"
+GTK_DEP_CFLAGS="`pkg-config --cflags  $GTK_PIXBUF_PACKAGES $GDK_PACKAGES $GTK_PACKAGES` $GDK_PIXBUF_EXTRA_CFLAGS $GDK_EXTRA_CFLAGS $GTK_EXTRA_CFLAGS"
+
+AC_SUBST(GTK_PACKAGES)
+AC_SUBST(GTK_EXTRA_LIBS)
+AC_SUBST(GTK_EXTRA_CFLAGS)
+AC_SUBST(GTK_DEP_LIBS)
+AC_SUBST(GTK_DEP_CFLAGS)
 
-AM_CONDITIONAL(USE_MMX, test x$use_mmx_asm = xyes)
 
+AC_SUBST(GTK_DEBUG_FLAGS)
+AC_SUBST(GTK_XIM_FLAGS)
 
 ##################################################
 # Checks for gtk-doc and docbook-tools
@@ -977,9 +1003,6 @@ EOF
    fi
 fi
 
-AM_CONDITIONAL(HAVE_GTK_DOC, $GTKDOC)
-AC_SUBST(HAVE_GTK_DOC)
-
 AC_CHECK_PROG(DB2HTML, db2html, true, false)
 AM_CONDITIONAL(HAVE_DOCBOOK, $DB2HTML)
 
@@ -998,9 +1021,6 @@ 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)
 
-GDK_PIXBUF_DIR=`(cd $srcdir; pwd)`
-AC_SUBST(GDK_PIXBUF_DIR)
-
 
 ##################################################
 # Output commands
index 3f8f74ec0c2baad006c817ec175191d778360387..e55035505f1a62a3e15846ba626381f0b1ebd6a1 100644 (file)
@@ -1,16 +1,14 @@
-
 lib_LTLIBRARIES=libgdk_pixbuf_xlib-1.3.la
 
-INCLUDES = -I$(top_srcdir) -I$(top_builddir)   \
+INCLUDES = @STRIP_BEGIN@                       \
+       -I$(top_srcdir) -I$(top_builddir)       \
        -I$(top_srcdir)/gdk-pixbuf              \
        -I$(top_srcdir)/contrib                 \
-       $(GLIB_CFLAGS)                          \
-       @x_cflags@ 
-LDADDS = @STRIP_BEGIN@         \
-       @x_ldflags@     \
-       @x_libs@        \
-       @GLIB_LIBS@     \
-       -lm             \
+       @GDK_PIXBUF_XLIB_DEP_CFLAGS@            \
+@STRIP_END@
+
+LDADDS = @STRIP_BEGIN@                                 \
+       @GDK_PIXBUF_XLIB_DEP_LIBS@              \
 @STRIP_END@
 
 libgdk_pixbuf_xlib_1_3_la_LDFLAGS =         \
index d86c8a1cc611e632dc686b674c6a93a390f7e18e..25eba726532215e09b6486b7c7b68d7b1c8c2b9e 100644 (file)
@@ -8,10 +8,7 @@ INCLUDES = @STRIP_BEGIN@ \
        -DGTK_DISABLE_COMPAT_H                          \
        -DGTK_DISABLE_DEPRECATED                        \
        @GTK_DEBUG_FLAGS@                               \
-       @GTK_XIM_FLAGS@                                 \
-       @PANGO_CFLAGS@                                  \
-       @GLIB_CFLAGS@                                   \
-       @more_cflags@                                   \
+       @GTK_DEP_CFLAGS@                                \
 @STRIP_END@
 
 DEPS = \
@@ -23,13 +20,6 @@ LDADDS = @STRIP_BEGIN@                                       \
        $(top_builddir)/gdk-pixbuf/libgdk_pixbuf-1.3.la \
        $(top_builddir)/gdk/@gdktargetlib@              \
        $(top_builddir)/gtk/@gtktargetlib@              \
-       @more_ldflags@                                  \
-       @more_libs@                                     \
-       @GDK_WLIBS@                                     \
-       @PANGO_LIBS@                                    \
-       @GLIB_LIBS@                                     \
-       @GTK_LIBS_EXTRA@                                \
-       -lm                                             \
 @STRIP_END@
 
 noinst_PROGRAMS =              \
index 50e2c3d9f3c4841f11438563167881abe81ad845..0154a1ef564f472da2863ec07b295a5dace3b1aa 100644 (file)
@@ -26,10 +26,7 @@ INCLUDES = @STRIP_BEGIN@ \
        -DGTK_DISABLE_COMPAT_H                          \
        -DGTK_DISABLE_DEPRECATED                        \
        @GTK_DEBUG_FLAGS@                               \
-       @GTK_XIM_FLAGS@                                 \
-       @PANGO_CFLAGS@                                  \
-       @GLIB_CFLAGS@                                   \
-       @more_cflags@                                   \
+       @GTK_DEP_CFLAGS@                                \
 @STRIP_END@
 
 DEPS = \
@@ -41,13 +38,6 @@ LDADDS = @STRIP_BEGIN@                                       \
        $(top_builddir)/gdk-pixbuf/libgdk_pixbuf-1.3.la \
        $(top_builddir)/gdk/@gdktargetlib@              \
        $(top_builddir)/gtk/@gtktargetlib@              \
-       @more_ldflags@                                  \
-       @more_libs@                                     \
-       @GDK_WLIBS@                                     \
-       @PANGO_LIBS@                                    \
-       @GLIB_LIBS@                                     \
-       @GTK_LIBS_EXTRA@                                \
-       -lm                                             \
 @STRIP_END@
 
 bin_PROGRAMS = gtk-demo
index 0623527c9cf6466b3537190a683a307b934cb3a8..ef63e95655351d6fa0cd043ac5985eef1bd83043 100644 (file)
@@ -54,23 +54,14 @@ GTKDOC_CFLAGS = @STRIP_BEGIN@                               \
        -I$(top_builddir)/gdk                           \
        -DGTK_DISABLE_COMPAT_H                          \
        @GTK_DEBUG_FLAGS@                               \
-       @GTK_XIM_FLAGS@                                 \
-       @PANGO_CFLAGS@                                  \
-       @GLIB_CFLAGS@                                   \
-       @more_cflags@                                   \
+       @GTK_DEP_CFLAGS@                                \
 @STRIP_END@
 
 GTKDOC_LIBS = @STRIP_BEGIN@                            \
        $(top_builddir)/gdk-pixbuf/libgdk_pixbuf-1.3.la \
        $(top_builddir)/gdk/@gdktargetlib@              \
        $(top_builddir)/gtk/@gtktargetlib@              \
-       @more_ldflags@                                  \
-       @more_libs@                                     \
-       @GDK_WLIBS@                                     \
-       @PANGO_LIBS@                                    \
-       @GLIB_LIBS@                                     \
-       @GTK_LIBS_EXTRA@                                \
-       -lm                                             \
+       @GTK_DEP_LIBS@                                  \
 @STRIP_END@
 
 GTKDOC_CC=$(LIBTOOL) --mode=compile $(CC)
index 8d479fb0e1f56170381f2fdc9e56c6002dca471d..47470743a8193bd29c714b33fde4591286687d73 100644 (file)
@@ -70,23 +70,13 @@ GTKDOC_CFLAGS = @STRIP_BEGIN@                               \
        -I$(top_builddir)/gdk                           \
        -DGTK_ENABLE_BROKEN                             \
        @GTK_DEBUG_FLAGS@                               \
-       @GTK_XIM_FLAGS@                                 \
-       @PANGO_CFLAGS@                                  \
-       @GLIB_CFLAGS@                                   \
-       @more_cflags@                                   \
+       @GTK_DEP_CFLAGS@                                \
 @STRIP_END@
 
 GTKDOC_LIBS = @STRIP_BEGIN@                            \
        $(top_builddir)/gdk-pixbuf/libgdk_pixbuf-1.3.la \
        $(top_builddir)/gdk/@gdktargetlib@              \
        $(top_builddir)/gtk/@gtktargetlib@              \
-       @more_ldflags@                                  \
-       @more_libs@                                     \
-       @GDK_WLIBS@                                     \
-       @PANGO_LIBS@                                    \
-       @GLIB_LIBS@                                     \
-       @GTK_LIBS_EXTRA@                                \
-       -lm                                             \
 @STRIP_END@
 
 GTKDOC_CC=$(LIBTOOL) --mode=compile $(CC)
index b69c3e29b28fb62d215db8e08eef8668ddb08dae..54048b642034e0df81c5265b13582d095d4f8817 100644 (file)
@@ -7,6 +7,6 @@ target=@gdktarget@
 Name: GDK
 Description: GIMP Drawing Kit (${target} target)
 Version: @VERSION@
-Requires: gdk-pixbuf-2.0 @PANGO_PACKAGES@
-Libs: -L${libdir} @more_ldflags@ -lgdk-${target}-1.3 @more_libs@ @GDK_WLIBS@
-Cflags: -I${includedir}/gtk-2.0 -I${libdir}/gtk-2.0/include @more_cflags@
+Requires: gdk-pixbuf-2.0 @GDK_PACKAGES@
+Libs: -L${libdir} -lgdk-${target}-1.3 @GDK_EXTRA_LIBS@
+Cflags: -I${includedir}/gtk-2.0 -I${libdir}/gtk-2.0/include @GDK_EXTRA_CFLAGS@
index 36480dc1a9a950e9ae4cf0db78469ce83c96e497..f4c0fb5b9788b77045ba3934b76532ca7c00467a 100644 (file)
@@ -7,6 +7,6 @@ Name: GdkPixbuf
 Description: Image loading and scaling
 Version: @VERSION@
 Requires: gobject-2.0,gmodule-2.0
-Libs: -L${libdir} -lgdk_pixbuf-1.3 @INTLLIBS@ @MATH_LIB@
-Cflags: -I${includedir}/gtk-2.0
+Libs: -L${libdir} -lgdk_pixbuf-1.3 @GDK_PIXBUF_EXTRA_LIBS@
+Cflags: -I${includedir}/gtk-2.0 @GDK_PIXBUF_EXTRA_CFLAGS@
 
index 21a222c34838f60ba9af1ae63cb26b82e4d0dd3a..c8ba6e08831b476ed6a6a5d075de8c75ecaaa71e 100644 (file)
@@ -154,22 +154,21 @@ noinst_LTLIBRARIES =      \
 
 builtin_objs = @INCLUDED_LOADER_OBJ@
 
-static_libs = $(STATIC_LIB_DEPS)
-
 endif
 
 noinst_PROGRAMS = test-gdk-pixbuf
 TESTS = test-gdk-pixbuf
 
 DEPS = libgdk_pixbuf-1.3.la
-INCLUDES = -I$(top_srcdir) -I$(top_builddir) \
-       -I$(top_srcdir)/gdk-pixbuf \
-       -I$(top_builddir)/gdk-pixbuf \
-       @INCLUDED_LOADER_DEFINE@ \
-       @GLIB_CFLAGS@
+INCLUDES = -I$(top_srcdir) -I$(top_builddir)   \
+       -I$(top_srcdir)/gdk-pixbuf              \
+       -I$(top_builddir)/gdk-pixbuf            \
+       @INCLUDED_LOADER_DEFINE@                \
+       @GTK_DEBUG_FLAGS@                       \
+       @GDK_PIXBUF_DEP_CFLAGS@
 AM_CPPFLAGS = "-DPIXBUF_LIBDIR=\"$(loaderdir)\""
 
-LDADDS = libgdk_pixbuf-1.3.la $(GLIB_LIBS) $(STATIC_LIB_DEPS) $(MATH_LIB)
+LDADDS = libgdk_pixbuf-1.3.la
 
 test_gdk_pixbuf_LDADD = $(LDADDS)
 
@@ -179,8 +178,6 @@ make_inline_pixbuf_SOURCES=make-inline-pixbuf.c
 
 make_inline_pixbuf_LDADD = $(LDADDS)
 
-GDK_PIXBUF_LIBS = $(GLIB_LIBS) $(INTLLIBS)
-
 #
 # The GdkPixBuf library
 #
@@ -205,7 +202,7 @@ libgdk_pixbuf_1_3_la_LDFLAGS =                                      \
        -version-info $(LT_CURRENT):$(LT_REVISION):$(LT_AGE)    \
        @LIBTOOL_EXPORT_OPTIONS@                                \
        $(GLIB_LIBS) 
-libgdk_pixbuf_1_3_la_LIBADD = pixops/libpixops.la $(builtin_objs) $(static_libs)
+libgdk_pixbuf_1_3_la_LIBADD = pixops/libpixops.la $(builtin_objs) $(GDK_PIXBUF_DEP_LIBS)
 libgdk_pixbuf_1_3_la_DEPENDENCIES = $(builtin_objs)
 
 libgdk_pixbufinclude_HEADERS = \
index 0c18890e50c67643be670ec82c9cca3291e21619..6ca672b0788a45319364de44f38885aa7eb50f34 100644 (file)
@@ -17,10 +17,7 @@ common_includes = @STRIP_BEGIN@      \
        -I$(top_builddir)/gdk           \
        -I$(top_srcdir)/gdk-pixbuf      \
        @GTK_DEBUG_FLAGS@               \
-       @GTK_XIM_FLAGS@                 \
-       @PANGO_CFLAGS@                  \
-       @GLIB_CFLAGS@                   \
-       @more_cflags@                   \
+       @GDK_DEP_CFLAGS@                \
 @STRIP_END@
 
 INCLUDES = $(common_includes)
@@ -34,10 +31,7 @@ LDFLAGS = @STRIP_BEGIN@                                      \
        -export-dynamic                                         \
        -rpath @prefix@/lib                                     \
        @LIBTOOL_EXPORT_OPTIONS@                                \
-       @PANGO_LIBS@                                            \
-       @GLIB_DEPLIBS@                                          \
-       @more_ldflags@                                          \
-       @more_libs@                                             \
+       @GDK_DEP_LIBS@                                          \
        -lm                                                     \
 @STRIP_END@
 
index f8cd8ba798ef38778b9bca20a242fed955137a01..795f15d9a9cfe888c5225275fe25544c3ebd5664 100644 (file)
@@ -9,17 +9,12 @@ INCLUDES = @STRIP_BEGIN@      \
        -I$(top_srcdir)         \
        -I$(top_srcdir)/gdk     \
        -I$(top_builddir)/gdk   \
-       @FREETYPE_CFLAGS@       \
+       @GDK_DEP_CFLAGS@        \
        @GTK_DEBUG_FLAGS@       \
-       @GTK_XIM_FLAGS@         \
-       @GLIB_CFLAGS@           \
-       @PANGO_CFLAGS@          \
 @STRIP_END@
 
 LDFLAGS = @STRIP_BEGIN@ \
-       @GLIB_LIBS@     \
-       @PANGO_LIBS@    \
-       @FREETYPE_LIBS@ \
+       @GDK_DEP_LIBS@  \
        -lm             \
 @STRIP_END@
 
index 043ac89a9ee5baa301e329a5110aecc2adc2b4d6..d906549139bdb4377355a5e1313f06449860413d 100644 (file)
@@ -5,16 +5,11 @@ INCLUDES = @STRIP_BEGIN@      \
        -I$(top_srcdir)         \
        -I$(top_srcdir)/gdk     \
        @GTK_DEBUG_FLAGS@       \
-       @GTK_XIM_FLAGS@         \
-       @GLIB_CFLAGS@           \
-       @more_cflags@           \
+       @GDK_DEP_CFLAGS@        \
 @STRIP_END@
 
-LDADDS = @STRIP_BEGIN@         \
-       @more_ldflags@  \
-       @more_libs@     \
-       @GLIB_LIBS@     \
-       -lm             \
+LDADDS = @STRIP_BEGIN@                 \
+       @GDK_DEP_LIBS@          \
 @STRIP_END@
 
 noinst_LTLIBRARIES = libgdk-nanox.la
index 79a2ce2ac4f5a8e81678cf01061cf5b708e8f6f9..703ebee435069de02b538ed1a11146e8fee5a5d7 100644 (file)
@@ -9,18 +9,11 @@ INCLUDES = @STRIP_BEGIN@      \
        -I$(top_srcdir)/gdk     \
        -I$(top_builddir)/gdk   \
        @GTK_DEBUG_FLAGS@       \
-       @GTK_XIM_FLAGS@         \
-       @PANGO_CFLAGS@          \
-       @GLIB_CFLAGS@           \
-       @FREETYPE_CFLAGS@       \
-       @x_cflags@              \
+       @GDK_DEP_CFLAGS@        \
 @STRIP_END@
 
-LDADDS = @STRIP_BEGIN@         \
-       @x_ldflags@     \
-       @x_libs@        \
-       @GLIB_LIBS@     \
-       -lm             \
+LDADDS = @STRIP_BEGIN@                 \
+       @GDK_DEP_LIBS@          \
 @STRIP_END@
 
 noinst_LTLIBRARIES = libgdk-x11.la
index 8d8876a1ad8aaec94678d1244b8a1b975791fe5d..f5a163a767436a5a506983dacea8cc80a90c6936 100644 (file)
@@ -785,4 +785,4 @@ gdk_keyval_convert_case (guint symbol,
   if (upper)
     *upper = xupper;
 }  
-#endif HAVE_XCONVERTCASE
+#endif /* HAVE_XCONVERTCASE */
index c6321e1b861b69c11773728a7fd093cc9408b16f..1773f761cc360ddcd42c5e6acbdb22c0c5438e0c 100644 (file)
 #include <limits.h>
 #include <errno.h>
 
-#ifdef HAVE_SYS_SELECT_H
-#include <sys/select.h>
-#endif /* HAVE_SYS_SELECT_H_ */
-
-#define XLIB_ILLEGAL_ACCESS
 #include <X11/Xatom.h>
 #include <X11/Xlib.h>
-#include <X11/Xos.h>
 #include <X11/Xutil.h>
-#include <X11/cursorfont.h>
 
 #ifdef HAVE_XKB
 #include <X11/XKBlib.h>
index baab69a33a24a1c096ada88c08f8cda7ac276105..4c6c1bcb0cd7fff5a75ec88ae983747ec8d6a836 100644 (file)
@@ -7,6 +7,6 @@ target=@gdktarget@
 Name: GTK+
 Description: GIMP Tool Kit (${target} target)
 Version: @VERSION@
-Requires: gdk-${target}-2.0
-Libs: -L${libdir} -lgtk-${target}-1.3
-Cflags: -I${includedir}/gtk-2.0
+Requires: gdk-${target}-2.0 @GTK_PACKAGES@
+Libs: -L${libdir} -lgtk-${target}-1.3 @GTK_EXTRA_LIBS@
+Cflags: -I${includedir}/gtk-2.0 @GTK_EXTRA_CFLAGS@
index 1822458844e69855148cb4b3c47f6aa1d60d3007..2f3c3e40c97ba90ae1520b52d976c555af06e7a2 100644 (file)
@@ -16,11 +16,7 @@ INCLUDES = @STRIP_BEGIN@ \
        -I$(top_srcdir) -I../gdk                        \
        -I$(top_srcdir)/gdk                             \
        -I$(top_srcdir)/gdk-pixbuf -I../gdk-pixbuf      \
-       @GTK_DEBUG_FLAGS@                               \
-       @GTK_XIM_FLAGS@                                 \
-       @PANGO_CFLAGS@                                  \
-       @GLIB_CFLAGS@                                   \
-       @more_cflags@                                   \
+       @GTK_DEP_CFLAGS@                                \
 @STRIP_END@
 
 gtarget=@gdktarget@
@@ -34,11 +30,7 @@ LDFLAGS = @STRIP_BEGIN@ \
        -export-dynamic                                         \
        -rpath @prefix@/lib                                     \
        @LIBTOOL_EXPORT_OPTIONS@                                \
-       @PANGO_LIBS@                                            \
-       @GLIB_DEPLIBS@                                          \
-       @more_ldflags@                                          \
-       @more_libs@                                             \
-       -lm                                                     \
+       @GTK_DEP_LIBS@                                          \
 @STRIP_END@
 
 #
@@ -51,6 +43,7 @@ gtk_public_h_sources = @STRIP_BEGIN@ \
        gtk.h                   \
        gtkaccelgroup.h         \
        gtkaccellabel.h         \
+       gtkaccessible.h         \
        gtkadjustment.h         \
        gtkalignment.h          \
        gtkarg.h                \
@@ -209,6 +202,7 @@ gtk_private_h_sources = @STRIP_BEGIN@ \
 gtk_c_sources = @STRIP_BEGIN@   \
        gtkaccelgroup.c         \
        gtkaccellabel.c         \
+       gtkaccessible.c         \
        gtkadjustment.c         \
        gtkalignment.c          \
        gtkarg.c                \
@@ -516,13 +510,6 @@ LDADDS = @STRIP_BEGIN@ \
        @gtktargetlib@                                  \
        $(top_builddir)/gdk-pixbuf/libgdk_pixbuf-1.3.la \
        $(top_builddir)/gdk/@gdktargetlib@              \
-       @more_ldflags@                                  \
-       @more_libs@                                     \
-       @GDK_WLIBS@                                     \
-       @PANGO_LIBS@                                    \
-       @GLIB_LIBS@                                     \
-       @GTK_LIBS_EXTRA@                                \
-       -lm                                             \
 @STRIP_END@
 
 #
index 512e9523d253344a3c1335cbd296c50ae87164e1..5c50ce22cc8cf9ca349b9dbb4b11cc5baf29cdc0 100644 (file)
--- a/gtk/gtk.h
+++ b/gtk/gtk.h
@@ -31,6 +31,7 @@
 #include <gdk/gdk.h>
 #include <gtk/gtkaccelgroup.h>
 #include <gtk/gtkaccellabel.h>
+#include <gtk/gtkaccessible.h>
 #include <gtk/gtkadjustment.h>
 #include <gtk/gtkalignment.h>
 #include <gtk/gtkarg.h>
diff --git a/gtk/gtkaccessible.c b/gtk/gtkaccessible.c
new file mode 100644 (file)
index 0000000..d5a96b2
--- /dev/null
@@ -0,0 +1,93 @@
+/* GTK - The GIMP Toolkit
+ * Copyright 2001 Sun Microsystems Inc.
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the
+ * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ * Boston, MA 02111-1307, USA.
+ */
+
+#include <string.h>
+#include <gtk/gtkwidget.h>
+#include <gtk/gtksignal.h>
+#include <gtk/gtkaccessible.h>
+
+static void gtk_accessible_class_init (GtkAccessibleClass *klass);
+
+static void gtk_accessible_real_connect_widget_destroyed (GtkAccessible *accessible);
+
+GtkType
+gtk_accessible_get_type (void)
+{
+  static GtkType accessible_type = 0;
+
+  if (!accessible_type)
+    {
+      static const GTypeInfo accessible_info =
+      {
+       sizeof (GtkAccessibleClass),
+       NULL,           /* base_init */
+       NULL,           /* base_finalize */
+       (GClassInitFunc) gtk_accessible_class_init,
+       NULL,           /* class_finalize */
+       NULL,           /* class_data */
+       sizeof (GtkAccessible),
+       16,             /* n_preallocs */
+       (GInstanceInitFunc) NULL,
+      };
+
+      accessible_type = g_type_register_static (ATK_TYPE_OBJECT, "GtkAccessible", &accessible_info, 0);
+    }
+
+  return accessible_type;
+}
+
+static void
+gtk_accessible_class_init (GtkAccessibleClass *klass)
+{
+  klass->connect_widget_destroyed = gtk_accessible_real_connect_widget_destroyed;
+
+}
+
+/**
+ * gtk_accessible_connect_widget_destroyed
+ * @accessible: a #GtkAccessible
+ *
+ * This function specifies the callback function to be called when the widget
+ * corresponding to a GtkAccessible is destroyed.
+ */
+void
+gtk_accessible_connect_widget_destroyed (GtkAccessible *accessible)
+{
+  GtkAccessibleClass *class;
+
+  g_return_if_fail (accessible != NULL);
+  g_return_if_fail (GTK_IS_ACCESSIBLE (accessible));
+
+  class = GTK_ACCESSIBLE_GET_CLASS (accessible);
+
+  if (class->connect_widget_destroyed)
+    class->connect_widget_destroyed (accessible);
+}
+
+static void
+gtk_accessible_real_connect_widget_destroyed (GtkAccessible *accessible)
+{
+  if (accessible->widget)
+  {
+    gtk_signal_connect (GTK_OBJECT (accessible->widget),
+                        "destroy",
+                        GTK_SIGNAL_FUNC (gtk_widget_destroyed),
+                        &accessible->widget);
+  }
+}
diff --git a/gtk/gtkaccessible.h b/gtk/gtkaccessible.h
new file mode 100644 (file)
index 0000000..a09832e
--- /dev/null
@@ -0,0 +1,73 @@
+/* GTK - The GIMP Toolkit
+ * Copyright 2001 Sun Microsystems Inc.
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Library General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Library General Public License for more details.
+ *
+ * You should have received a copy of the GNU Library General Public
+ * License along with this library; if not, write to the
+ * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ * Boston, MA 02111-1307, USA.
+ */
+
+#ifndef __GTK_ACCESSIBLE_H__
+#define __GTK_ACCESSIBLE_H__
+
+#include <atk/atk.h>
+
+
+#ifdef __cplusplus
+extern "C" {
+#endif /* __cplusplus */
+
+#define GTK_TYPE_ACCESSIBLE                  (gtk_accessible_get_type ())
+#define GTK_ACCESSIBLE(obj)                  (GTK_CHECK_CAST ((obj), GTK_TYPE_ACCESSIBLE, GtkAccessible))
+#define GTK_ACCESSIBLE_CLASS(klass)          (GTK_CHECK_CLASS_CAST ((klass), GTK_TYPE_ACCESSIBLE, GtkAccessibleClass))
+#define GTK_IS_ACCESSIBLE(obj)               (GTK_CHECK_TYPE ((obj), GTK_TYPE_ACCESSIBLE))
+#define GTK_IS_ACCESSIBLE_CLASS(klass)       (GTK_CHECK_CLASS_TYPE ((klass), GTK_TYPE_ACCESSIBLE))
+#define GTK_ACCESSIBLE_GET_CLASS(obj)        (GTK_CHECK_GET_CLASS ((obj), GTK_TYPE_ACCESSIBLE, GtkAccessibleClass))
+
+typedef struct _GtkAccessible                GtkAccessible;
+typedef struct _GtkAccessibleClass           GtkAccessibleClass;
+
+  /**
+   * This object is a thin wrapper, in the GTK+ namespace, for AtkObject
+   */
+
+struct _GtkAccessible
+{
+  AtkObject parent;
+
+  /*
+   * The GtkWidget whose properties and features are exported via this 
+   * accessible instance.
+   */
+  GtkWidget *widget;
+
+};
+
+GtkType gtk_accessible_get_type (void);
+
+struct _GtkAccessibleClass
+{
+  AtkObjectClass parent_class;
+
+  void (*connect_widget_destroyed)              (GtkAccessible     *accessible);
+};
+
+void gtk_accessible_connect_widget_destroyed    (GtkAccessible     *accessible);
+#ifdef __cplusplus
+}
+#endif /* __cplusplus */
+
+
+#endif /* __GTK_ACCESSIBLE_H__ */
+
+
index e5a2738a810d35f4db902edf0d1d38181d6c4ff9..8079611f84c8eecf108a7d9853d32f4e62d9ea4d 100644 (file)
@@ -44,7 +44,7 @@
 #include "gobject/gvaluecollector.h"
 #include "gdk/gdkkeysyms.h"
 #include "gtkintl.h"
-
+#include "gtkaccessible.h"
 
 #define WIDGET_CLASS(w)         GTK_WIDGET_GET_CLASS (w)
 #define        INIT_PATH_SIZE  (512)
@@ -203,7 +203,11 @@ static gboolean gtk_widget_real_mnemonic_activate  (GtkWidget *widget,
 static void             gtk_widget_aux_info_destroy (GtkWidgetAuxInfo *aux_info);
 
 static void  gtk_widget_do_uposition (GtkWidget *widget);
-     
+
+static AtkObject*        gtk_widget_real_get_accessible   (GtkWidget *widget);
+static void              gtk_widget_accessible_interface_init (AtkImplementorIface *iface);
+static AtkObject *       gtk_widget_ref_accessible (AtkImplementor *implementor);
+
 static gpointer         parent_class = NULL;
 static guint            widget_signals[LAST_SIGNAL] = { 0 };
 
@@ -226,6 +230,7 @@ static GQuark quark_shape_info = 0;
 static GQuark quark_colormap = 0;
 static GQuark quark_pango_context = 0;
 static GQuark quark_rc_style = 0;
+static GQuark quark_accessible_object = 0;
 
 
 /*****************************************
@@ -255,7 +260,19 @@ gtk_widget_get_type (void)
        (GtkClassInitFunc) NULL,
       };
       
+      static const GInterfaceInfo accessibility_info =
+      {
+        (GInterfaceInitFunc) gtk_widget_accessible_interface_init,
+        (GInterfaceFinalizeFunc) NULL,
+        NULL /* interface data */
+      };
+
       widget_type = gtk_type_unique (GTK_TYPE_OBJECT, &widget_info);
+
+      g_type_add_interface_static (widget_type, ATK_TYPE_IMPLEMENTOR,
+                                   &accessibility_info) ;
+
     }
   
   return widget_type;
@@ -337,6 +354,9 @@ gtk_widget_class_init (GtkWidgetClass *klass)
   klass->drag_drop = NULL;
   klass->drag_data_received = NULL;
 
+  /* Accessibility support */
+  klass->get_accessible = gtk_widget_real_get_accessible;
+
   klass->no_expose_event = NULL;
 
   quark_property_parser = g_quark_from_static_string ("gtk-rc-property-parser");
@@ -349,6 +369,7 @@ gtk_widget_class_init (GtkWidgetClass *klass)
   quark_colormap = g_quark_from_static_string ("gtk-colormap");
   quark_pango_context = g_quark_from_static_string ("gtk-pango-context");
   quark_rc_style = g_quark_from_static_string ("gtk-rc-style");
+  quark_accessible_object = g_quark_from_static_string ("gtk-accessible-object");
 
   style_property_spec_pool = g_param_spec_pool_new (FALSE);
 
@@ -4954,6 +4975,7 @@ gtk_widget_finalize (GObject *object)
   gint *events;
   GdkExtensionMode *mode;
   GtkStyle *saved_style;
+  GtkAccessible *accessible;
   
   gtk_grab_remove (widget);
   gtk_selection_remove_all (widget);
@@ -4983,6 +5005,10 @@ gtk_widget_finalize (GObject *object)
   if (mode)
     g_free (mode);
 
+  accessible = gtk_object_get_data_by_id (GTK_OBJECT (widget), quark_accessible_object);
+  if (accessible)
+    g_object_unref (G_OBJECT (accessible));
+
   G_OBJECT_CLASS (parent_class)->finalize (object);
 }
 
@@ -5684,3 +5710,61 @@ gtk_requisition_free (GtkRequisition *requisition)
   g_free (requisition);
 }
 
+AtkObject* gtk_widget_get_accessible (GtkWidget *widget)
+{
+  GtkWidgetClass *klass;
+
+  g_return_val_if_fail (widget != NULL, NULL);
+  g_return_val_if_fail (GTK_IS_WIDGET (widget), NULL);
+
+  klass = GTK_WIDGET_GET_CLASS (widget);
+
+  g_return_val_if_fail (klass->get_accessible != NULL, NULL);
+
+  return klass->get_accessible(widget);
+}
+
+AtkObject* gtk_widget_real_get_accessible (GtkWidget *widget)
+{
+  AtkObject* accessible;
+
+  accessible = g_object_get_qdata (G_OBJECT (widget), 
+                                   quark_accessible_object);
+  if (!accessible)
+  {
+    AtkObjectFactory *factory;
+    AtkRegistry *default_registry;
+
+    default_registry = atk_get_default_registry ();
+    factory = atk_registry_get_factory (default_registry, 
+                                        GTK_OBJECT_TYPE (widget));
+    accessible =
+      atk_object_factory_create_accessible (factory,
+                                               G_OBJECT(widget));
+    g_object_set_qdata (G_OBJECT (widget), 
+                        quark_accessible_object,
+                        accessible);
+  }
+  return accessible;
+}
+
+/*
+ * Initialize a AtkImplementorIface instance's virtual pointers as
+ * appropriate to this implementor's class (GtkWidget).
+ */
+static void
+gtk_widget_accessible_interface_init (AtkImplementorIface *iface)
+{
+  iface->ref_accessible = gtk_widget_ref_accessible;
+}
+
+static AtkObject*
+gtk_widget_ref_accessible(AtkImplementor *implementor)
+{
+  AtkObject *accessible;
+
+  accessible = gtk_widget_get_accessible (GTK_WIDGET (implementor));
+  if (accessible)
+    g_object_ref (G_OBJECT (accessible));
+  return accessible;
+}
index 64ba08553a0f7cbaba2afed8efa36d0809ec3a1c..8bdc5d17be66360a59d4687652f61970e17661d2 100644 (file)
@@ -32,7 +32,7 @@
 #include <gtk/gtkobject.h>
 #include <gtk/gtkadjustment.h>
 #include <gtk/gtkstyle.h>
-
+#include <atk/atkobject.h>
 
 #ifdef __cplusplus
 extern "C" {
@@ -235,7 +235,7 @@ struct _GtkWidgetClass
    * Implementation of this signal is optional.
    */
   guint set_scroll_adjustments_signal;
-  
+
   /* basics */
   void (* show)                       (GtkWidget        *widget);
   void (* show_all)            (GtkWidget        *widget);
@@ -381,6 +381,11 @@ struct _GtkWidgetClass
   /* Signals used only for keybindings */
   void (* popup_menu)              (GtkWidget          *widget);
   
+  
+  /* accessibility support 
+   */
+  AtkObject*   (* get_accessible)  (GtkWidget          *widget);
+
   /* Padding for future expansion */
   GtkFunction pad1;
   GtkFunction pad2;
@@ -536,6 +541,10 @@ GtkWidget*   gtk_widget_get_ancestor       (GtkWidget      *widget,
 GdkColormap* gtk_widget_get_colormap   (GtkWidget      *widget);
 GdkVisual*   gtk_widget_get_visual     (GtkWidget      *widget);
 
+
+/* Accessibility support */
+AtkObject*       gtk_widget_get_accessible               (GtkWidget          *widget);
+
 /* The following functions must not be called on an already
  * realized widget. Because it is possible that somebody
  * can call get_colormap() or get_visual() and save the
index 9d3b59aa7567217c8a5de87527be0d294566fdc9..c7c71eec341dd15b05bdaed15a4bb1ae18e8fe36 100644 (file)
@@ -8,9 +8,7 @@ INCLUDES = @STRIP_BEGIN@ \
        -DGTK_LOCALEDIR=\"$(gtklocaledir)\"             \
        @GTK_DEBUG_FLAGS@                               \
        @GTK_XIM_FLAGS@                                 \
-       @PANGO_CFLAGS@                                  \
-       @GLIB_CFLAGS@                                   \
-       @more_cflags@                                   \
+       @GTK_DEP_CFLAGS@                                \
 @STRIP_END@
 
 DEPS = \
@@ -22,13 +20,7 @@ LDADDS = @STRIP_BEGIN@                                       \
        $(top_builddir)/gdk-pixbuf/libgdk_pixbuf-1.3.la \
        $(top_builddir)/gdk/@gdktargetlib@              \
        $(top_builddir)/gtk/@gtktargetlib@              \
-       @more_ldflags@                                  \
-       @more_libs@                                     \
-       @GDK_WLIBS@                                     \
-       @PANGO_LIBS@                                    \
-       @GLIB_LIBS@                                     \
-       @GTK_LIBS_EXTRA@                                \
-       -lm                                             \
+       @GTK_DEP_LIBS@                                  \
 @STRIP_END@
 
 moduledir = $(libdir)/gtk-2.0/$(GTK_VERSION)/immodules
index 2e7d20778f539245647fa52f94e7ccf2ef8a135b..e8b3f9a60cafba41d745a41986526015dcfea56c 100644 (file)
@@ -5,10 +5,7 @@ INCLUDES = @STRIP_BEGIN@ \
        -I$(top_builddir)/gdk                           \
        -DGTK_DISABLE_COMPAT_H                          \
        @GTK_DEBUG_FLAGS@                               \
-       @GTK_XIM_FLAGS@                                 \
-       @PANGO_CFLAGS@                                  \
-       @GLIB_CFLAGS@                                   \
-       @more_cflags@                                   \
+       @GTK_DEP_CFLAGS@                                \
 @STRIP_END@
 
 DEPS = \
@@ -20,13 +17,6 @@ LDADDS = @STRIP_BEGIN@                                       \
        $(top_builddir)/gdk-pixbuf/libgdk_pixbuf-1.3.la \
        $(top_builddir)/gdk/@gdktargetlib@              \
        $(top_builddir)/gtk/@gtktargetlib@              \
-       @more_ldflags@                                  \
-       @more_libs@                                     \
-       @GDK_WLIBS@                                     \
-       @PANGO_LIBS@                                    \
-       @GLIB_LIBS@                                     \
-       @GTK_LIBS_EXTRA@                                \
-       -lm                                             \
 @STRIP_END@
 
 if USE_X11