libtool installs/uninstalls the import library, no need to do it
[platform/upstream/glib.git] / glib / Makefile.am
index c959c43..ad051b0 100644 (file)
@@ -1,65 +1,93 @@
 ## Process this file with automake to produce Makefile.in
 
-AUTOMAKE_OPTIONS = 1.4
+if HAVE_GOOD_PRINTF
+else
+PRINTF_SUBDIR = gnulib
+printf_la = gnulib/libgnulib.la
+endif 
 
-SUBDIRS = . m4macros gobject gmodule gthread docs tests build
+SUBDIRS = libcharset $(PRINTF_SUBDIR)
 
-INCLUDES = -DG_LOG_DOMAIN=g_log_domain_glib @GLIB_DEBUG_FLAGS@ \
-       -DG_DISABLE_DEPRECATED -DGLIB_COMPILATION
+DIST_SUBDIRS = libcharset gnulib
+
+INCLUDES = -I$(top_srcdir) -DG_LOG_DOMAIN=\"GLib\" \
+       $(GLIB_DEBUG_FLAGS) -DG_DISABLE_DEPRECATED -DGLIB_COMPILATION 
+
+glib.def: glib.symbols
+       (echo -e EXPORTS; $(CPP) -P -DINCLUDE_VARIABLES -DINCLUDE_INTERNAL_SYMBOLS -DG_OS_WIN32 -DALL_FILES - <$(srcdir)/glib.symbols | sed -e '/^$$/d' -e 's/^/        /' -e 's/G_GNUC_[^ ]*//g') > glib.def
+
+galias.h: glib.symbols
+         $(PERL) $(srcdir)/makegalias.pl < $(srcdir)/glib.symbols > galias.h
+
+galiasdef.c: glib.symbols
+         $(PERL) $(srcdir)/makegalias.pl -def < $(srcdir)/glib.symbols > galiasdef.c
+
+if OS_LINUX
+if HAVE_GNUC_VISIBILITY
+TESTS = abicheck.sh
+endif
+endif
+
+BUILT_SOURCES = galias.h galiasdef.c
 
 EXTRA_DIST =                   \
-       ChangeLog.pre-1-2       \
-       glib.spec.in            \
-       NEWS.pre-1-3            \
-       acglib.m4               \
-       sanity_check            \
-       README.win32            \
-       TODO.xml                \
-       glib.def                \
        makefile.msc.in         \
-       makefile.mingw.in       \
-       glibconfig.h.win32.in   \
-       config.h.win32.in       \
-       build-dll               \
        glib.rc.in              \
-       glib-2.0.pc.in          \
-       gobject-2.0.pc.in       \
-       gmodule-2.0.pc.in       \
-       gthread-2.0.pc.in       \
-       gen-unicode-tables.pl
+       gen-unicode-tables.pl   \
+       makegalias.pl           \
+       abicheck.sh             \
+       glib.symbols
 
 # These may be in the builddir too
 BUILT_EXTRA_DIST =             \
        makefile.msc            \
-       makefile.mingw          \
-       glibconfig.h.win32      \
-       config.h.win32          \
        glib.rc                 \
-       glib.spec
+       galias.h                \
+       galiasdef.c
+
+lib_LTLIBRARIES = libglib-2.0.la
+
+if MS_LIB_AVAILABLE
+noinst_DATA = glib-2.0.lib
 
-lib_LTLIBRARIES = libglib-1.3.la
+install-ms-lib:
+       $(INSTALL) glib-2.0.lib $(DESTDIR)$(libdir)
 
-libglib_1_3_la_SOURCES =       \
+uninstall-ms-lib:
+       -rm $(DESTDIR)$(libdir)/glib-2.0.lib
+else
+install-ms-lib:
+uninstall-ms-lib:
+endif
+
+libglib_2_0_la_SOURCES =       \
        garray.c                \
        gasyncqueue.c           \
+       gatomic.c               \
        gbacktrace.c            \
+       gbsearcharray.h         \
        gcache.c                \
        gcompletion.c           \
        gconvert.c              \
        gdataset.c              \
+       gdatasetprivate.h       \
        gdate.c                 \
+       gdir.c                  \
        gerror.c                \
        gfileutils.c            \
        ghash.c                 \
        ghook.c                 \
        giochannel.c            \
+       gkeyfile.c              \
        glibintl.h              \
        glist.c                 \
        gmain.c                 \
+       gmappedfile.c           \
        gmarkup.c               \
        gmem.c                  \
        gmessages.c             \
        gnode.c                 \
+       goption.c               \
        gpattern.c              \
        gprimes.c               \
        gqsort.c                \
@@ -69,9 +97,11 @@ libglib_1_3_la_SOURCES =     \
        gscanner.c              \
        gshell.c                \
        gslist.c                \
