mirror of
https://github.com/async-rs/async-std.git
synced 2025-01-19 20:13:51 +00:00
add os::windows::symlink_{dir,file}
This commit is contained in:
parent
355e2eded8
commit
2c9b558d14
3 changed files with 58 additions and 0 deletions
|
@ -3,11 +3,13 @@
|
||||||
//! This module is an async version of [`std::fs`].
|
//! This module is an async version of [`std::fs`].
|
||||||
//!
|
//!
|
||||||
//! [`os::unix::fs`]: ../os/unix/fs/index.html
|
//! [`os::unix::fs`]: ../os/unix/fs/index.html
|
||||||
|
//! [`os::windows::fs`]: ../os/windows/fs/index.html
|
||||||
//! [`std::fs`]: https://doc.rust-lang.org/std/fs/index.html
|
//! [`std::fs`]: https://doc.rust-lang.org/std/fs/index.html
|
||||||
//!
|
//!
|
||||||
//! # Platform-specific extensions
|
//! # Platform-specific extensions
|
||||||
//!
|
//!
|
||||||
//! * Unix: use the [`os::unix::fs`] module.
|
//! * Unix: use the [`os::unix::fs`] module.
|
||||||
|
//! * Windows: use the [`os::windows::fs`] module.
|
||||||
//!
|
//!
|
||||||
//! # Examples
|
//! # Examples
|
||||||
//!
|
//!
|
||||||
|
|
55
src/os/windows/fs.rs
Normal file
55
src/os/windows/fs.rs
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
//! Windows-specific filesystem extensions.
|
||||||
|
|
||||||
|
use crate::io;
|
||||||
|
use crate::path::Path;
|
||||||
|
use crate::task::spawn_blocking;
|
||||||
|
|
||||||
|
/// Creates a new directory symbolic link on the filesystem.
|
||||||
|
///
|
||||||
|
/// The `dst` path will be a directory symbolic link pointing to the `src` path.
|
||||||
|
///
|
||||||
|
/// This function is an async version of [`std::os::windows::fs::symlink_dir`].
|
||||||
|
///
|
||||||
|
/// [`std::os::windows::fs::symlink_dir`]: https://doc.rust-lang.org/std/os/windows/fs/fn.symlink_dir.html
|
||||||
|
///
|
||||||
|
/// # Examples
|
||||||
|
///
|
||||||
|
/// ```no_run
|
||||||
|
/// # fn main() -> std::io::Result<()> { async_std::task::block_on(async {
|
||||||
|
/// #
|
||||||
|
/// use async_std::os::windows::fs::symlink_dir;
|
||||||
|
///
|
||||||
|
/// symlink_dir("a", "b").await?;
|
||||||
|
/// #
|
||||||
|
/// # Ok(()) }) }
|
||||||
|
/// ```
|
||||||
|
pub async fn symlink_dir<P: AsRef<Path>, Q: AsRef<Path>>(src: P, dst: Q) -> io::Result<()> {
|
||||||
|
let src = src.as_ref().to_owned();
|
||||||
|
let dst = dst.as_ref().to_owned();
|
||||||
|
spawn_blocking(move || std::os::windows::fs::symlink_dir(&src, &dst)).await
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Creates a new file symbolic link on the filesystem.
|
||||||
|
///
|
||||||
|
/// The `dst` path will be a file symbolic link pointing to the `src` path.
|
||||||
|
///
|
||||||
|
/// This function is an async version of [`std::os::windows::fs::symlink_file`].
|
||||||
|
///
|
||||||
|
/// [`std::os::windows::fs::symlink_file`]: https://doc.rust-lang.org/std/os/windows/fs/fn.symlink_file.html
|
||||||
|
///
|
||||||
|
/// # Examples
|
||||||
|
///
|
||||||
|
/// ```no_run
|
||||||
|
/// # fn main() -> std::io::Result<()> { async_std::task::block_on(async {
|
||||||
|
/// #
|
||||||
|
/// use async_std::os::windows::fs::symlink_file;
|
||||||
|
///
|
||||||
|
/// symlink_file("a.txt", "b.txt").await?;
|
||||||
|
/// #
|
||||||
|
/// # Ok(()) }) }
|
||||||
|
/// ```
|
||||||
|
pub async fn symlink_file<P: AsRef<Path>, Q: AsRef<Path>>(src: P, dst: Q) -> io::Result<()> {
|
||||||
|
let src = src.as_ref().to_owned();
|
||||||
|
let dst = dst.as_ref().to_owned();
|
||||||
|
spawn_blocking(move || std::os::windows::fs::symlink_file(&src, &dst)).await
|
||||||
|
}
|
|
@ -2,4 +2,5 @@
|
||||||
|
|
||||||
cfg_std! {
|
cfg_std! {
|
||||||
pub mod io;
|
pub mod io;
|
||||||
|
pub mod fs;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue