rust: extract function to convert Path to platform CString
authorYuya Nishihara <yuya@tcha.org>
Fri, 12 Jan 2018 22:09:34 +0900
changeset 35631 edbe11cfedcf
parent 35630 6061e54ff81d
child 35632 fa9747e7fc86
rust: extract function to convert Path to platform CString It can be better on Unix.
rust/hgcli/src/main.rs
--- a/rust/hgcli/src/main.rs	Mon Oct 09 11:46:27 2017 +0200
+++ b/rust/hgcli/src/main.rs	Fri Jan 12 22:09:34 2018 +0900
@@ -14,7 +14,7 @@
 
 use std::env;
 use std::path::PathBuf;
-use std::ffi::CString;
+use std::ffi::{CString, OsStr};
 #[cfg(target_family = "unix")]
 use std::os::unix::ffi::OsStringExt;
 
@@ -62,6 +62,10 @@
     }
 }
 
+fn cstring_from_os<T: AsRef<OsStr>>(s: T) -> CString {
+    CString::new(s.as_ref().to_str().unwrap()).unwrap()
+}
+
 // On UNIX, argv starts as an array of char*. So it is easy to convert
 // to C strings.
 #[cfg(target_family = "unix")]
@@ -86,9 +90,7 @@
 }
 
 fn set_python_home(env: &Environment) {
-    let raw = CString::new(env.python_home.to_str().unwrap())
-        .unwrap()
-        .into_raw();
+    let raw = cstring_from_os(&env.python_home).into_raw();
     unsafe {
         python27_sys::Py_SetPythonHome(raw);
     }
@@ -133,9 +135,7 @@
     // Python files. Apparently we could define our own ``Py_GetPath()``
     // implementation. But this may require statically linking Python, which is
     // not desirable.
-    let program_name = CString::new(env.python_exe.to_str().unwrap())
-        .unwrap()
-        .as_ptr();
+    let program_name = cstring_from_os(&env.python_exe).as_ptr();
     unsafe {
         python27_sys::Py_SetProgramName(program_name as *mut i8);
     }