Struct CleanDir

Source
pub struct CleanDir<T: DirStructureItem>(pub T);
Expand description

A newtype that will clean the directory it is written to, before writing the value.

This is useful when we want to write a directory structure, but we want to make sure that the directory is clean before writing it, so that there are no old files / directories left in it.

use std::path::Path;

use dir_structure::DirStructureItem;
use dir_structure::CleanDir;

#[derive(dir_structure::DirStructure)]
struct Dir {
   #[dir_structure(path = "f.txt")]
   f: String,
}

fn main() -> Result<(), Box<dyn std::error::Error>> {
    let d = Path::new("dir");
    std::fs::create_dir_all(&d)?;
    std::fs::write(d.join("f.txt"), "Hello, world!")?;
    std::fs::write(d.join("f2.txt"), "Hello, world! (2)")?;
    let dir = Dir::read(&d)?;
    assert_eq!(dir.f, "Hello, world!");
    assert_eq!(std::fs::read_to_string(d.join("f2.txt"))?, "Hello, world! (2)");
    CleanDir(dir).write(&d)?;
    assert_eq!(std::fs::read_to_string(d.join("f.txt"))?, "Hello, world!");
    assert!(!d.join("f2.txt").exists());
    Ok(())
}

Tuple Fields§

§0: T

Trait Implementations§

Source§

impl<'a, T> FromRefForWriter<'a> for CleanDir<T>
where T: DirStructureItem + 'a,

Source§

type Inner = T

The inner type to cast.
Source§

type Wr = CleanDirRefWr<'a, T>

The reference type to cast to.
Source§

fn from_ref_for_writer(value: &'a Self::Inner) -> Self::Wr

Casts the reference to the inner type to a WriteTo reference type.
Source§

impl<T> NewtypeToInner for CleanDir<T>

Source§

type Inner = T

The inner type.
Source§

fn into_inner(self) -> Self::Inner

Converts the newtype to its inner type.
Source§

impl<T> ReadFrom for CleanDir<T>

Source§

fn read_from(path: &Path) -> Result<Self>
where Self: Sized,

Reads the structure from the specified path, which can be either a file or a directory.
Source§

impl<T> WriteTo for CleanDir<T>

Source§

fn write_to(&self, path: &Path) -> Result<()>

Writes the structure to the specified path.

Auto Trait Implementations§

§

impl<T> Freeze for CleanDir<T>
where T: Freeze,

§

impl<T> RefUnwindSafe for CleanDir<T>
where T: RefUnwindSafe,

§

impl<T> Send for CleanDir<T>
where T: Send,

§

impl<T> Sync for CleanDir<T>
where T: Sync,

§

impl<T> Unpin for CleanDir<T>
where T: Unpin,

§

impl<T> UnwindSafe for CleanDir<T>
where T: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> DirStructureItem for T
where T: ReadFrom + WriteTo,

Source§

fn read(path: impl AsRef<Path>) -> Result<Self>
where Self: Sized,

Uses the ReadFrom implementation to read the structure from disk, from the specified path.
Source§

fn write(&self, path: impl AsRef<Path>) -> Result<()>

Uses the WriteTo implementation to write the structure to disk at the specified path.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

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

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.