-noinst_LIBRARIES = fu
+## Process this file with automake to produce Makefile.in -*-Makefile-*-
-DIST_OTHER = alloca.c euidaccess.c fnmatch.c fsusage.c ftruncate.c \
-getdate.y memcmp.c memcpy.c memset.c mkdir.c mktime.c mountlist.c \
-posixtm.y rename.c rmdir.c stpcpy.c strdup.c strstr.c strtol.c strtoul.c
+AUTOMAKE_OPTIONS = ../src/ansi2knr
+
+noinst_LIBRARIES = libfetish.a
INCLUDES = -I.. -I$(srcdir)
+DEFS = -DLIBDIR=\"$(libdir)\" @DEFS@
+
+## 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 \
+ closeout.c closeout.h \
+ diacrit.c diacrit.h \
+ dirname.c dirname.h \
+ dirfd.h \
+ dup-safer.c \
+ exclude.c exclude.h \
+ filemode.c filemode.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 \
+ 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)
+
+
+BUILT_SOURCES = getdate.c lstat.c stat.c unlocked-io.h
+MAINTAINERCLEANFILES = $(BUILT_SOURCES)
+DISTCLEANFILES = lstat.c stat.c unlocked-io.h
+
+EXTRA_DIST = xstat.in config.charset ref-add.sin ref-del.sin gen-uio
+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 $@
+
+stat.c: xstat.in
+ sed \
+ -e '/@IGNORE@/d' \
+ -e 's/@xstat@/stat/g' \
+ -e '/_STAT_ONLY@/d' \
+ -e '/@BEGIN_LSTAT_ONLY@/,/@END_LSTAT_ONLY@/d' \
+ $(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
-fu_SOURCES = getdate.c posixtm.c argmatch.c backupfile.c basename.c \
-dirname.c error.c fileblocks.c filemode.c \
-full-write.c getopt.c getopt1.c getversion.c group-member.c idcache.c \
-isdir.c long-options.c makepath.c modechange.c obstack.c \
-safe-read.c save-cwd.c savedir.c stripslash.c userspec.c xgetcwd.c \
-xmalloc.c xstrdup.c xstrtol.c xstrtoul.c yesno.c
-
-fu_LIBADD = @LIBOBJS@ @ALLOCA@
-
-HEADERS = argmatch.h backupfile.h error.h fnmatch.h fsusage.h getopt.h \
-group-member.h long-options.h makepath.h modechange.h mountlist.h \
-obstack.h pathmax.h save-cwd.h xstrtol.h xstrtoul.h
-
-CONFIG_HEADER = ../config.h
-BUILT_SOURCES = getdate.c posixtm.c
-
-# Since this directory contains two parsers, we have to be careful to avoid
-# running two $(YACC)s during parallel makes. See below.
-getdate.c: getdate.y
- @echo expect 10 shift/reduce conflicts
- $(YACC) $(srcdir)/getdate.y
- mv y.tab.c getdate.c
-
-# Make the rename atomic, in case sed is interrupted and later rerun.
-# The artificial dependency on getdate.c keeps the two parsers from being
-# built in parallel. Enforcing this little bit of sequentiality lets
-# everyone (even those without bison) still run mostly parallel builds.
-posixtm.c: posixtm.y getdate.c
- $(YACC) $(srcdir)/posixtm.y
- mv y.tab.c posixtm.tab.c
- sed -e 's/yy/zz/g' posixtm.tab.c > tposixtm.c
- mv tposixtm.c posixtm.c
- rm -f posixtm.tab.c
+unlocked-io.h: $(srcdir)/gen-uio Makefile.am
+ srcdir=$(srcdir) $(SHELL) $(srcdir)/gen-uio $(io_functions) > $@t
+ mv $@t $@