From da1b137e389365ddfb9d16b3d6761cf1a3986e0b Mon Sep 17 00:00:00 2001 From: Paul Smith Date: Mon, 27 Jun 2005 01:01:07 +0000 Subject: [PATCH] Fix strerror() handling for systems which set ANSI_STRING. Don't print errors if "include" is specified with no arguments. New test suite for the $(shell ...) function. --- ChangeLog | 10 ++++++++++ doc/make.texi | 7 ++++++- function.c | 5 ++++- main.c | 2 +- make.h | 9 ++++----- read.c | 8 +++----- tests/ChangeLog | 7 +++++++ tests/scripts/features/include | 10 ++++++++++ tests/scripts/functions/shell | 23 +++++++++++++++++++++++ 9 files changed, 68 insertions(+), 13 deletions(-) create mode 100644 tests/scripts/functions/shell diff --git a/ChangeLog b/ChangeLog index dc134232..bf8bf759 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,15 @@ +2005-06-26 Paul D. Smith + + * make.h: Fix bug in ANSI_STRING/strerror() handling; only define + it if ANSI_STRING is not set. + 2005-06-25 Paul D. Smith + * read.c (eval): If no filenames are passed to any of the + "include" variants, don't print an error. + * doc/make.texi (Include): Document this. + Fixes Savannah bug #1761. + * job.c (construct_command_argv_internal): Sanitize handling of backslash/newline pairs according to POSIX: that is, keep the backslash-newline in the command script, but remove a following diff --git a/doc/make.texi b/doc/make.texi index 4f07338c..32d15584 100644 --- a/doc/make.texi +++ b/doc/make.texi @@ -1099,7 +1099,8 @@ include @var{filenames}@dots{} @end example @noindent -@var{filenames} can contain shell file name patterns. +@var{filenames} can contain shell file name patterns. If +@var{filenames} is empty, nothing is included and no error is printed. @cindex shell file name pattern (in @code{include}) @cindex shell wildcards (in @code{include}) @cindex wildcard, in @code{include} @@ -1379,6 +1380,10 @@ Supports secondary expansion of prerequisite lists. Supports ``job server'' enhanced parallel builds. @xref{Parallel, ,Parallel Execution}. +@item else-if +Supports ``else if'' non-nested conditionals. @xref{Conditional +Syntax, ,Syntax of Conditionals}. + @item check-symlink Supports the @code{-L} (@code{--check-symlink-times}) flag. @xref{Options Summary, ,Summary of Options}. diff --git a/function.c b/function.c index 983df74f..0772739f 100644 --- a/function.c +++ b/function.c @@ -1482,7 +1482,10 @@ func_shell (char *o, char **argv, const char *funcname UNUSED) because target_environment hits a loop trying to expand $(var) to put it in the environment. This is even more confusing when var was not explicitly exported, but just appeared in the - calling environment. */ + calling environment. + + envp = target_environment (NILF); + */ envp = environ; diff --git a/main.c b/main.c index cd58a493..b7db0673 100644 --- a/main.c +++ b/main.c @@ -1102,7 +1102,7 @@ main (int argc, char **argv, char **envp) /* Set up .FEATURES */ define_variable (".FEATURES", 9, - "target-specific order-only second-expansion", + "target-specific order-only second-expansion else-if", o_default, 0); #ifdef MAKE_JOBSERVER do_variable_definition (NILF, ".FEATURES", "jobserver", diff --git a/make.h b/make.h index 55682d86..b772d777 100644 --- a/make.h +++ b/make.h @@ -276,16 +276,15 @@ extern void bzero PARAMS ((char *, int)); extern void bcopy PARAMS ((const char *b1, char *b2, int)); # endif -#endif /* ANSI_STRING. */ -#undef ANSI_STRING - /* SCO Xenix has a buggy macro definition in . */ #undef strerror - -#if !defined(ANSI_STRING) && !defined(__DECC) +#if !defined(__DECC) extern char *strerror PARAMS ((int errnum)); #endif +#endif /* !ANSI_STRING. */ +#undef ANSI_STRING + #if HAVE_INTTYPES_H # include #endif diff --git a/read.c b/read.c index 024567a9..a6e18b07 100644 --- a/read.c +++ b/read.c @@ -800,12 +800,10 @@ eval (struct ebuffer *ebuf, int set_default) int noerror = (p[0] != 'i'); p = allocated_variable_expand (p2); + + /* If no filenames, it's a no-op. */ if (*p == '\0') - { - error (fstart, - _("no file name for `%sinclude'"), noerror ? "-" : ""); - continue; - } + continue; /* Parse the list of file names. */ p2 = p; diff --git a/tests/ChangeLog b/tests/ChangeLog index c07d7c14..bc2108d0 100644 --- a/tests/ChangeLog +++ b/tests/ChangeLog @@ -1,5 +1,12 @@ +2005-06-26 Paul D. Smith + + * scripts/functions/shell: New test suite for the shell function. + 2005-06-25 Paul D. Smith + * scripts/features/include: Test include/-include/sinclude with no + arguments. Tests fix for Savannah bug #1761. + * scripts/misc/general3: Implement comprehensive testing of backslash-newline behavior in command scripts: various types of quoting, fast path / slow path, etc. diff --git a/tests/scripts/features/include b/tests/scripts/features/include index 26ee1bdb..5030662e 100644 --- a/tests/scripts/features/include +++ b/tests/scripts/features/include @@ -107,4 +107,14 @@ foo: bar; @: bar:; @false ', '', ''); +# Check include, sinclude, -include with no filenames. +# (Savannah bug #1761). + +run_make_test(' +.PHONY: all +all:; @: +include +-include +sinclude', '', ''); + 1; diff --git a/tests/scripts/functions/shell b/tests/scripts/functions/shell new file mode 100644 index 00000000..ecea4cf6 --- /dev/null +++ b/tests/scripts/functions/shell @@ -0,0 +1,23 @@ +# -*-perl-*- + +$description = 'Test the $(shell ...) function.'; + +$details = ''; + + +# Test shells inside rules. +run_make_test('.PHONY: all +all: ; @echo $(shell echo hi) +','','hi'); + + +# Test shells inside exported environment variables. +# This is the test that fails if we try to put make exported variables into +# the environment for a $(shell ...) call. +run_make_test(' +export HI = $(shell echo hi) +.PHONY: all +all: ; @echo $$HI +','','hi'); + +1;