Skip to content

Commit

Permalink
Rename rustflags variable to make global scope clear
Browse files Browse the repository at this point in the history
The currently available way of setting Rustflags is by setting the `RUSTFLAGS`
environment variable, which affects all crates in the dependency graph.

This may be undesirable in some circumstances, so a future commit will
the option to specify RUSTFLAGS via `cargo rustc`, which only affects
the current crate and not dependencies.

This commit prepares by refactoring some names to make the distinction
easier.
  • Loading branch information
jschwe committed Sep 6, 2022
1 parent 6671452 commit 9e926bf
Showing 1 changed file with 4 additions and 7 deletions.
11 changes: 4 additions & 7 deletions cmake/Corrosion.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -252,10 +252,7 @@ function(_add_cargo_build)
set(no_default_libraries_arg --no-default-libraries)
endif()

set(rustflags_target_property "$<TARGET_GENEX_EVAL:${target_name},$<TARGET_PROPERTY:${target_name},INTERFACE_CORROSION_RUSTFLAGS>>")
# `rustflags_target_property` may contain multiple arguments and double quotes, so we _should_ single quote it to
# preserve any double quotes and keep it as one argument value. However single quotes don't work on windows, so we
# can only add double quotes here. Any double quotes _in_ the rustflags must be escaped like `\\\"`.
set(global_rustflags_target_property "$<TARGET_GENEX_EVAL:${target_name},$<TARGET_PROPERTY:${target_name},INTERFACE_CORROSION_RUSTFLAGS>>")

set(features_target_property "$<GENEX_EVAL:$<TARGET_PROPERTY:${target_name},${_CORR_PROP_FEATURES}>>")
set(features_genex "$<$<BOOL:${features_target_property}>:--features=$<JOIN:${features_target_property},$<COMMA>>>")
Expand Down Expand Up @@ -358,8 +355,8 @@ function(_add_cargo_build)
corrosion_add_target_rustflags("${target_name}" "-Cdefault-linker-libraries=yes")
endif()

set(joined_rustflags "$<JOIN:${rustflags_target_property}, >")
set(rustflags_genex "$<$<BOOL:${rustflags_target_property}>:RUSTFLAGS=${joined_rustflags}>")
set(global_joined_rustflags "$<JOIN:${global_rustflags_target_property}, >")
set(global_rustflags_genex "$<$<BOOL:${global_rustflags_target_property}>:RUSTFLAGS=${global_joined_rustflags}>")

# Used to set a linker for a specific target-triple.
set(cargo_target_linker_var "CARGO_TARGET_${_CORROSION_RUST_CARGO_TARGET_UPPER}_LINKER")
Expand Down Expand Up @@ -389,7 +386,7 @@ function(_add_cargo_build)
COMMAND
${CMAKE_COMMAND} -E env
"${build_env_variable_genex}"
"${rustflags_genex}"
"${global_rustflags_genex}"
"${cargo_target_linker}"
"${corrosion_cc_rs_flags}"
"${cargo_library_path}"
Expand Down

0 comments on commit 9e926bf

Please sign in to comment.