[−][src]Trait std::str::pattern::Pattern   
🔬 This is a nightly-only experimental API. (pattern #27721)
API not fully fleshed out and ready to be stabilized
A string pattern.
A Pattern<'a> expresses that the implementing type
can be used as a string pattern for searching in a &'a str.
For example, both 'a' and "aa" are patterns that
would match at index 1 in the string "baaaab".
The trait itself acts as a builder for an associated
Searcher type, which does the actual work of finding
occurrences of the pattern in a string.
Associated Types
type Searcher: Searcher<'a>
🔬 This is a nightly-only experimental API. (pattern #27721)
API not fully fleshed out and ready to be stabilized
Associated searcher for this pattern
Required methods
fn into_searcher(self, haystack: &'a str) -> Self::Searcher
🔬 This is a nightly-only experimental API. (pattern #27721)
API not fully fleshed out and ready to be stabilized
Constructs the associated searcher from
self and the haystack to search in.
Provided methods
fn is_contained_in(self, haystack: &'a str) -> bool
🔬 This is a nightly-only experimental API. (pattern #27721)
API not fully fleshed out and ready to be stabilized
Checks whether the pattern matches anywhere in the haystack
fn is_prefix_of(self, haystack: &'a str) -> bool
🔬 This is a nightly-only experimental API. (pattern #27721)
API not fully fleshed out and ready to be stabilized
Checks whether the pattern matches at the front of the haystack
fn strip_prefix_of(self, haystack: &'a str) -> Option<&'a str>
🔬 This is a nightly-only experimental API. (pattern #27721)
API not fully fleshed out and ready to be stabilized
Removes the pattern from the front of haystack, if it matches.
fn is_suffix_of(self, haystack: &'a str) -> bool where
    Self::Searcher: ReverseSearcher<'a>, 
Self::Searcher: ReverseSearcher<'a>,
🔬 This is a nightly-only experimental API. (pattern #27721)
API not fully fleshed out and ready to be stabilized
Checks whether the pattern matches at the back of the haystack
fn strip_suffix_of(self, haystack: &'a str) -> Option<&'a str> where
    Self::Searcher: ReverseSearcher<'a>, 
Self::Searcher: ReverseSearcher<'a>,
🔬 This is a nightly-only experimental API. (pattern #27721)
API not fully fleshed out and ready to be stabilized
Removes the pattern from the back of haystack, if it matches.
Implementors
impl<'a> Pattern<'a> for char[src]
Searches for chars that are equal to a given char.
Examples
assert_eq!("Hello world".find('o'), Some(4));Run
type Searcher = CharSearcher<'a>
🔬 This is a nightly-only experimental API. (pattern #27721)
API not fully fleshed out and ready to be stabilized
fn into_searcher(self, haystack: &'a str) -> <char as Pattern<'a>>::Searcher[src]
fn is_contained_in(self, haystack: &'a str) -> bool[src]
fn is_prefix_of(self, haystack: &'a str) -> bool[src]
fn strip_prefix_of(self, haystack: &'a str) -> Option<&'a str>[src]
fn is_suffix_of(self, haystack: &'a str) -> bool where
    <char as Pattern<'a>>::Searcher: ReverseSearcher<'a>, [src]
<char as Pattern<'a>>::Searcher: ReverseSearcher<'a>,
fn strip_suffix_of(self, haystack: &'a str) -> Option<&'a str> where
    <char as Pattern<'a>>::Searcher: ReverseSearcher<'a>, [src]
<char as Pattern<'a>>::Searcher: ReverseSearcher<'a>,
impl<'a, 'b> Pattern<'a> for &'b str[src]
Non-allocating substring search.
Will handle the pattern "" as returning empty matches at each character
boundary.
Examples
assert_eq!("Hello world".find("world"), Some(6));Run
type Searcher = StrSearcher<'a, 'b>
🔬 This is a nightly-only experimental API. (pattern #27721)
API not fully fleshed out and ready to be stabilized
fn into_searcher(self, haystack: &'a str) -> StrSearcher<'a, 'b>[src]
fn is_prefix_of(self, haystack: &'a str) -> bool[src]
🔬 This is a nightly-only experimental API. (pattern #27721)
API not fully fleshed out and ready to be stabilized
Checks whether the pattern matches at the front of the haystack.
fn strip_prefix_of(self, haystack: &'a str) -> Option<&'a str>[src]
🔬 This is a nightly-only experimental API. (pattern #27721)
API not fully fleshed out and ready to be stabilized
Removes the pattern from the front of haystack, if it matches.
fn is_suffix_of(self, haystack: &'a str) -> bool[src]
🔬 This is a nightly-only experimental API. (pattern #27721)
API not fully fleshed out and ready to be stabilized
Checks whether the pattern matches at the back of the haystack.
fn strip_suffix_of(self, haystack: &'a str) -> Option<&'a str>[src]
🔬 This is a nightly-only experimental API. (pattern #27721)
API not fully fleshed out and ready to be stabilized
Removes the pattern from the back of haystack, if it matches.
impl<'a, 'b> Pattern<'a> for &'b String[src]
A convenience impl that delegates to the impl for &str.
Examples
assert_eq!(String::from("Hello world").find("world"), Some(6));Run
type Searcher = <&'b str as Pattern<'a>>::Searcher
🔬 This is a nightly-only experimental API. (pattern #27721)
API not fully fleshed out and ready to be stabilized
fn into_searcher(self, haystack: &'a str) -> <&'b str as Pattern<'a>>::Searcher[src]
fn is_contained_in(self, haystack: &'a str) -> bool[src]
fn is_prefix_of(self, haystack: &'a str) -> bool[src]
fn strip_prefix_of(self, haystack: &'a str) -> Option<&'a str>[src]
fn is_suffix_of(self, haystack: &'a str) -> bool[src]
fn strip_suffix_of(self, haystack: &'a str) -> Option<&'a str>[src]
impl<'a, 'b> Pattern<'a> for &'b [char][src]
Searches for chars that are equal to any of the chars in the slice.
Examples
assert_eq!("Hello world".find(&['l', 'l'] as &[_]), Some(2)); assert_eq!("Hello world".find(&['l', 'l'][..]), Some(2));Run
type Searcher = CharSliceSearcher<'a, 'b>
🔬 This is a nightly-only experimental API. (pattern #27721)
API not fully fleshed out and ready to be stabilized
fn into_searcher(self, haystack: &'a str) -> CharSliceSearcher<'a, 'b>[src]
fn is_contained_in(self, haystack: &'a str) -> bool[src]
fn is_prefix_of(self, haystack: &'a str) -> bool[src]
fn strip_prefix_of(self, haystack: &'a str) -> Option<&'a str>[src]
fn is_suffix_of(self, haystack: &'a str) -> bool where
    CharSliceSearcher<'a, 'b>: ReverseSearcher<'a>, [src]
CharSliceSearcher<'a, 'b>: ReverseSearcher<'a>,
fn strip_suffix_of(self, haystack: &'a str) -> Option<&'a str> where
    CharSliceSearcher<'a, 'b>: ReverseSearcher<'a>, [src]
CharSliceSearcher<'a, 'b>: ReverseSearcher<'a>,
impl<'a, 'b, 'c> Pattern<'a> for &'c &'b str[src]
Delegates to the &str impl.
type Searcher = StrSearcher<'a, 'b>
🔬 This is a nightly-only experimental API. (pattern #27721)
API not fully fleshed out and ready to be stabilized
fn into_searcher(self, haystack: &'a str) -> StrSearcher<'a, 'b>[src]
fn is_contained_in(self, haystack: &'a str) -> bool[src]
fn is_prefix_of(self, haystack: &'a str) -> bool[src]
fn strip_prefix_of(self, haystack: &'a str) -> Option<&'a str>[src]
fn is_suffix_of(self, haystack: &'a str) -> bool where
    StrSearcher<'a, 'b>: ReverseSearcher<'a>, [src]
StrSearcher<'a, 'b>: ReverseSearcher<'a>,
fn strip_suffix_of(self, haystack: &'a str) -> Option<&'a str> where
    StrSearcher<'a, 'b>: ReverseSearcher<'a>, [src]
StrSearcher<'a, 'b>: ReverseSearcher<'a>,
impl<'a, F> Pattern<'a> for F where
    F: FnMut(char) -> bool, [src]
F: FnMut(char) -> bool,
Searches for chars that match the given predicate.
Examples
assert_eq!("Hello world".find(char::is_uppercase), Some(0)); assert_eq!("Hello world".find(|c| "aeiou".contains(c)), Some(1));Run
type Searcher = CharPredicateSearcher<'a, F>
🔬 This is a nightly-only experimental API. (pattern #27721)
API not fully fleshed out and ready to be stabilized
fn into_searcher(self, haystack: &'a str) -> CharPredicateSearcher<'a, F>[src]
fn is_contained_in(self, haystack: &'a str) -> bool[src]
fn is_prefix_of(self, haystack: &'a str) -> bool[src]
fn strip_prefix_of(self, haystack: &'a str) -> Option<&'a str>[src]
fn is_suffix_of(self, haystack: &'a str) -> bool where
    CharPredicateSearcher<'a, F>: ReverseSearcher<'a>, [src]
CharPredicateSearcher<'a, F>: ReverseSearcher<'a>,
fn strip_suffix_of(self, haystack: &'a str) -> Option<&'a str> where
    CharPredicateSearcher<'a, F>: ReverseSearcher<'a>, [src]
CharPredicateSearcher<'a, F>: ReverseSearcher<'a>,