X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2FMakefile.am;h=ed7391369c518438765da9e723a80fec767d5abc;hb=2238bc8f821ef84c53dc823a67b4326b0b211da1;hp=bdbab1a4742ad0cf6e773cf7a74e434b591b76a0;hpb=7ee01a941c730ac09f1be55381ddc07dbea7ddc0;p=gnulib.git diff --git a/lib/Makefile.am b/lib/Makefile.am index bdbab1a47..ed7391369 100644 --- a/lib/Makefile.am +++ b/lib/Makefile.am @@ -4,42 +4,122 @@ AUTOMAKE_OPTIONS = ../src/ansi2knr noinst_LIBRARIES = libfetish.a -INCLUDES = -I.. -I$(srcdir) -I../intl +INCLUDES = -I.. -I$(srcdir) +DEFS = -DLIBDIR=\"$(libdir)\" @DEFS@ -libfetish_a_SOURCES = getdate.y posixtm.c \ -addext.c argmatch.c backupfile.c basename.c \ -closeout.c dirname.c exclude.c filemode.c \ -full-write.c getopt.c getopt1.c human.c idcache.c \ -isdir.c long-options.c makepath.c modechange.c hash.c path-concat.c \ -quotearg.c safe-read.c same.c save-cwd.c savedir.c stripslash.c userspec.c \ -version-etc.c xgetcwd.c xmalloc.c xstrdup.c \ -xstrtol.c xstrtoul.c xstrtoumax.c yesno.c +## Put relatively complex files at the beginning of the list so +## that parallel compiles finish a tiny bit sooner. I don't see +## a way to make regex.c appear earlier in the list, since it's +## added by automake, but on systems with an up to date GNU libc, +## regex.c isn't even compiled. +libfetish_a_SOURCES = \ + acl.h acl.c \ + getdate.h getdate.y \ + posixtm.c posixtm.h \ + posixver.c posixver.h \ + strftime.c \ + getopt.c getopt.h getopt1.c \ + hash.c hash.h \ + hash-pjw.c hash-pjw.h \ + __fpending.h \ + addext.c \ + argmatch.c argmatch.h \ + backupfile.c backupfile.h \ + basename.c \ + bumpalloc.h \ + canon-host.c \ + c-stack.c c-stack.h \ + closeout.c closeout.h \ + diacrit.c diacrit.h \ + dirname.c dirname.h \ + dirfd.h \ + dup-safer.c \ + exclude.c exclude.h \ + exitfail.c exitfail.h \ + filemode.c filemode.h \ + file-type.c file-type.h \ + fnmatch_.h \ + fopen-safer.c \ + fsusage.h \ + full-write.c full-write.h \ + getline.h \ + getpagesize.h \ + getstr.c getstr.h \ + gettime.c \ + gettext.h \ + getugroups.c \ + group-member.h \ + hard-locale.c hard-locale.h \ + human.c human.h \ + idcache.c \ + isdir.c \ + lchown.h \ + linebuffer.c linebuffer.h \ + localcharset.c \ + long-options.c long-options.h \ + makepath.c makepath.h \ + mbswidth.c mbswidth.h \ + md5.c md5.h \ + memcasecmp.c memcasecmp.h \ + memcoll.c memcoll.h \ + modechange.c modechange.h \ + mountlist.h \ + path-concat.c path-concat.h \ + pathmax.h \ + physmem.c physmem.h \ + quote.c quote.h \ + quotearg.c quotearg.h \ + readtokens.c readtokens.h \ + readutmp.h \ + regex.h \ + safe-read.c safe-read.h \ + same.c same.h \ + save-cwd.c save-cwd.h \ + savedir.c savedir.h \ + settime.c \ + sha.c sha.h \ + sig2str.h \ + stdio-safer.h \ + stripslash.c \ + strverscmp.h \ + timespec.h \ + unicodeio.c unicodeio.h \ + unistd-safer.h \ + userspec.c \ + version-etc.c version-etc.h \ + xalloc.h \ + xgetcwd.c \ + xgethostname.c \ + xmalloc.c \ + xmemcoll.c xmemcoll.h \ + xreadlink.c xreadlink.h \ + xstrdup.c \ + xstrtod.c xstrtod.h \ + xstrtol.c xstrtol.h \ + xstrtoul.c \ + xstrtoimax.c \ + xstrtoumax.c \ + yesno.c libfetish_a_LIBADD = @LIBOBJS@ @ALLOCA@ libfetish_a_DEPENDENCIES = $(libfetish_a_LIBADD) -noinst_HEADERS = argmatch.h backupfile.h closeout.h \ -dirname.h error.h exclude.h filemode.h fnmatch.h fsusage.h \ -getdate.h getline.h getopt.h getpagesize.h \ -group-member.h hash.h human.h lchown.h long-options.h \ -makepath.h modechange.h mountlist.h nanosleep.h path-concat.h pathmax.h \ -posixtm.h quotearg.h regex.h safe-read.h same.h save-cwd.h \ -savedir.h strverscmp.h \ -version-etc.h xalloc.h xstrtol.h -BUILT_SOURCES = getdate.c lstat.c stat.c +BUILT_SOURCES = getdate.c lstat.c stat.c unlocked-io.h MAINTAINERCLEANFILES = $(BUILT_SOURCES) -DISTCLEANFILES = lstat.c stat.c +DISTCLEANFILES = lstat.c stat.c unlocked-io.h + +EXTRA_DIST = xstat.in config.charset ref-add.sin ref-del.sin gen-uio \ + fnmatch_loop.c -EXTRA_DIST = xstat.in lstat.c: xstat.in sed \ -e '/@IGNORE@/d' \ -e 's/@xstat@/lstat/g' \ -e '/_LSTAT_ONLY@/d' \ -e '/@BEGIN_STAT_ONLY@/,/@END_STAT_ONLY@/d' \ - $(srcdir)/xstat.in > $@-t - mv $@-t $@ + $(srcdir)/xstat.in > t-$@ + mv t-$@ $@ stat.c: xstat.in sed \ @@ -47,5 +127,71 @@ stat.c: xstat.in -e 's/@xstat@/stat/g' \ -e '/_STAT_ONLY@/d' \ -e '/@BEGIN_LSTAT_ONLY@/,/@END_LSTAT_ONLY@/d' \ - $(srcdir)/xstat.in > $@-t - mv $@-t $@ + $(srcdir)/xstat.in > t-$@ + mv t-$@ $@ + +# The following is needed in order to install a simple file in $(libdir) +# which is shared with other installed packages. We use a list of referencing +# packages so that "make uninstall" will remove the file if and only if it +# is not used by another installed package. +# On systems with glibc-2.1 or newer, the file is redundant, therefore we +# avoid installing it. + +all-local: charset.alias ref-add.sed ref-del.sed lstat.c stat.c unlocked-io.h + +charset_alias = $(DESTDIR)$(libdir)/charset.alias +charset_tmp = $(DESTDIR)$(libdir)/charset.tmp +install-exec-local: all-local + $(mkinstalldirs) $(DESTDIR)$(libdir) + if test -f $(charset_alias); then \ + sed -f ref-add.sed $(charset_alias) > $(charset_tmp) ; \ + $(INSTALL_DATA) $(charset_tmp) $(charset_alias) ; \ + rm -f $(charset_tmp) ; \ + else \ + if test @GLIBC21@ = no; then \ + sed -f ref-add.sed charset.alias > $(charset_tmp) ; \ + $(INSTALL_DATA) $(charset_tmp) $(charset_alias) ; \ + rm -f $(charset_tmp) ; \ + fi ; \ + fi + +uninstall-local: all-local + if test -f $(charset_alias); then \ + sed -f ref-del.sed $(charset_alias) > $(charset_tmp); \ + if grep '^# Packages using this file: $$' $(charset_tmp) \ + > /dev/null; then \ + rm -f $(charset_alias); \ + else \ + $(INSTALL_DATA) $(charset_tmp) $(charset_alias); \ + fi; \ + rm -f $(charset_tmp); \ + fi + +charset.alias: config.charset + $(SHELL) $(srcdir)/config.charset '@host@' > t-$@ + mv t-$@ $@ + +SUFFIXES = .sed .sin +.sin.sed: + sed -e '/^#/d' -e 's/@''PACKAGE''@/@PACKAGE@/g' $< > t-$@ + mv t-$@ $@ + +CLEANFILES = charset.alias ref-add.sed ref-del.sed + +############################################### + +# FIXME: remove this dependency once automake handles it. +# As of cvs automake of about 2002-01-13, +# this dependency is necessary to avoid a build failure +# when running `make check' before running `make all'. +# Otherwise, unlocked-io.h is not built before it's needed. +getdate$U.o: unlocked-io.h + +# FIXME: CAUTION this list is a duplicate of one in ../Makefile.cfg. +io_functions = \ + clearerr feof ferror fflush fgets fputc fputs \ + fread fwrite getc getchar putc putchar + +unlocked-io.h: $(srcdir)/gen-uio Makefile.am + srcdir=$(srcdir) $(SHELL) $(srcdir)/gen-uio $(io_functions) > $@t + mv $@t $@