+       gstdio.c                \
        gstrfuncs.c             \
        gstring.c               \
        gthread.c               \
+       gthreadinit.h           \
        gthreadpool.c           \
        gtimer.c                \
        gtree.c                 \
@@ -80,11 +110,17 @@ libglib_1_3_la_SOURCES =   \
        gunibreak.h             \
        gunibreak.c             \
        gunichartables.h        \
+       gunicollate.c           \
+       gunicomp.h              \
        gunidecomp.h            \
        gunidecomp.c            \
-       gutils.c
+       gunicodeprivate.h       \
+       gutils.c                \
+       gdebug.h                \
+       gprintf.c               \
+       gprintfint.h
 
-EXTRA_libglib_1_3_la_SOURCES = \
+EXTRA_libglib_2_0_la_SOURCES = \
        giounix.c       \
        giowin32.c      \
        gspawn.c        \
@@ -93,29 +129,39 @@ EXTRA_libglib_1_3_la_SOURCES = \
 
 glibincludedir=$(includedir)/glib-2.0
 glibinclude_HEADERS =   \
+       glib-object.h   \
+       glib.h
+
+glibsubincludedir=$(includedir)/glib-2.0/glib
+glibsubinclude_HEADERS =   \
        galloca.h       \
        garray.h        \
        gasyncqueue.h   \
+       gatomic.h       \
        gbacktrace.h    \
        gcache.h        \
        gcompletion.h   \
        gconvert.h      \
        gdataset.h      \
        gdate.h         \
+       gdir.h          \
        gerror.h        \
        gfileutils.h    \
        ghash.h         \
        ghook.h         \
+       gi18n.h         \
+       gi18n-lib.h     \
        giochannel.h    \
-       glib.h          \
-       glib-object.h   \
+       gkeyfile.h      \
        glist.h         \
        gmacros.h       \
        gmain.h         \
+       gmappedfile.h   \
        gmarkup.h       \
        gmem.h          \
        gmessages.h     \
        gnode.h         \
+       goption.h       \
        gpattern.h      \
        gprimes.h       \
        gqsort.h        \
@@ -127,6 +173,7 @@ glibinclude_HEADERS =   \
        gshell.h        \
        gslist.h        \
        gspawn.h        \
+       gstdio.h        \
        gstrfuncs.h     \
        gstring.h       \
        gthread.h       \
@@ -136,104 +183,59 @@ glibinclude_HEADERS =   \
        gtypes.h        \
        gunicode.h      \
        gutils.h        \
-       gwin32.h
+       gwin32.h        \
+       gprintf.h
 
-configexecincludedir = $(libdir)/glib-2.0/include
-#configexecinclude_DATA = glibconfig.h
-
-install-exec-local: glibconfig.h
-       $(mkinstalldirs) $(DESTDIR)$(configexecincludedir)
-       file=$(DESTDIR)$(configexecincludedir)/glibconfig.h; \
-       if test -r $$file && cmp -s glibconfig.h $$file; then :; \
-       else $(INSTALL_DATA) glibconfig.h $$file; fi
-
-CONFIGURE_DEPENDENCIES = acglib.m4
-
-BUILT_SOURCES = stamp-gc-h #note: not glibconfig.h
-glibconfig.h: stamp-gc-h
-       @if test -f glibconfig.h; then :; \
-       else rm -f stamp-gc-h; $(MAKE) stamp-gc-h; fi
-stamp-gc-h: config.status
-       CONFIG_FILES= CONFIG_HEADERS= CONFIG_OTHER=glibconfig.h ./config.status
-       echo timestamp > stamp-gc-h
-
-libglib_1_3_la_LIBADD = @GIO@ @GSPAWN@ @PLATFORMDEP@ @ICONV_LIBS@ @G_LIBS_EXTRA@
-libglib_1_3_la_DEPENDENCIES = @GIO@ @GSPAWN@ @PLATFORMDEP@ 
+install-data-local: install-ms-lib install-def-file
+       @if test -f $(glibincludedir)/glist.h ; then                                    \
+         echo "*** Old headers found in $(glibincludedir). You should remove the" ;    \
+         echo "*** contents of this directory and type 'make install' again." ;        \
+         false ;                                                                       \
+        fi
 
+uninstall-local: uninstall-ms-lib uninstall-def-file
 
 if PLATFORM_WIN32
 no_undefined = -no-undefined
 endif
+
 if OS_WIN32
 # This requires a very new libtool
 export_symbols = -export-symbols glib.def
+
+install-def-file:
+       $(INSTALL) glib.def $(DESTDIR)$(libdir)/glib-2.0.def
+
+uninstall-def-file:
+       -rm $(DESTDIR)$(libdir)/glib-2.0.def
+else
+install-def-file:
+uninstall-def-file:
+
+export_symbols = $(LIBTOOL_EXPORT_OPTIONS)
 endif
 
