run_make_support: make set_host_rpath private and move into util

This commit is contained in:
许杰友 Jieyou Xu (Joe) 2024-07-15 12:14:19 +00:00
parent e956808c6c
commit aadd08576d
6 changed files with 28 additions and 24 deletions

View file

@ -1,6 +1,7 @@
use std::path::{Path, PathBuf};
use crate::{env_var, Command};
use crate::command::Command;
use crate::env_checked::env_var;
/// Construct a new `llvm-readobj` invocation with the `GNU` output style.
/// This assumes that `llvm-readobj` is available at `$LLVM_BIN_DIR/llvm-readobj`.

View file

@ -1,8 +1,10 @@
use command::Command;
use std::ffi::{OsStr, OsString};
use std::path::Path;
use crate::{command, cwd, env_var, set_host_rpath};
use crate::command::Command;
use crate::env_checked::env_var;
use crate::path_helpers::cwd;
use crate::util::set_host_rpath;
/// Construct a new `rustc` invocation. This will automatically set the library
/// search path as `-L cwd()`. Use [`bare_rustc`] to avoid this.

View file

@ -2,7 +2,8 @@ use std::ffi::OsStr;
use std::path::Path;
use crate::command::Command;
use crate::{env_var, env_var_os, set_host_rpath};
use crate::env_checked::{env_var, env_var_os};
use crate::util::set_host_rpath;
/// Construct a plain `rustdoc` invocation with no flags set.
#[track_caller]

View file

@ -20,8 +20,6 @@ pub mod run;
pub mod scoped_run;
pub mod targets;
use std::path::PathBuf;
// Re-exports of third-party library crates.
pub use bstr;
pub use gimli;
@ -85,8 +83,6 @@ pub use assertion_helpers::{
shallow_find_files,
};
use command::Command;
/// Builds a static lib (`.lib` on Windows MSVC and `.a` for the rest) with the given name.
#[track_caller]
pub fn build_native_static_lib(lib_name: &str) -> PathBuf {
@ -106,17 +102,3 @@ pub fn build_native_static_lib(lib_name: &str) -> PathBuf {
llvm_ar().obj_to_ar().output_input(&lib_path, &obj_file).run();
path(lib_path)
}
/// Set the runtime library path as needed for running the host rustc/rustdoc/etc.
pub fn set_host_rpath(cmd: &mut Command) {
let ld_lib_path_envvar = env_var("LD_LIB_PATH_ENVVAR");
cmd.env(&ld_lib_path_envvar, {
let mut paths = vec![];
paths.push(cwd());
paths.push(PathBuf::from(env_var("HOST_RPATH_DIR")));
for p in std::env::split_paths(&env_var(&ld_lib_path_envvar)) {
paths.push(p.to_path_buf());
}
std::env::join_paths(paths.iter()).unwrap()
});
}

View file

@ -4,8 +4,8 @@ use std::panic;
use std::path::{Path, PathBuf};
use crate::command::{Command, CompletedProcess};
use crate::util::handle_failed_output;
use crate::{cwd, env_var, is_windows, set_host_rpath};
use crate::util::{handle_failed_output, set_host_rpath};
use crate::{cwd, env_var, is_windows};
#[track_caller]
fn run_common(name: &str, args: Option<&[&str]>) -> Command {

View file

@ -1,4 +1,8 @@
use std::path::PathBuf;
use crate::command::{Command, CompletedProcess};
use crate::env_checked::env_var;
use crate::path_helpers::cwd;
/// If a given [`Command`] failed (as indicated by its [`CompletedProcess`]), verbose print the
/// executed command, failure location, output status and stdout/stderr, and abort the process with
@ -19,3 +23,17 @@ pub(crate) fn handle_failed_output(
eprintln!("=== STDERR ===\n{}\n\n", output.stderr_utf8());
std::process::exit(1)
}
/// Set the runtime library path as needed for running the host rustc/rustdoc/etc.
pub(crate) fn set_host_rpath(cmd: &mut Command) {
let ld_lib_path_envvar = env_var("LD_LIB_PATH_ENVVAR");
cmd.env(&ld_lib_path_envvar, {
let mut paths = vec![];
paths.push(cwd());
paths.push(PathBuf::from(env_var("HOST_RPATH_DIR")));
for p in std::env::split_paths(&env_var(&ld_lib_path_envvar)) {
paths.push(p.to_path_buf());
}
std::env::join_paths(paths.iter()).unwrap()
});
}