]> Pileus Git - ~andy/gtk/blobdiff - gdk/Makefile.am
Merge libgdk and libgtk
[~andy/gtk] / gdk / Makefile.am
index aeba1389ceebbca55324306d7d17a6e163eb294f..801719d9ac4d12b12c89edf90f58929b146b2b20 100644 (file)
@@ -1,8 +1,17 @@
 ## Makefile.am for gtk+/gdk
 include $(top_srcdir)/Makefile.decl
+-include $(INTROSPECTION_MAKEFILE)
+INTROSPECTION_GIRS =
+INTROSPECTION_SCANNER_ARGS = \
+   --add-include-path=../gdk
+INTROSPECTION_COMPILER_ARGS = \
+   --includedir=$(srcdir) \
+   --includedir=.
 
-SUBDIRS = $(gdktarget)
-DIST_SUBDIRS = win32 x11 quartz directfb
+SUBDIRS = $(gdktarget) . tests
+DIST_SUBDIRS = win32 x11 quartz tests
+
+CLEANFILES =
 
 EXTRA_DIST +=                  \
        keynames.txt            \
@@ -12,24 +21,19 @@ EXTRA_DIST +=                       \
        gdkkeysyms-update.pl    \
        gdk.def                 \
        gdkmarshalers.list      \
-       gdkmedialib.h           \
+       gdkwindowimpl.h         \
        makeenums.pl            \
        makefile.msc            \
        gdk.symbols             \
-       makegdkalias.pl         \
-       gdkaliasdef.c           \
        gdkenumtypes.c.template \
        gdkenumtypes.h.template \
-       abicheck.sh             \
-       pltcheck.sh
+       abicheck.sh
 
 INCLUDES =                              \
        -DG_LOG_DOMAIN=\"Gdk\"          \
        -DGDK_COMPILATION               \
        -I$(top_srcdir)                 \
        -I$(top_builddir)/gdk           \
-       -I$(top_srcdir)/gdk-pixbuf      \
-       -DGDK_PIXBUF_DISABLE_DEPRECATED \
        $(GTK_DEBUG_FLAGS)              \
        $(GDK_DEP_CFLAGS)
 
@@ -43,19 +47,13 @@ endif
 # since automake doesn't support conditionalized libsomething_la_LDFLAGS
 # we use the general approach here
 LDADD = \
+       $(GTK_LINK_FLAGS)                                               \
        -version-info $(LT_VERSION_INFO)                                \
        -export-dynamic                                                 \
        -rpath $(libdir)                                                \
        $(no_undefined)                                                 \
        $(LIBTOOL_EXPORT_OPTIONS)
 
-if USE_MEDIALIB
-medialib_sources =  \
-    gdkmedialib.c
-else
-medialib_sources =
-endif
-
 #
 # setup source file variables
 #
@@ -64,114 +62,187 @@ endif
 #
 gdk_public_h_sources =                         \
        gdk.h                                   \
+       gdkapplaunchcontext.h                   \
        gdkcairo.h                              \
        gdkcolor.h                              \
        gdkcursor.h                             \
+       gdkdevice.h                             \
+       gdkdevicemanager.h                      \
        gdkdisplay.h                            \
+       gdkdisplaymanager.h                     \
        gdkdnd.h                                \
-       gdkdrawable.h                           \
        gdkevents.h                             \
-       gdkfont.h                               \
-       gdkgc.h                                 \
-       gdkkeysyms.h                            \
-       gdki18n.h                               \
-       gdkimage.h                              \
-       gdkinput.h                              \
        gdkkeys.h                               \
-       gdkdisplaymanager.h                     \
+       gdkkeysyms.h                            \
+       gdkkeysyms-compat.h                     \
+       gdkmain.h                               \
        gdkpango.h                              \
        gdkpixbuf.h                             \
-       gdkpixmap.h                             \
+       gdkprivate.h                            \
        gdkproperty.h                           \
-       gdkregion.h                             \
-       gdkrgb.h                                \
+       gdkrectangle.h                          \
+       gdkrgba.h                               \
        gdkscreen.h                             \
        gdkselection.h                          \
        gdkspawn.h                              \
        gdktestutils.h                          \
+       gdkthreads.h                            \
        gdktypes.h                              \
        gdkvisual.h                             \
        gdkwindow.h
 
