src/dirname.rs in faster_path-0.1.12 vs src/dirname.rs in faster_path-0.1.13

- old
+ new

@@ -1,32 +1,46 @@ -use std::path::MAIN_SEPARATOR; use libc::c_char; use std::ffi::{CStr, CString}; -use path_parsing::{last_sep_i, last_non_sep_i, last_non_sep_i_before}; #[no_mangle] pub extern "C" fn dirname(path: *const c_char) -> *const c_char { if path.is_null() { return path } let r_str = unsafe { CStr::from_ptr(path) }.to_str().unwrap(); - if r_str.is_empty() { - return CString::new(".").unwrap().into_raw(); + + CString::new(rust::dirname(r_str)).unwrap().into_raw() +} + +pub mod rust { + use std::path::MAIN_SEPARATOR; + use path_parsing::{last_sep_i, last_non_sep_i, last_non_sep_i_before}; + + pub fn dirname(path: &str) -> String { + let r_str = path; + if r_str.is_empty() { + return ".".to_string(); + } + let non_sep_i = last_non_sep_i(r_str); + if non_sep_i == -1 { + return MAIN_SEPARATOR.to_string(); + } + let sep_i = last_sep_i(r_str, non_sep_i); + if sep_i == -1 { + return ".".to_string(); + } + if sep_i == 0 { + return MAIN_SEPARATOR.to_string(); + } + let non_sep_i2 = last_non_sep_i_before(r_str, sep_i); + if non_sep_i2 != -1 { + return r_str[..(non_sep_i2 + 1) as usize].to_string(); + } else { + return MAIN_SEPARATOR.to_string(); + } } - let non_sep_i = last_non_sep_i(r_str); - if non_sep_i == -1 { - return CString::new(MAIN_SEPARATOR.to_string()).unwrap().into_raw(); - } - let sep_i = last_sep_i(r_str, non_sep_i); - if sep_i == -1 { - return CString::new(".").unwrap().into_raw(); - } - if sep_i == 0 { - return CString::new(MAIN_SEPARATOR.to_string()).unwrap().into_raw(); - } - let non_sep_i2 = last_non_sep_i_before(r_str, sep_i); - if non_sep_i2 != -1 { - return CString::new(&r_str[..(non_sep_i2 + 1) as usize]).unwrap().into_raw(); - } else { - return CString::new(MAIN_SEPARATOR.to_string()).unwrap().into_raw(); - } +} + +#[test] +fn returns_dot_for_empty_string(){ + assert_eq!(rust::dirname(""), ".".to_string()); }