+2004-04-09 Alexandre Duret-Lutz <adl@gnu.org>
+
+ * automake.in (handle_lib_objects): Pass the condition of
+ the variable definition to handle_LIBOBJS and handle_ALLOCA,
+ not the aggregated conditions.
+ * tests/Makefile.am (TESTS): Add libobj14.test.
+ * tests/libobj14.test: New file.
+ Report from Bill Davidson.
+
2004-04-02 Mike Nolta <mike@nolta.net>
Better support for Fortran 9x.
}
elsif ($val =~ /^\@(LT)?LIBOBJS\@$/)
{
- handle_LIBOBJS ($subvar, $full_cond, $1);
+ handle_LIBOBJS ($subvar, $cond, $1);
$seen_libobjs = 1;
return $val;
}
elsif ($val =~ /^\@(LT)?ALLOCA\@$/)
{
- handle_ALLOCA ($subvar, $full_cond, $1);
+ handle_ALLOCA ($subvar, $cond, $1);
return $val;
}
else
--- /dev/null
+#!/bin/sh
+# Copyright (C) 2004 Free Software Foundation, Inc.
+#
+# This file is part of GNU Automake.
+#
+# GNU Automake is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2, or (at your option)
+# any later version.
+#
+# GNU Automake 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 General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with Automake; see the file COPYING. If not, write to
+# the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+# Boston, MA 02111-1307, USA.
+
+# Regression test for an internal error when @LIBOBJS@ is used in
+# a variable that is not defined in the same conditions as the _LDADD
+# that uses it.
+# Report from Bill Davidson
+
+required=gcc
+. ./defs
+
+set -e
+
+cat >>configure.in <<'EOF'
+AC_PROG_CC
+AC_LIBSOURCE([bar.c])
+AM_CONDITIONAL([CASE], :)
+AC_OUTPUT
+EOF
+
+: >bar.c
+
+cat >>Makefile.am <<'EOF'
+COMMON_LIBS = @LIBOBJS@
+bin_PROGRAMS = foo
+if ! CASE
+foo_LDADD = $(COMMON_LIBS)
+endif
+EOF
+
+$ACLOCAL
+$AUTOMAKE