-gdk_headers =                     \
-       $(gdk_public_h_sources)   \
-       gdkenumtypes.h            \
-       gdkprivate.h              \
-       gdkalias.h
+gdk_built_public_sources =                     \
+       gdkconfig.h                             \
+       gdkenumtypes.h
+
+gdk_private_headers =                          \
+       gdkinternals.h                          \
+       gdkdeviceprivate.h                      \
+       gdkintl.h
 
 gdk_c_sources =                 \
-       $(medialib_sources)     \
        gdk.c                   \
+       gdkapplaunchcontext.c   \
        gdkcairo.c              \
        gdkcolor.c              \
        gdkcursor.c             \
+       gdkdevice.c             \
+       gdkdevicemanager.c      \
        gdkdisplay.c            \
+       gdkdisplaymanager.c     \
        gdkdnd.c                \
-       gdkdraw.c               \
        gdkevents.c             \
-       gdkfont.c               \
-       gdkgc.c                 \
        gdkglobals.c            \
        gdkkeys.c               \
        gdkkeyuni.c             \
-       gdkimage.c              \
-       gdkinternals.h          \
-       gdkintl.h               \
-       gdkdisplaymanager.c     \
+       gdkoffscreenwindow.c    \
        gdkpango.c              \
        gdkpixbuf-drawable.c    \
-       gdkpixbuf-render.c      \
-       gdkpixmap.c             \
-       gdkpoly-generic.h       \
-       gdkpolyreg-generic.c    \
-       gdkrgb.c                \
        gdkrectangle.c          \
-       gdkregion-generic.c     \
-       gdkregion-generic.h     \
+       gdkrgba.c               \
        gdkscreen.c             \
        gdkselection.c          \
        gdkvisual.c             \
-       gdkwindow.c
+       gdkwindow.c             \
+       gdkwindowimpl.c
+
+gdk_built_sources =                            \
+       gdkenumtypes.c                          \
+       gdkmarshalers.h                         \
+       gdkmarshalers.c                         \
+       $(gdk_built_public_sources)
 
 #
 # setup GDK sources and their dependencies
 #
 
-gdkincludedir = $(includedir)/gtk-2.0/gdk
-gdkinclude_HEADERS = $(gdk_headers)
+gdkincludedir = $(includedir)/gtk-3.0/gdk
+gdkinclude_HEADERS = $(gdk_public_h_sources) $(gdk_built_public_sources)
 
-# gdkmarshalers.c is not here because it is currently an empty file
-common_sources =                \
+common_sources =               \
+       $(gdk_private_headers)  \
        $(gdk_c_sources)        \
        gdkenumtypes.c          \
+       gdkmarshalers.c         \
        gdkmarshalers.h
 
-libgdk_directfb_2_0_la_SOURCES = $(common_sources) 
-libgdk_directfb_2_0_la_LIBADD = directfb/libgdk-directfb.la $(GDK_DEP_LIBS) \
-  $(top_builddir)/gdk-pixbuf/libgdk_pixbuf-$(GTK_API_VERSION).la
-libgdk_directfb_2_0_la_LDFLAGS = $(LDADD)
+libgdk_3_0_la_SOURCES = $(common_sources)
+libgdk_3_0_la_LIBADD = x11/libgdk-x11.la $(GDK_DEP_LIBS)
+libgdk_3_0_la_LDFLAGS = $(LDADD)
+
+libgdk_x11_3_0_la_SOURCES = $(common_sources)
+libgdk_x11_3_0_la_LIBADD = x11/libgdk-x11.la $(GDK_DEP_LIBS)
+libgdk_x11_3_0_la_LDFLAGS = $(LDADD)
 
-libgdk_x11_2_0_la_SOURCES = $(common_sources)
-libgdk_x11_2_0_la_LIBADD = x11/libgdk-x11.la $(GDK_DEP_LIBS) \
-  $(top_builddir)/gdk-pixbuf/libgdk_pixbuf-$(GTK_API_VERSION).la
-libgdk_x11_2_0_la_LDFLAGS = $(LDADD)
+libgdk_quartz_3_0_la_SOURCES = $(common_sources) gdkkeynames.c
+libgdk_quartz_3_0_la_LIBADD = quartz/libgdk-quartz.la $(GDK_DEP_LIBS)
+libgdk_quartz_3_0_la_LDFLAGS = $(LDADD)
 
