Load configure task arguments before early configure operations - close #157
This commit is contained in:
parent
b932380b3b
commit
1bf1c30242
@ -2,4 +2,5 @@ configure do
|
|||||||
check_c_compiler
|
check_c_compiler
|
||||||
end
|
end
|
||||||
env do |env|
|
env do |env|
|
||||||
|
puts "Prefix is #{Task["configure"]["prefix"]}"
|
||||||
end
|
end
|
||||||
|
@ -446,6 +446,9 @@ end
|
|||||||
See ${#Configuring the Project} for more details on how to make use of the
|
See ${#Configuring the Project} for more details on how to make use of the
|
||||||
configuration functionality that Rscons provides.
|
configuration functionality that Rscons provides.
|
||||||
|
|
||||||
|
Configure blocks must be defined in the Rsconscript file before any
|
||||||
|
environments are created.
|
||||||
|
|
||||||
####> Default Task
|
####> Default Task
|
||||||
|
|
||||||
The `default` task is special in that Rscons will execute it if no other task
|
The `default` task is special in that Rscons will execute it if no other task
|
||||||
|
@ -73,6 +73,7 @@ module Rscons
|
|||||||
# Process exit code (0 on success).
|
# Process exit code (0 on success).
|
||||||
def run(rsconscript, tasks_and_params, show_tasks, all_tasks, enabled_variants)
|
def run(rsconscript, tasks_and_params, show_tasks, all_tasks, enabled_variants)
|
||||||
Cache.instance["failed_commands"] = []
|
Cache.instance["failed_commands"] = []
|
||||||
|
@tasks_and_params = tasks_and_params
|
||||||
@enabled_variants = enabled_variants
|
@enabled_variants = enabled_variants
|
||||||
if enabled_variants == "" && !tasks_and_params.include?("configure")
|
if enabled_variants == "" && !tasks_and_params.include?("configure")
|
||||||
if cache_enabled_variants = Cache.instance["configuration_data"]["enabled_variants"]
|
if cache_enabled_variants = Cache.instance["configuration_data"]["enabled_variants"]
|
||||||
@ -86,7 +87,7 @@ module Rscons
|
|||||||
show_script_tasks(all_tasks)
|
show_script_tasks(all_tasks)
|
||||||
return 0
|
return 0
|
||||||
end
|
end
|
||||||
apply_task_params(tasks_and_params)
|
apply_task_params(false)
|
||||||
@task_execution_phase = true
|
@task_execution_phase = true
|
||||||
if tasks_and_params.empty?
|
if tasks_and_params.empty?
|
||||||
check_process_environments
|
check_process_environments
|
||||||
@ -179,6 +180,7 @@ module Rscons
|
|||||||
#
|
#
|
||||||
# @return [void]
|
# @return [void]
|
||||||
def check_configure
|
def check_configure
|
||||||
|
apply_task_params(true)
|
||||||
enable_variants
|
enable_variants
|
||||||
unless Cache.instance["configuration_data"]["configured"]
|
unless Cache.instance["configuration_data"]["configured"]
|
||||||
if @script.autoconf
|
if @script.autoconf
|
||||||
@ -378,8 +380,9 @@ module Rscons
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def apply_task_params(tasks_and_params)
|
def apply_task_params(only_configure)
|
||||||
tasks_and_params.each do |task_name, task_params|
|
@tasks_and_params.each do |task_name, task_params|
|
||||||
|
unless only_configure && task_name != "configure"
|
||||||
task_params.each do |param_name, param_value|
|
task_params.each do |param_name, param_value|
|
||||||
if param = Task[task_name].params[param_name]
|
if param = Task[task_name].params[param_name]
|
||||||
Task[task_name].set_param_value(param_name, param_value)
|
Task[task_name].set_param_value(param_name, param_value)
|
||||||
@ -389,6 +392,7 @@ module Rscons
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -1845,6 +1845,15 @@ EOF
|
|||||||
expect(result.stdout).to_not match %r{Configuring project.*Configuring project}m
|
expect(result.stdout).to_not match %r{Configuring project.*Configuring project}m
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it "loads configure parameters before invoking configure" do
|
||||||
|
test_dir "configure"
|
||||||
|
|
||||||
|
result = run_rscons(args: %w[-f configure_with_top_level_env.rb configure --prefix=/yodabob])
|
||||||
|
expect(result.stderr).to eq ""
|
||||||
|
expect(result.status).to eq 0
|
||||||
|
expect(result.stdout).to match "Prefix is /yodabob"
|
||||||
|
end
|
||||||
|
|
||||||
it "automatically runs the configure task if the project is not yet configured in the given build directory" do
|
it "automatically runs the configure task if the project is not yet configured in the given build directory" do
|
||||||
test_dir "configure"
|
test_dir "configure"
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user