Struct simple_fs::SPath

source ·
pub struct SPath { /* private fields */ }
Expand description

An SPath can be constructed from a Path, io::DirEntry, or walkdir::DirEntry and guarantees the following:

  • The full path is UTF-8 valid.
  • It has a file name.

Implementations§

source§

impl SPath

Constructors that guarantees the SPath contract describe in the struct

source

pub fn from_path(path: impl AsRef<Path>) -> Result<Self>

Constructor from Path and all impl AsRef.

Returns Result

Note: Prefer the use of the SPath::try_from(…) when available as it might avoid a PathBuf allocation.

source

pub fn from_path_ok(path: impl AsRef<Path>) -> Option<Self>

Constructor for anything that impl AsRef.

Returns Option. Useful for filter_map.

Note: Favor using concrete type functions like SPath::from_path_buf_ok when available.

source

pub fn from_path_buf_ok(path_buf: PathBuf) -> Option<Self>

Constructor from PathBuf returning an Option, none if validation fail. Useful for filter_map.

source

pub fn from_fs_entry_ok(fs_entry: DirEntry) -> Option<Self>

Constructor from fs::DirEntry returning an Option, none if validation fail. Useful for filter_map.

source

pub fn from_walkdir_entry_ok(wd_entry: DirEntry) -> Option<Self>

Constructor from walkdir::DirEntry returning an Option, none if validation fail. Useful for filter_map.

source§

impl SPath

Public return Path constructs.

source

pub fn into_path_buf(self) -> PathBuf

source

pub fn path(&self) -> &Path

source§

impl SPath

Public file components as str methods.

source

pub fn to_str(&self) -> &str

Returns the &str of the path.

NOTE: We know that this must be Some() since the SPath constructor guarantees that the path.to_str() is valid.

source

pub fn file_name(&self) -> &str

Returns the &str representation of the file_name()

NOTE: According to the constructors’ contract, this method will never return “” as a file_name() is required for construction.

source

pub fn stem(&self) -> &str

Returns the &str representation of the file_name()

NOTE: According to the constructors’ contract, this method will never return “” as a file_name() is required for construction, and stem is always part of it.

source

pub fn extension(&self) -> Option<&str>

Returns the Option<&str> representation of the extension().

NOTE: This should never be a non-UTF-8 string as the path was validated during SPath construction.

Trait Implementations§

source§

impl AsRef<Path> for SPath

source§

fn as_ref(&self) -> &Path

Converts this type into a shared reference of the (usually inferred) input type.
source§

impl Debug for SPath

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Display for SPath

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl From<&SPath> for String

source§

fn from(val: &SPath) -> Self

Converts to this type from the input type.
source§

impl From<SPath> for String

source§

fn from(val: SPath) -> Self

Converts to this type from the input type.
source§

impl TryFrom<&String> for SPath

§

type Error = Error

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

fn try_from(path: &String) -> Result<SPath>

Performs the conversion.
source§

impl TryFrom<&str> for SPath

§

type Error = Error

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

fn try_from(path: &str) -> Result<SPath>

Performs the conversion.
source§

impl TryFrom<DirEntry> for SPath

§

type Error = Error

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

fn try_from(fs_entry: DirEntry) -> Result<SPath>

Performs the conversion.
source§

impl TryFrom<DirEntry> for SPath

§

type Error = Error

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

fn try_from(wd_entry: DirEntry) -> Result<SPath>

Performs the conversion.
source§

impl TryFrom<PathBuf> for SPath

§

type Error = Error

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

fn try_from(path_buf: PathBuf) -> Result<SPath>

Performs the conversion.
source§

impl TryFrom<SPath> for SFile

§

type Error = Error

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

fn try_from(spath: SPath) -> Result<SFile>

Performs the conversion.
source§

impl TryFrom<String> for SPath

§

type Error = Error

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

fn try_from(path: String) -> Result<SPath>

Performs the conversion.

Auto Trait Implementations§

§

impl RefUnwindSafe for SPath

§

impl Send for SPath

§

impl Sync for SPath

§

impl Unpin for SPath

§

impl UnwindSafe for SPath

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> 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> ToString for T
where T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
source§

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

§

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>,

§

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.