-libgdk_quartz_2_0_la_SOURCES = $(common_sources) gdkkeynames.c
-libgdk_quartz_2_0_la_LIBADD = quartz/libgdk-quartz.la $(GDK_DEP_LIBS) \
-  $(top_builddir)/gdk-pixbuf/libgdk_pixbuf-$(GTK_API_VERSION).la
-libgdk_quartz_2_0_la_LDFLAGS = $(LDADD)
+libgdk_win32_3_0_la_SOURCES = $(common_sources) gdkkeynames.c
+libgdk_win32_3_0_la_LIBADD = win32/libgdk-win32.la $(GDK_DEP_LIBS)
+libgdk_win32_3_0_la_DEPENDENCIES = win32/libgdk-win32.la win32/rc/gdk-win32-res.o gdk.def
+libgdk_win32_3_0_la_LDFLAGS = -Wl,win32/rc/gdk-win32-res.o -export-symbols $(srcdir)/gdk.def $(LDADD)
 
-libgdk_win32_2_0_la_SOURCES = $(common_sources) gdkkeynames.c
-libgdk_win32_2_0_la_LIBADD = win32/libgdk-win32.la $(GDK_DEP_LIBS) \
-  $(top_builddir)/gdk-pixbuf/libgdk_pixbuf-$(GTK_API_VERSION).la
-libgdk_win32_2_0_la_DEPENDENCIES = win32/libgdk-win32.la win32/rc/gdk-win32-res.o gdk.def
-libgdk_win32_2_0_la_LDFLAGS = -Wl,win32/rc/gdk-win32-res.o -export-symbols gdk.def $(LDADD)
+if HAVE_INTROSPECTION
+
+introspection_files =          \
+       $(filter-out gdkkeysyms-compat.h, $(gdk_public_h_sources))      \
+       $(gdk_c_sources)        \
+        gdkenumtypes.c         \
+        gdkenumtypes.h
+
+Gdk-3.0.gir: libgdk-3.0.la Makefile
+Gdk_3_0_gir_SCANNERFLAGS = --warn-all
+Gdk_3_0_gir_INCLUDES = Gio-2.0 GdkPixbuf-2.0 Pango-1.0 cairo-1.0
+Gdk_3_0_gir_LIBS = libgdk-3.0.la
+Gdk_3_0_gir_FILES = $(introspection_files)
+Gdk_3_0_gir_CFLAGS = $(INCLUDES)
+INTROSPECTION_GIRS += Gdk-3.0.gir
+
+if USE_X11
+x11_introspection_files =              \
+       x11/checksettings.c             \
+       x11/gdkapplaunchcontext-x11.c   \
+       x11/gdkasync.c                  \
+       x11/gdkcursor-x11.c             \
+       x11/gdkdevice-core.c            \
+       x11/gdkdevicemanager-core.c     \
+       x11/gdkdevicemanager-x11.c      \
+       x11/gdkdevicemanager-xi2.c      \
+       x11/gdkdevicemanager-xi.c       \
+       x11/gdkdevice-xi2.c             \
+       x11/gdkdevice-xi.c              \
+       x11/gdkdisplay-x11.c            \
+       x11/gdkdnd-x11.c                \
+       x11/gdkeventsource.c            \
+       x11/gdkeventtranslator.c        \
+       x11/gdkgeometry-x11.c           \
+       x11/gdkglobals-x11.c            \
+       x11/gdkim-x11.c                 \
+       x11/gdkkeys-x11.c               \
+       x11/gdkmain-x11.c               \
+       x11/gdkproperty-x11.c           \
+       x11/gdkscreen-x11.c             \
+       x11/gdkselection-x11.c          \
+       x11/gdksettings.c               \
+       x11/gdkspawn-x11.c              \
+       x11/gdktestutils-x11.c          \
+       x11/gdkvisual-x11.c             \
+       x11/gdkwindow-x11.c             \
+       x11/gdkxftdefaults.c            \
+       x11/gdkxid.c                    \
+       x11/xsettings-client.c          \
+       x11/xsettings-common.c          \
+        x11/gdkx.h
+
+GdkX11-3.0.gir: libgdk-3.0.la Gdk-3.0.gir Makefile
+GdkX11_3_0_gir_SCANNERFLAGS = --warn-all --strip-prefix=Gdk
+GdkX11_3_0_gir_INCLUDES = Gio-2.0 Gdk-3.0 GdkPixbuf-2.0 Pango-1.0 xlib-2.0
+GdkX11_3_0_gir_LIBS = libgdk-3.0.la
+GdkX11_3_0_gir_FILES = $(x11_introspection_files)
+GdkX11_3_0_gir_CFLAGS = $(INCLUDES) -L$(top_builddir)/gdk
+INTROSPECTION_GIRS += GdkX11-3.0.gir
+
+introspection_files += $(filter-out x11/gdkx.h, $(x11_introspection_files))
+
+endif # USE_X11
+
+girdir = $(datadir)/gir-1.0
+gir_DATA = $(INTROSPECTION_GIRS)
+
+typelibsdir = $(libdir)/girepository-1.0
+typelibs_DATA = $(INTROSPECTION_GIRS:.gir=.typelib)
+
+CLEANFILES += $(gir_DATA) $(typelibs_DATA)
+
+endif # HAVE_INTROSPECTION
 
 if OS_WIN32
 install-def-file: gdk.def
