[][src]Struct async_std::fs::OpenOptions

pub struct OpenOptions(_);

A builder for opening files with configurable options.

Files can be opened in read and/or write mode.

The append option opens files in a special writing mode that moves the file cursor to the end of file before every write operation.

It is also possible to truncate the file right after opening, to create a file if it doesn't exist yet, or to always create a new file with create_new.

This type is an async version of std::fs::OpenOptions.

Examples

Open a file for reading:

use async_std::fs::OpenOptions;

let file = OpenOptions::new()
    .read(true)
    .open("a.txt")
    .await?;

Open a file for both reading and writing, and create it if it doesn't exist yet:

use async_std::fs::OpenOptions;

let file = OpenOptions::new()
    .read(true)
    .write(true)
    .create(true)
    .open("a.txt")
    .await?;

Methods

impl OpenOptions[src]

pub fn new() -> OpenOptions[src]

Creates a blank set of options.

All options are initially set to false.

Examples

use async_std::fs::OpenOptions;

let file = OpenOptions::new()
    .read(true)
    .open("a.txt")
    .await?;

pub fn read(&mut self, read: bool) -> &mut OpenOptions[src]

Configures the option for read mode.

When set to true, this option means the file will be readable after opening.

Examples

use async_std::fs::OpenOptions;

let file = OpenOptions::new()
    .read(true)
    .open("a.txt")
    .await?;

pub fn write(&mut self, write: bool) -> &mut OpenOptions[src]

Configures the option for write mode.

When set to true, this option means the file will be writable after opening.

If the file already exists, write calls on it will overwrite the previous contents without truncating it.

Examples

use async_std::fs::OpenOptions;

let file = OpenOptions::new()
    .write(true)
    .open("a.txt")
    .await?;

pub fn append(&mut self, append: bool) -> &mut OpenOptions[src]

Configures the option for append mode.

When set to true, this option means the file will be writable after opening and the file cursor will be moved to the end of file before every write operaiton.

Examples

use async_std::fs::OpenOptions;

let file = OpenOptions::new()
    .append(true)
    .open("a.txt")
    .await?;

pub fn truncate(&mut self, truncate: bool) -> &mut OpenOptions[src]

Configures the option for truncating the previous file.

When set to true, the file will be truncated to the length of 0 bytes.

The file must be opened in write or append mode for truncation to work.

Examples

use async_std::fs::OpenOptions;

let file = OpenOptions::new()
    .write(true)
    .truncate(true)
    .open("a.txt")
    .await?;

pub fn create(&mut self, create: bool) -> &mut OpenOptions[src]

Configures the option for creating a new file if it doesn't exist.

When set to true, this option means a new file will be created if it doesn't exist.

The file must be opened in write or append mode for file creation to work.

Examples

use async_std::fs::OpenOptions;

let file = OpenOptions::new()
    .write(true)
    .create(true)
    .open("a.txt")
    .await?;

pub fn create_new(&mut self, create_new: bool) -> &mut OpenOptions[src]

Configures the option for creating a new file or failing if it already exists.

When set to true, this option means a new file will be created, or the open operation will fail if the file already exists.

The file must be opened in write or append mode for file creation to work.

Examples

use async_std::fs::OpenOptions;

let file = OpenOptions::new()
    .write(true)
    .create_new(true)
    .open("a.txt")
    .await?;

pub fn open<P: AsRef<Path>>(
    &self,
    path: P
) -> impl Future<Output = Result<File>>
[src]

Opens a file with the configured options.

Errors

An error will be returned in the following situations:

  • The file does not exist and neither create nor create_new were set.
  • The file's parent directory does not exist.
  • The current process lacks permissions to open the file in the configured mode.
  • The file already exists and create_new was set.
  • Invalid combination of options was used, like truncate was set but write wasn't, or none of read, write, and append modes was set.
  • An OS-level occurred, like too many files are open or the file name is too long.
  • Some other I/O error occurred.

Examples

use async_std::fs::OpenOptions;

let file = OpenOptions::new()
    .read(true)
    .open("a.txt")
    .await?;

Trait Implementations

impl Clone for OpenOptions[src]

impl Debug for OpenOptions[src]

impl Default for OpenOptions[src]

impl OpenOptionsExt for OpenOptions[src]

Auto Trait Implementations

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.