blob: 1fb14c4907f5b583c97848eb5e6c76eb1ab9e628 [file] [log] [blame]
use crate::errors::{Error, ErrorKind};
use crate::tokio::File;
use std::io;
use std::path::Path;
use tokio::fs::OpenOptions as TokioOpenOptions;
/// Options and flags which can be used to configure how a file is opened.
///
/// This is a wrapper around [`tokio::fs::OpenOptions`].
#[derive(Clone, Debug, Default)]
#[cfg_attr(docsrs, doc(cfg(feature = "tokio")))]
pub struct OpenOptions {
tokio: TokioOpenOptions,
}
impl OpenOptions {
/// Creates a blank new set of options ready for configuration.
///
/// All options are initially set to `false`.
///
/// This is a wrapped version of [`tokio::fs::OpenOptions::new`]
///
/// # Examples
///
/// ```no_run
/// use fs_err::tokio::OpenOptions;
///
/// let mut options = OpenOptions::new();
/// let future = options.read(true).open("foo.txt");
/// ```
pub fn new() -> OpenOptions {
OpenOptions {
tokio: TokioOpenOptions::new(),
}
}
/// Sets the option for read access.
///
/// Wrapper for [`tokio::fs::OpenOptions::read`].
pub fn read(&mut self, read: bool) -> &mut OpenOptions {
self.tokio.read(read);
self
}
/// Sets the option for write access.
///
/// Wrapper for [`tokio::fs::OpenOptions::write`].
pub fn write(&mut self, write: bool) -> &mut OpenOptions {
self.tokio.write(write);
self
}
/// Sets the option for the append mode.
///
/// Wrapper for [`tokio::fs::OpenOptions::append`].
pub fn append(&mut self, append: bool) -> &mut OpenOptions {
self.tokio.append(append);
self
}
/// Sets the option for truncating a previous file.
///
/// Wrapper for [`tokio::fs::OpenOptions::truncate`].
pub fn truncate(&mut self, truncate: bool) -> &mut OpenOptions {
self.tokio.truncate(truncate);
self
}
/// Sets the option for creating a new file.
///
/// Wrapper for [`tokio::fs::OpenOptions::create`].
pub fn create(&mut self, create: bool) -> &mut OpenOptions {
self.tokio.create(create);
self
}
/// Sets the option to always create a new file.
///
/// Wrapper for [`tokio::fs::OpenOptions::create_new`].
pub fn create_new(&mut self, create_new: bool) -> &mut OpenOptions {
self.tokio.create_new(create_new);
self
}
/// Opens a file at `path` with the options specified by `self`.
///
/// Wrapper for [`tokio::fs::OpenOptions::open`].
pub async fn open(&self, path: impl AsRef<Path>) -> io::Result<File> {
let path = path.as_ref();
self.tokio
.open(path)
.await
.map(|f| File::from_parts(f, path))
.map_err(|err| Error::build(err, ErrorKind::OpenFile, path))
}
}
#[cfg(unix)]
impl OpenOptions {
/// Sets the mode bits that a new file will be created with.
///
/// Wrapper for [`tokio::fs::OpenOptions::mode`].
pub fn mode(&mut self, mode: u32) -> &mut OpenOptions {
self.tokio.mode(mode);
self
}
/// Passes custom flags to the `flags` argument of `open`.
///
/// Wrapper for [`tokio::fs::OpenOptions::custom_flags`].
pub fn custom_flags(&mut self, flags: i32) -> &mut OpenOptions {
self.tokio.custom_flags(flags);
self
}
}
impl From<std::fs::OpenOptions> for OpenOptions {
fn from(std: std::fs::OpenOptions) -> Self {
OpenOptions { tokio: std.into() }
}
}
impl From<TokioOpenOptions> for OpenOptions {
fn from(tokio: TokioOpenOptions) -> Self {
OpenOptions { tokio }
}
}