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
use super::OpenFuture; use std::convert::From; use std::fs::OpenOptions as StdOpenOptions; use std::path::Path; /// Options and flags which can be used to configure how a file is opened. /// /// This is a specialized version of [`std::fs::OpenOptions`] for usage from /// the Tokio runtime. /// /// `From<std::fs::OpenOptions>` is implemented for more advanced configuration /// than the methods provided here. /// /// [`std::fs::OpenOptions`]: https://doc.rust-lang.org/std/fs/struct.OpenOptions.html #[derive(Clone, Debug)] pub struct OpenOptions(StdOpenOptions); impl OpenOptions { /// Creates a blank new set of options ready for configuration. /// /// All options are initially set to `false`. /// /// # Examples /// /// ```ignore /// use tokio::fs::OpenOptions; /// /// let mut options = OpenOptions::new(); /// let future = options.read(true).open("foo.txt"); /// ``` pub fn new() -> OpenOptions { OpenOptions(StdOpenOptions::new()) } /// See the underlying [`read`] call for details. /// /// [`read`]: https://doc.rust-lang.org/std/fs/struct.OpenOptions.html#method.read pub fn read(&mut self, read: bool) -> &mut OpenOptions { self.0.read(read); self } /// See the underlying [`write`] call for details. /// /// [`write`]: https://doc.rust-lang.org/std/fs/struct.OpenOptions.html#method.write pub fn write(&mut self, write: bool) -> &mut OpenOptions { self.0.write(write); self } /// See the underlying [`append`] call for details. /// /// [`append`]: https://doc.rust-lang.org/std/fs/struct.OpenOptions.html#method.append pub fn append(&mut self, append: bool) -> &mut OpenOptions { self.0.append(append); self } /// See the underlying [`truncate`] call for details. /// /// [`truncate`]: https://doc.rust-lang.org/std/fs/struct.OpenOptions.html#method.truncate pub fn truncate(&mut self, truncate: bool) -> &mut OpenOptions { self.0.truncate(truncate); self } /// See the underlying [`create`] call for details. /// /// [`create`]: https://doc.rust-lang.org/std/fs/struct.OpenOptions.html#method.create pub fn create(&mut self, create: bool) -> &mut OpenOptions { self.0.create(create); self } /// See the underlying [`create_new`] call for details. /// /// [`create_new`]: https://doc.rust-lang.org/std/fs/struct.OpenOptions.html#method.create_new pub fn create_new(&mut self, create_new: bool) -> &mut OpenOptions { self.0.create_new(create_new); self } /// Opens a file at `path` with the options specified by `self`. /// /// # Errors /// /// `OpenOptionsFuture` results in an error if called from outside of the /// Tokio runtime or if the underlying [`open`] call results in an error. /// /// [`open`]: https://doc.rust-lang.org/std/fs/struct.OpenOptions.html#method.open pub fn open<P>(&self, path: P) -> OpenFuture<P> where P: AsRef<Path> + Send + 'static, { OpenFuture::new(self.0.clone(), path) } } impl From<StdOpenOptions> for OpenOptions { fn from(options: StdOpenOptions) -> OpenOptions { OpenOptions(options) } }