-
Notifications
You must be signed in to change notification settings - Fork 1k
Expand file tree
/
Copy pathproxy_mode.rs
More file actions
62 lines (53 loc) · 1.79 KB
/
proxy_mode.rs
File metadata and controls
62 lines (53 loc) · 1.79 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
use std::ffi::OsString;
use std::process::ExitStatus;
use anyhow::Result;
use crate::{
cli::{common::set_globals, job, self_update},
command::run_command_for_dir,
config::Cfg,
currentprocess::process,
toolchain::names::{LocalToolchainName, ResolvableLocalToolchainName},
utils::utils,
};
#[cfg_attr(feature = "otel", tracing::instrument)]
pub async fn main(arg0: &str) -> Result<ExitStatus> {
self_update::cleanup_self_updater()?;
let _setup = job::setup();
let process = process();
let mut args = process.args_os().skip(1);
// Check for a + toolchain specifier
let arg1 = args.next();
let toolchain = arg1
.as_ref()
.map(|arg| arg.to_string_lossy())
.filter(|arg| arg.starts_with('+'))
.map(|name| ResolvableLocalToolchainName::try_from(&name.as_ref()[1..]))
.transpose()?;
// Build command args now while we know whether or not to skip arg 1.
let cmd_args: Vec<_> = crate::currentprocess::process()
.args_os()
.skip(1 + toolchain.is_some() as usize)
.collect();
let cfg = set_globals(false, true)?;
cfg.check_metadata_version()?;
let toolchain = toolchain
.map(|t| t.resolve(&cfg.get_default_host_triple()?))
.transpose()?;
direct_proxy(&cfg, arg0, toolchain, &cmd_args).await
}
#[cfg_attr(feature = "otel", tracing::instrument(skip(cfg)))]
async fn direct_proxy(
cfg: &Cfg,
arg0: &str,
toolchain: Option<LocalToolchainName>,
args: &[OsString],
) -> Result<ExitStatus> {
let cmd = match toolchain {
None => {
cfg.create_command_for_dir(&utils::current_dir()?, arg0)
.await?
}
Some(tc) => cfg.create_command_for_toolchain(&tc, false, arg0).await?,
};
run_command_for_dir(cmd, arg0, args)
}