Trait typed_path::Component

source ·
pub trait Component<'a>: AsRef<[u8]> + Clone + Debug + PartialEq + Eq + PartialOrd + Ord + Sealed {
    // Required methods
    fn as_bytes(&self) -> &'a [u8] ;
    fn is_root(&self) -> bool;
    fn is_normal(&self) -> bool;
    fn len(&self) -> usize;

    // Provided method
    fn is_empty(&self) -> bool { ... }
}
Expand description

Interface representing a component in a Path

Required Methods§

source

fn as_bytes(&self) -> &'a [u8]

Extracts the underlying [[u8]] slice

source

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

  • UnixComponent::RootDir - is_root() == true
  • UnixComponent::ParentDir - is_root() == false
  • UnixComponent::CurDir - is_root() == false
  • UnixComponent::Normal(b"here.txt") - is_root() == false
source

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

  • UnixComponent::RootDir - is_normal() == false
  • UnixComponent::ParentDir - is_normal() == false
  • UnixComponent::CurDir - is_normal() == false
  • UnixComponent::Normal(b"here.txt") - is_normal() == true
source

fn len(&self) -> usize

Returns size of component in bytes

Provided Methods§

source

fn is_empty(&self) -> bool

Returns true if component represents an empty byte slice

Implementors§

source§

impl<'a> Component<'a> for UnixComponent<'a>

source§

impl<'a> Component<'a> for WindowsComponent<'a>