|
|
@ -1,6 +1,5 @@
|
|
|
|
use crate::path::{Path, PathBuf};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
use crate::io;
|
|
|
|
use crate::io;
|
|
|
|
|
|
|
|
use crate::path::{Path, PathBuf};
|
|
|
|
use crate::task::blocking;
|
|
|
|
use crate::task::blocking;
|
|
|
|
|
|
|
|
|
|
|
|
/// Returns the canonical form of a path.
|
|
|
|
/// Returns the canonical form of a path.
|
|
|
@ -32,8 +31,6 @@ use crate::task::blocking;
|
|
|
|
/// # Ok(()) }) }
|
|
|
|
/// # Ok(()) }) }
|
|
|
|
/// ```
|
|
|
|
/// ```
|
|
|
|
pub async fn canonicalize<P: AsRef<Path>>(path: P) -> io::Result<PathBuf> {
|
|
|
|
pub async fn canonicalize<P: AsRef<Path>>(path: P) -> io::Result<PathBuf> {
|
|
|
|
let path: PathBuf = path.as_ref().to_owned();
|
|
|
|
let path = path.as_ref().to_owned();
|
|
|
|
Ok(blocking::spawn(async move { std::fs::canonicalize(&path) })
|
|
|
|
blocking::spawn(async move { std::fs::canonicalize(&path).map(Into::into) }).await
|
|
|
|
.await?
|
|
|
|
|
|
|
|
.into())
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|