changeset 39980:6bdee4bc181a

rust-chg: add main program It can at least connect to a *running* command server, and execute Mercurial command. No signal handling nor daemon management is implemented yet.
author Yuya Nishihara <yuya@tcha.org>
date Mon, 24 Sep 2018 19:23:50 +0900
parents 045ea159418d
children d71e0ba34d9b
files rust/chg/src/main.rs
diffstat 1 files changed, 44 insertions(+), 0 deletions(-) [+]
line wrap: on
line diff
--- a/rust/chg/src/main.rs	Mon Sep 24 19:06:30 2018 +0900
+++ b/rust/chg/src/main.rs	Mon Sep 24 19:23:50 2018 +0900
@@ -3,5 +3,49 @@
 // This software may be used and distributed according to the terms of the
 // GNU General Public License version 2 or any later version.
 
+extern crate chg;
+extern crate futures;
+extern crate tokio;
+extern crate tokio_hglib;
+
+use chg::{ChgClientExt, ChgUiHandler};
+use chg::locator;
+use futures::sync::oneshot;
+use std::env;
+use std::io;
+use std::process;
+use tokio::prelude::*;
+use tokio_hglib::UnixClient;
+
 fn main() {
+    let code = run().unwrap_or_else(|err| {
+        eprintln!("chg: abort: {}", err);
+        255
+    });
+    process::exit(code);
 }
+
+fn run() -> io::Result<i32> {
+    let current_dir = env::current_dir()?;
+    let sock_path = locator::prepare_server_socket_path()?;
+    let handler = ChgUiHandler::new();
+    let (result_tx, result_rx) = oneshot::channel();
+    let fut = UnixClient::connect(sock_path)
+        .and_then(|client| {
+            client.set_current_dir(current_dir)
+        })
+        .and_then(|client| {
+            client.attach_io(io::stdin(), io::stdout(), io::stderr())
+        })
+        .and_then(|client| {
+            client.run_command_chg(handler, env::args_os().skip(1))
+        })
+        .map(|(_client, _handler, code)| {
+            Ok(code)
+        })
+        .or_else(|err| Ok(Err(err)))  // pass back error to caller
+        .map(|res| result_tx.send(res).unwrap());
+    tokio::run(fut);
+    result_rx.wait().unwrap_or(Err(io::Error::new(io::ErrorKind::Other,
+                                                  "no exit code set")))
+}