-       $(INSTALL) gdk.def $(DESTDIR)$(libdir)/gdk-win32-2.0.def
+       mkdir -p $(DESTDIR)$(libdir)
+       $(INSTALL) $(srcdir)/gdk.def $(DESTDIR)$(libdir)/gdk-win32-3.0.def
 uninstall-def-file:
-       -rm $(DESTDIR)$(libdir)/gdk-win32-2.0.def
+       -rm $(DESTDIR)$(libdir)/gdk-win32-3.0.def
 else
 install-def-file:
 uninstall-def-file:
@@ -181,9 +252,10 @@ if MS_LIB_AVAILABLE
 noinst_DATA = gdk-win32-$(GTK_API_VERSION).lib
 
 gdk-win32-$(GTK_API_VERSION).lib: libgdk-win32-$(GTK_API_VERSION).la gdk.def
-       lib -name:libgdk-win32-$(GTK_API_VERSION)-@LT_CURRENT_MINUS_AGE@.dll -def:gdk.def -out:$@
+       lib -machine:@LIB_EXE_MACHINE_FLAG@ -name:libgdk-win32-$(GTK_API_VERSION)-@LT_CURRENT_MINUS_AGE@.dll -def:gdk.def -out:$@
 
 install-ms-lib:
+       mkdir -p $(DESTDIR)$(libdir)
        $(INSTALL) gdk-win32-$(GTK_API_VERSION).lib $(DESTDIR)$(libdir)
 
 uninstall-ms-lib:
@@ -193,53 +265,31 @@ install-ms-lib:
 uninstall-ms-lib:
 endif
 
+# This places the generated .def file in srcdir, since it is expected to be there.
+# (The one from a tarball is)
 gdk.def: gdk.symbols
-       (echo -e EXPORTS; $(CPP) -P -DALL_FILES -DGDK_WINDOWING_WIN32 -DINCLUDE_VARIABLES - <$(srcdir)/gdk.symbols | sed -e '/^$$/d' -e 's/^/   /' -e 's/G_GNUC_[^ ]*//g') > gdk.def
-
-gdkalias.h: gdk.symbols
-        $(PERL) $(srcdir)/makegdkalias.pl < $(srcdir)/gdk.symbols > gdkalias.h
-
-gdkaliasdef.c: gdk.symbols
-        $(PERL) $(srcdir)/makegdkalias.pl -def < $(srcdir)/gdk.symbols > gdkaliasdef.c
+       (echo -e EXPORTS; $(CPP) -P -DGDK_WINDOWING_WIN32 - <$(srcdir)/gdk.symbols | sed -e '/^$$/d' -e 's/^/   /' -e 's/G_GNUC_[^ ]*//g') > $(srcdir)/gdk.def
 
+TESTS_ENVIRONMENT = srcdir="$(srcdir)"
 if OS_LINUX
-TESTS = abicheck.sh pltcheck.sh
+TESTS = abicheck.sh
 endif
 
 
-lib_LTLIBRARIES = $(gdktargetlib)
+noinst_LTLIBRARIES = libgdk-3.0.la
 
