#relative-path #path #path-slash

sugar_path

Sugar functions for manipulating paths

14 releases (3 stable)

1.2.0 Apr 9, 2024
0.0.12 Feb 28, 2023
0.0.9 Nov 15, 2022
0.0.5 May 29, 2022
0.0.3 Mar 19, 2022

#120 in Filesystem

Download history 1627/week @ 2024-07-21 1102/week @ 2024-07-28 1157/week @ 2024-08-04 1108/week @ 2024-08-11 1115/week @ 2024-08-18 1060/week @ 2024-08-25 1807/week @ 2024-09-01 1684/week @ 2024-09-08 1089/week @ 2024-09-15 1380/week @ 2024-09-22 1070/week @ 2024-09-29 1276/week @ 2024-10-06 1456/week @ 2024-10-13 1412/week @ 2024-10-20 1589/week @ 2024-10-27 1870/week @ 2024-11-03

6,470 downloads per month
Used in 59 crates (15 directly)

MIT license

22KB
272 lines

sugar_path

document crate version MIT

Sugar functions for manipulating paths.

Main functionalities

  • SugarPath::as_path makes it easy to convert T: Deref<Target = str> to Path and allows you to use methods of SugarPath on &str or String directly.
use std::path::Path;
use sugar_path::SugarPath;
assert_eq!("foo".as_path().join("bar"), Path::new("foo/bar"));
assert_eq!("foo/./bar/../baz".normalize(), "foo/baz".as_path());
use sugar_path::SugarPath;
#[cfg(target_family = "unix")]
let p = "./hello/world".as_path();
#[cfg(target_family = "windows")]
let p = ".\\hello\\world".as_path();
assert_eq!(p.to_slash().unwrap(), "./hello/world");
assert_eq!(p.to_slash_lossy(), "./hello/world");
use std::path::Path;
use sugar_path::SugarPath;
assert_eq!("foo/./bar/../baz".normalize(), "foo/baz".as_path());
  • SugarPath::relative allows you to get the relative path from the given path to the target path.
use sugar_path::SugarPath;
assert_eq!("/base".relative("/base/project"), "..".as_path());
assert_eq!("/base".relative("/var/lib"), "../../base".as_path());
use sugar_path::SugarPath;
let cwd = std::env::current_dir().unwrap();
assert_eq!("hello/world".absolutize(), cwd.join("hello").join("world"));
use sugar_path::SugarPath;
#[cfg(target_family = "unix")]
{
  assert_eq!("./world".absolutize_with("/hello"), "/hello/world".as_path());
  assert_eq!("../world".absolutize_with("/hello"), "/world".as_path());
}
#[cfg(target_family = "windows")]
{
  assert_eq!(".\\world".absolutize_with("C:\\hello"), "C:\\hello\\world".as_path());
  assert_eq!("..\\world".absolutize_with("C:\\hello"), "C:\\world".as_path());
}
  • For more details, please refer to the SugarPath.

No runtime deps