[PATCH 4 of 6] rust-chg: add struct holding information needed to spawn server process

Gregory Szorc gregory.szorc at gmail.com
Sun Oct 14 07:48:31 EDT 2018


On Sun, Oct 14, 2018 at 10:29 AM Yuya Nishihara <yuya at tcha.org> wrote:

> # HG changeset patch
> # User Yuya Nishihara <yuya at tcha.org>
> # Date 1538828039 -32400
> #      Sat Oct 06 21:13:59 2018 +0900
> # Node ID 83ae46b307d87085a0a0f8224f021adf7788050d
> # Parent  efdf82aa259682f10c9211e283aceffd861f77cd
> rust-chg: add struct holding information needed to spawn server process
>
> The Locator will handle the initialization of the connection. It will spawn
> server processes as needed.
>
> diff --git a/rust/chg/src/locator.rs b/rust/chg/src/locator.rs
> --- a/rust/chg/src/locator.rs
> +++ b/rust/chg/src/locator.rs
> @@ -6,13 +6,54 @@
>  //! Utility for locating command-server process.
>
>  use std::env;
> +use std::ffi::{OsStr, OsString};
>  use std::fs::{self, DirBuilder};
>  use std::io;
> +use std::os::unix::ffi::{OsStrExt, OsStringExt};
>  use std::os::unix::fs::{DirBuilderExt, MetadataExt};
>  use std::path::{Path, PathBuf};
> +use std::process;
> +use std::time::Duration;
>
>  use super::procutil;
>
> +/// Helper to connect to and spawn a server process.
> +#[derive(Clone, Debug)]
> +pub struct Locator {
> +    hg_command: OsString,
> +    current_dir: PathBuf,
> +    env_vars: Vec<(OsString, OsString)>,
> +    process_id: u32,
> +    base_sock_path: PathBuf,
> +    timeout: Duration,
> +}
> +
> +impl Locator {
> +    /// Creates locator capturing the current process environment.
> +    ///
> +    /// If no `$CHGSOCKNAME` is specified, the socket directory will be
> +    /// created as necessary.
> +    pub fn prepare_from_env() -> io::Result<Locator> {
> +        Ok(Locator {
> +            hg_command: default_hg_command(),
> +            current_dir: env::current_dir()?,
> +            env_vars: env::vars_os().collect(),
> +            process_id: process::id(),
> +            base_sock_path: prepare_server_socket_path()?,
> +            timeout: default_timeout(),
> +        })
> +    }
> +
> +    /// Temporary socket path for this client process.
> +    fn temp_sock_path(&self) -> PathBuf {
> +        let src = self.base_sock_path.as_os_str().as_bytes();
> +        let mut buf = Vec::with_capacity(src.len() + 6);
>

This magic number to hold the formatted pid scared me a bit. But Rust
should guarantee memory safety. I wish this could be expressed in terms of
the size of another variable that will occupy the space. But meh.


> +        buf.extend_from_slice(src);
> +        buf.extend_from_slice(format!(".{}", self.process_id).as_bytes());
> +        OsString::from_vec(buf).into()
> +    }
> +}
> +
>  /// Determines the server socket to connect to.
>  ///
>  /// If no `$CHGSOCKNAME` is specified, the socket directory will be
> created
> @@ -47,6 +88,17 @@ pub fn default_server_socket_dir() -> Pa
>      }
>  }
>
> +/// Determines the default hg command.
> +pub fn default_hg_command() -> OsString {
> +    // TODO: maybe allow embedding the path at compile time (or load from
> hgrc)
> +
> env::var_os("CHGHG").or(env::var_os("HG")).unwrap_or(OsStr::new("hg").to_owned())
> +}
> +
> +fn default_timeout() -> Duration {
> +    let secs = env::var("CHGTIMEOUT").ok().and_then(|s|
> s.parse().ok()).unwrap_or(60);
> +    Duration::from_secs(secs)
> +}
> +
>  /// Creates a directory which the other users cannot access to.
>  ///
>  /// If the directory already exists, tests its permission.
> _______________________________________________
> Mercurial-devel mailing list
> Mercurial-devel at mercurial-scm.org
> https://www.mercurial-scm.org/mailman/listinfo/mercurial-devel
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://www.mercurial-scm.org/pipermail/mercurial-devel/attachments/20181014/e19f8b07/attachment.html>


More information about the Mercurial-devel mailing list