-EXTRA_LTLIBRARIES = libgdk-x11-2.0.la libgdk-win32-2.0.la libgdk-quartz-2.0.la libgdk-directfb-2.0.la
-
-MAINTAINERCLEANFILES = gdkenumtypes.h stamp-gdkenumtypes.h gdkenumtypes.c \
-  gdkmarshalers.h gdkmarshalers.c
+MAINTAINERCLEANFILES = $(gdk_built_sources) stamp-gdkenumtypes.h
+EXTRA_DIST += $(gdk_built_sources)
 EXTRA_HEADERS =
 
-#
-# Rule to install gdkconfig.h header file
-#
-configexecincludedir = $(libdir)/gtk-2.0/include
-#configexecinclude_DATA = gdkconfig.h
-
-install-exec-local: gdkconfig.h
-       $(mkinstalldirs) $(DESTDIR)$(configexecincludedir)
-       file=$(DESTDIR)$(configexecincludedir)/gdkconfig.h; \
-       if test -r $$file && cmp -s gdkconfig.h $$file; then :; \
-       else $(INSTALL_DATA) gdkconfig.h $$file; fi
-
 install-exec-hook:
 if DISABLE_EXPLICIT_DEPS
-       $(SHELL) $(top_srcdir)/sanitize-la.sh $(DESTDIR)$(libdir)/$(gdktargetlib)
+       $(SHELL) $(top_srcdir)/sanitize-la.sh $(DESTDIR)$(libdir)/libgdk-3.0.la
 endif
 
 #note: not gdkconfig.h
-BUILT_SOURCES =                                        \
-       gdkalias.h                              \
-       gdkaliasdef.c                           \
-       gdkenumtypes.h                          \
-       gdkenumtypes.c                          \
-       gdkmarshalers.h                         \
-       gdkmarshalers.c                         \
+BUILT_SOURCES = \
+       $(gdk_built_sources)                    \
        gdkconfig.h
 
 gdkenumtypes.h: stamp-gdkenumtypes.h
@@ -260,11 +310,11 @@ gdkenumtypes.c: @REBUILD@ $(gdk_public_h_sources) gdkenumtypes.c.template
 # Marshaller generation
 #
 gdkmarshalers.h: @REBUILD@ gdkmarshalers.list
-       $(GLIB_GENMARSHAL) --prefix=gdk_marshal $(srcdir)/gdkmarshalers.list --header > gdkmarshalers-h.tmp \
+       $(GLIB_GENMARSHAL) --prefix=_gdk_marshal $(srcdir)/gdkmarshalers.list --header > gdkmarshalers-h.tmp \
        && mv gdkmarshalers-h.tmp gdkmarshalers.h \
        || ( rm -f gdkmarshalers-h.tmp && exit 1)
 gdkmarshalers.c: @REBUILD@ gdkmarshalers.list
-       (echo "#include \"gdkalias.h\""; $(GLIB_GENMARSHAL) --prefix=gdk_marshal $(srcdir)/gdkmarshalers.list --body) > gdkmarshalers-c.tmp     \
+       $(GLIB_GENMARSHAL) --prefix=_gdk_marshal $(srcdir)/gdkmarshalers.list --body > gdkmarshalers-c.tmp      \
        && mv gdkmarshalers-c.tmp gdkmarshalers.c \
        || ( rm -f gdkmarshalers-c.tmp && exit 1 )
 
@@ -275,6 +325,18 @@ stamp-gc-h: $(top_builddir)/config.status
        cd $(top_builddir) && $(SHELL) ./config.status gdk/gdkconfig.h
        echo timestamp > stamp-gc-h
 
+dist-hook: ../build/win32/vs9/gdk.vcproj
+
+../build/win32/vs9/gdk.vcproj: ../build/win32/vs9/gdk.vcprojin
+       for F in $(libgdk_win32_3_0_la_SOURCES); do \
+               case $$F in \
+               *.c) echo '   <File RelativePath="..\..\..\gdk\'$$F'" />' \
+                    ;; \
+               esac; \
+       done >libgdk.sourcefiles
+       $(CPP) -P - <$(top_srcdir)/build/win32/vs9/gdk.vcprojin >$@
+       rm libgdk.sourcefiles
+
 DISTCLEANFILES = gdkconfig.h stamp-gc-h
 
 install-data-local: install-ms-lib install-def-file
@@ -295,3 +357,5 @@ files:
        @files=`ls $(DISTFILES) 2> /dev/null `; for p in $$files; do \
          echo $$p; \
        done
+
+-include $(top_srcdir)/git.mk