1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127
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 }
}
}