Trait typed_path::Utf8Component 
source · pub trait Utf8Component<'a>: AsRef<str> + Clone + Debug + PartialEq + Eq + PartialOrd + Ord + Sealed {
    // Required methods
    fn as_str(&self) -> &'a str;
    fn is_root(&self) -> bool;
    fn is_normal(&self) -> bool;
    fn is_parent(&self) -> bool;
    fn is_current(&self) -> bool;
    fn is_valid(&self) -> bool;
    fn len(&self) -> usize;
    fn root() -> Self;
    fn parent() -> Self;
    fn current() -> Self;
    // Provided method
    fn is_empty(&self) -> bool { ... }
}Expand description
Interface representing a component in a Utf8Path
Required Methods§
sourcefn is_root(&self) -> bool
 
fn is_root(&self) -> bool
Returns true if this component is the root component, meaning there are no more components before this one
Use cases are for the root dir separator on Windows and Unix as
well as Windows std::path::PrefixComponent
§Examples
/my/../path/./here.txt has the components on Unix of
- Utf8UnixComponent::RootDir-- is_root() == true
- Utf8UnixComponent::ParentDir-- is_root() == false
- Utf8UnixComponent::CurDir-- is_root() == false
- Utf8UnixComponent::Normal("here.txt")-- is_root() == false
sourcefn is_normal(&self) -> bool
 
fn is_normal(&self) -> bool
Returns true if this component represents a normal part of the path
§Examples
/my/../path/./here.txt has the components on Unix of
- Utf8UnixComponent::RootDir-- is_normal() == false
- Utf8UnixComponent::ParentDir-- is_normal() == false
- Utf8UnixComponent::CurDir-- is_normal() == false
- Utf8UnixComponent::Normal("here.txt")-- is_normal() == true
sourcefn is_parent(&self) -> bool
 
fn is_parent(&self) -> bool
Returns true if this component represents a relative representation of a parent directory
§Examples
/my/../path/./here.txt has the components on Unix of
- Utf8UnixComponent::RootDir-- is_parent() == false
- Utf8UnixComponent::ParentDir-- is_parent() == true
- Utf8UnixComponent::CurDir-- is_parent() == false
- Utf8UnixComponent::Normal("here.txt")-- is_parent() == false
sourcefn is_current(&self) -> bool
 
fn is_current(&self) -> bool
Returns true if this component represents a relative representation of the current directory
§Examples
/my/../path/./here.txt has the components on Unix of
- Utf8UnixComponent::RootDir-- is_current() == false
- Utf8UnixComponent::ParentDir-- is_current() == false
- Utf8UnixComponent::CurDir-- is_current() == true
- Utf8UnixComponent::Normal("here.txt")-- is_current() == false
sourcefn is_valid(&self) -> bool
 
fn is_valid(&self) -> bool
Returns true if this component is valid. A component can only be invalid if it represents a normal component with characters that are disallowed by the encoding.
§Examples
use typed_path::{Utf8Component, Utf8UnixComponent, Utf8WindowsComponent};
assert!(Utf8UnixComponent::RootDir.is_valid());
assert!(Utf8UnixComponent::ParentDir.is_valid());
assert!(Utf8UnixComponent::CurDir.is_valid());
assert!(Utf8UnixComponent::Normal("abc").is_valid());
assert!(!Utf8UnixComponent::Normal("\0").is_valid());
assert!(Utf8WindowsComponent::RootDir.is_valid());
assert!(Utf8WindowsComponent::ParentDir.is_valid());
assert!(Utf8WindowsComponent::CurDir.is_valid());
assert!(Utf8WindowsComponent::Normal("abc").is_valid());
assert!(!Utf8WindowsComponent::Normal("|").is_valid());sourcefn root() -> Self
 
fn root() -> Self
Returns a root Utf8Component.
sourcefn parent() -> Self
 
fn parent() -> Self
Returns a parent directory Utf8Component.
sourcefn current() -> Self
 
fn current() -> Self
Returns a current directory Utf8Component.