summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorPaul Smith <psmith@gnu.org>2022-12-24 09:26:24 -0500
committerPaul Smith <psmith@gnu.org>2022-12-24 10:52:43 -0500
commit76d2e5d98dbbf655f74f6ef2f6dd3cdd45052ea0 (patch)
tree3a9ed561d856a8031812f472cae408f9bc74fe8d /src
parenta581146562009407649b85fac48f4e7cafe5eaa0 (diff)
downloadmake-git-76d2e5d98dbbf655f74f6ef2f6dd3cdd45052ea0.tar.gz
[SV 63552] Change directories before constructing include paths
* src/makeint.h (reset_makeflags): New function to handle changing MAKEFLAGS from within makefiles. Remove decode_env_switches(). * src/variable.c (set_special_var): Call reset_makeflags() instead of various internal methods. * src/main.c (decode_env_switches): Only internal now so make static. (decode_switches): Don't invoke construct_include_path() yet. (reset_makeflags): Decode env switches and construct include paths. (main): Construct include paths after we process -C options. * tests/scripts/options/dash-C: Rewrite to use new test constructs. Add a test using both -C and -I together. Add a test for multiple -C options.
Diffstat (limited to 'src')
-rw-r--r--src/main.c20
-rw-r--r--src/makeint.h4
-rw-r--r--src/variable.c10
3 files changed, 22 insertions, 12 deletions
diff --git a/src/main.c b/src/main.c
index cae35033..4f1c40ba 100644
--- a/src/main.c
+++ b/src/main.c
@@ -107,6 +107,8 @@ static void print_data_base (void);
static void print_version (void);
static void decode_switches (int argc, const char **argv,
enum variable_origin origin);
+static void decode_env_switches (const char *envar, size_t len,
+ enum variable_origin origin);
static char *quote_for_env (char *out, const char *in);
static void initialize_global_hash_tables (void);
@@ -1818,6 +1820,10 @@ main (int argc, char **argv, char **envp)
define_variable_cname ("CURDIR", current_directory, o_file, 0);
+ /* Construct the list of include directories to search.
+ This will check for existence so it must be done after chdir. */
+ construct_include_path (include_dirs ? include_dirs->list : NULL);
+
/* Validate the arg_job_slots configuration before we define MAKEFLAGS so
users get an accurate value in their makefiles.
At this point arg_job_slots is the argv setting, if there is one, else
@@ -3108,6 +3114,15 @@ handle_non_switch_argument (const char *arg, enum variable_origin origin)
}
}
+/* Called if the makefile resets the MAKEFLAGS variable. */
+void
+reset_makeflags (enum variable_origin origin)
+{
+ decode_env_switches (STRING_SIZE_TUPLE(MAKEFLAGS_NAME), origin);
+ construct_include_path (include_dirs ? include_dirs->list : NULL);
+ define_makeflags (rebuilding_makefiles);
+}
+
/* Decode switches from ARGC and ARGV.
They came from the environment if ORIGIN is o_env. */
@@ -3350,9 +3365,6 @@ decode_switches (int argc, const char **argv, enum variable_origin origin)
/* Perform any special switch handling. */
run_silent = silent_flag;
-
- /* Construct the list of include directories to search. */
- construct_include_path (include_dirs ? include_dirs->list : NULL);
}
/* Decode switches from environment variable ENVAR (which is LEN chars long).
@@ -3360,7 +3372,7 @@ decode_switches (int argc, const char **argv, enum variable_origin origin)
dash to the first word if it lacks one, and passing the vector to
decode_switches. */
-void
+static void
decode_env_switches (const char *envar, size_t len, enum variable_origin origin)
{
char *varref = alloca (2 + len + 2);
diff --git a/src/makeint.h b/src/makeint.h
index 40383b9c..4076928b 100644
--- a/src/makeint.h
+++ b/src/makeint.h
@@ -571,9 +571,9 @@ void out_of_memory (void) NORETURN;
(_f), (_n), (_s))
enum variable_origin;
-void decode_env_switches (const char*, size_t line,
- enum variable_origin origin);
struct variable;
+
+void reset_makeflags (enum variable_origin origin);
struct variable *define_makeflags (int makefile);
int should_print_dir (void);
void temp_stdin_unlink (void);
diff --git a/src/variable.c b/src/variable.c
index d8bf4288..1b1cb743 100644
--- a/src/variable.c
+++ b/src/variable.c
@@ -1217,18 +1217,16 @@ target_environment (struct file *file, int recursive)
static struct variable *
set_special_var (struct variable *var, enum variable_origin origin)
{
- if (streq (var->name, RECIPEPREFIX_NAME))
+ if (streq (var->name, MAKEFLAGS_NAME))
+ reset_makeflags (origin);
+
+ else if (streq (var->name, RECIPEPREFIX_NAME))
{
/* The user is resetting the command introduction prefix. This has to
happen immediately, so that subsequent rules are interpreted
properly. */
cmd_prefix = var->value[0]=='\0' ? RECIPEPREFIX_DEFAULT : var->value[0];
}
- else if (streq (var->name, MAKEFLAGS_NAME))
- {
- decode_env_switches (STRING_SIZE_TUPLE(MAKEFLAGS_NAME), origin);
- define_makeflags (rebuilding_makefiles);
- }
return var;
}