Mercurial > hg-stable
changeset 44676:97e6d435ff7e
rust-chg: send client-side environment variables to server
This is also needed to run config validation.
The "validate" request and its response handling will be implemented in
the next batch.
Differential Revision: https://phab.mercurial-scm.org/D8364
author | Yuya Nishihara <yuya@tcha.org> |
---|---|
date | Thu, 04 Oct 2018 23:07:48 +0900 |
parents | 8a7beeea655f |
children | 1756f75873bf |
files | rust/chg/src/clientext.rs rust/chg/src/locator.rs |
diffstat | 2 files changed, 20 insertions(+), 1 deletions(-) [+] |
line wrap: on
line diff
--- a/rust/chg/src/clientext.rs Thu Oct 04 23:01:34 2018 +0900 +++ b/rust/chg/src/clientext.rs Thu Oct 04 23:07:48 2018 +0900 @@ -33,6 +33,12 @@ where P: AsRef<Path>; + /// Updates the environment variables of the server. + fn set_env_vars_os<I, P>(self, vars: I) -> OneShotRequest<C> + where + I: IntoIterator<Item = (P, P)>, + P: AsRef<OsStr>; + /// Runs the specified Mercurial command with cHg extension. fn run_command_chg<I, P, H>(self, handler: H, args: I) -> ChgRunCommand<C, H> where @@ -61,6 +67,14 @@ OneShotRequest::start_with_args(self, b"chdir", dir.as_ref().as_os_str().as_bytes()) } + fn set_env_vars_os<I, P>(self, vars: I) -> OneShotRequest<C> + where + I: IntoIterator<Item = (P, P)>, + P: AsRef<OsStr>, + { + OneShotRequest::start_with_args(self, b"setenv", message::pack_env_vars_os(vars)) + } + fn run_command_chg<I, P, H>(self, handler: H, args: I) -> ChgRunCommand<C, H> where I: IntoIterator<Item = P>,
--- a/rust/chg/src/locator.rs Thu Oct 04 23:01:34 2018 +0900 +++ b/rust/chg/src/locator.rs Thu Oct 04 23:07:48 2018 +0900 @@ -24,7 +24,7 @@ use super::message::ServerSpec; use super::procutil; -const REQUIRED_SERVER_CAPABILITIES: &[&str] = &["attachio", "chdir", "runcommand"]; +const REQUIRED_SERVER_CAPABILITIES: &[&str] = &["attachio", "chdir", "runcommand", "setenv"]; /// Helper to connect to and spawn a server process. #[derive(Clone, Debug)] @@ -86,6 +86,11 @@ .set_current_dir(&loc.current_dir) .map(|client| (loc, client)) }) + .and_then(|(loc, client)| { + client + .set_env_vars_os(loc.env_vars.iter().cloned()) + .map(|client| (loc, client)) + }) } /// Spawns new server process and connects to it.