-libglib_1_3_la_LDFLAGS = \
+libglib_2_0_la_LIBADD = libcharset/libcharset.la $(printf_la) @GIO@ @GSPAWN@ @PLATFORMDEP@ @G_LIB_WIN32_RESOURCE@ @ICONV_LIBS@ @G_LIBS_EXTRA@ 
+libglib_2_0_la_DEPENDENCIES = libcharset/libcharset.la $(printf_la) @GIO@ @GSPAWN@ @PLATFORMDEP@ @G_LIB_WIN32_RESOURCE@ @GLIB_DEF@
+
+libglib_2_0_la_LDFLAGS = \
        -version-info $(LT_CURRENT):$(LT_REVISION):$(LT_AGE) \
        -export-dynamic $(no_undefined) $(export_symbols)
 
 if OS_WIN32
 bin_PROGRAMS = gspawn-win32-helper
-gspawn_win32_helper_LDADD = libglib-1.3.la
-endif
-if ENABLE_TIMELOOP
-timeloop = timeloop
-endif
-noinst_PROGRAMS = testglib testgdate testgdateparser $(timeloop)
-testglib_LDADD = libglib-1.3.la
-testgdate_LDADD = libglib-1.3.la
-testgdateparser_LDADD = libglib-1.3.la
-if ENABLE_TIMELOOP
-timeloop_LDADD = libglib-1.3.la
-endif
-
-pkgconfigdir = $(libdir)/pkgconfig
-pkgconfig_DATA = glib-2.0.pc gobject-2.0.pc gmodule-2.0.pc gthread-2.0.pc
-
-glibconfig.h.win32: $(top_builddir)/config.status $(top_srcdir)/glibconfig.h.win32.in
-       cd $(top_builddir) && CONFIG_FILES=$@ CONFIG_HEADERS= $(SHELL) ./config.status
-
-config.h.win32: $(top_builddir)/config.status $(top_srcdir)/config.h.win32.in
-       cd $(top_builddir) && CONFIG_FILES=$@ CONFIG_HEADERS= $(SHELL) ./config.status
+gspawn_win32_helper_LDADD = libglib-2.0.la
+gspawn_win32_helper_LDFLAGS = -mwindows
 
-makefile.msc: $(top_builddir)/config.status $(top_srcdir)/makefile.msc.in
-       cd $(top_builddir) && CONFIG_FILES=$@ CONFIG_HEADERS= $(SHELL) ./config.status
-
-makefile.mingw: $(top_builddir)/config.status $(top_srcdir)/makefile.mingw.in
-       cd $(top_builddir) && CONFIG_FILES=$@ CONFIG_HEADERS= $(SHELL) ./config.status
-
-glib.rc: $(top_builddir)/config.status $(top_srcdir)/glib.rc.in
-       cd $(top_builddir) && CONFIG_FILES=$@ CONFIG_HEADERS= $(SHELL) ./config.status
-
-bin_SCRIPTS=glib-config-2.0
-BUILT_SOURCES=glib-config-2.0
-glib-config-2.0: glib-config-2.0.in
-
-.PHONY: files release sanity snapshot
-
-files:
-       @files=`ls $(DISTFILES) 2> /dev/null `; for p in $$files; do \
-         echo $$p; \
-       done
-
-release:
-       rm -rf .deps */.deps
-       cd docs && make glib.html
-       $(MAKE) distcheck
-
-sanity:
-       ./sanity_check $(VERSION)
-
-snapshot:
-       $(MAKE) dist distdir=$(PACKAGE)-snap`date +"%Y%m%d"`
+$(G_LIB_WIN32_RESOURCE): glib.rc
+       $(top_srcdir)/build/win32/lt-compile-resource glib.rc $@
+endif
 
-snapcheck:
-       $(MAKE) distcheck distdir=$(PACKAGE)-snap`date +"%Y%m%d"`
+glib-2.0.lib: libglib-2.0.la glib.def
+       lib -name:libglib-2.0-$(LT_CURRENT_MINUS_AGE).dll -def:glib.def -out:$@
 
 dist-hook: $(BUILT_EXTRA_DIST)
-       cd $(top_builddir) && CONFIG_FILES="INSTALL README" CONFIG_HEADERS= $(SHELL) ./config.status
-       files='$(BUILT_EXTRA_DIST)' INSTALL README; \
+       files='$(BUILT_EXTRA_DIST)'; \
        for f in $$files; do \
          if test -f $$f; then d=.; else d=$(srcdir); fi; \
-         rm -f $(distdir)/$$f && cp $$d/$$f $(distdir) || exit 1; done
+         cp $$d/$$f $(distdir) || exit 1; done