-
Notifications
You must be signed in to change notification settings - Fork 917
/
Copy pathproxy_mode.rs
40 lines (33 loc) · 1.18 KB
/
proxy_mode.rs
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
use std::{path::PathBuf, process::ExitStatus};
use anyhow::Result;
use crate::{
cli::{common::set_globals, job, self_update},
command::run_command_for_dir,
process::Process,
toolchain::ResolvableLocalToolchainName,
};
#[tracing::instrument(level = "trace")]
pub async fn main(arg0: &str, current_dir: PathBuf, process: &Process) -> Result<ExitStatus> {
self_update::cleanup_self_updater(process)?;
let _setup = job::setup();
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<_> = process
.args_os()
.skip(1 + toolchain.is_some() as usize)
.collect();
let cfg = set_globals(current_dir, true, process)?;
let cmd = cfg
.resolve_local_toolchain(toolchain)
.await?
.command(arg0)?;
run_command_for_dir(cmd, arg0, &cmd_args)
}