A class suitable for use with std::experimental::search that delegates the search operation to the standard library's std::search.
default_searcher
is CopyConstructible and CopyAssignable.
ForwardIterator pat_last,
Constructs a default_searcher
by storing copies of pat_first, pat_last, and pred.
Any exceptions thrown by the copy constructors of BinaryPredicate
or ForwardIterator
.
template< class ForwardIterator2 >
ForwardIterator2 operator()( ForwardIterator2 first, ForwardIterator2 last ) const;
std::pair<ForwardIterator2, ForwardIterator2>
The member function called by std::experimental::search to perform a search with this searcher.
Equivalent to std::search(first, last, pat_first, pat_last, pred);.
(until C++17)Returns a pair of iterators i, j
, where i
is std::search(first, last, pat_first, pat_last, pred) and j
is std::next(i, std::distance(pat_first, pat_last)) unless std::search
returned last (no match), in which case j
equals last as well.
Iterator to the first position in [
first,
last)
where a subsequence that compares equal to [
pat_first,
pat_last)
as defined by pred is located, or a copy of last otherwise.
A pair of iterators to the first and one past last positions in [
first,
last)
where a subsequence that compares equal to [
pat_first,
pat_last)
as defined by pred is located, or a pair of copies of last otherwise.
default_searcher<ForwardIterator, BinaryPredicate> make_default_searcher(
ForwardIterator pat_first,
ForwardIterator pat_last,
Helper function that constructs a std::experimental::default_searcher
using template argument deduction. Equivalent to return default_searcher<ForwardIterator, BinaryPredicate>(pat_first, pat_last, pred);
A default_searcher
constructed with the arguments pat_first, pat_last, pred.
#include <experimental/algorithm> #include <experimental/functional> #include <iostream> #include <string> int main() { std::string in = "Lorem ipsum dolor sit amet, consectetur adipiscing elit," " sed do eiusmod tempor incididunt ut labore et dolore magna aliqua"; std::string needle = "pisci"; auto it = std::experimental::search(in.begin(), in.end(), std::experimental::make_default_searcher( needle.begin(), needle.end())); if (it != in.end()) std::cout << "The string " << needle << " found at offset " << it - in.begin() << '\n'; else std::cout << "The string " << needle << " not found\n"; }
Output:
The string pisci found at offset 43[edit] See also searches for the first occurrence of a range of elements
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4