[llvm] r242823 - Add some utilities to iterator_range for trimming a range and constructing one from a container.
Justin Bogner via llvm-commits
llvm-commits at lists.llvm.org
Tue Jun 12 13:55:22 PDT 2018
David Blaikie <dblaikie at gmail.com> writes:
> Author: dblaikie
> Date: Tue Jul 21 13:37:12 2015
> New Revision: 242823
>
> URL: http://llvm.org/viewvc/llvm-project?rev=242823&view=rev
> Log:
> Add some utilities to iterator_range for trimming a range and
> constructing one from a container.
>
> To be used in clang in a follow-up commit.
>
> Modified:
> llvm/trunk/include/llvm/ADT/iterator_range.h
>
> Modified: llvm/trunk/include/llvm/ADT/iterator_range.h
> URL:
> http://llvm.org/viewvc/llvm-project/llvm/trunk/include/llvm/ADT/iterator_range.h?rev=242823&r1=242822&r2=242823&view=diff
> ==============================================================================
>
> --- llvm/trunk/include/llvm/ADT/iterator_range.h (original)
> +++ llvm/trunk/include/llvm/ADT/iterator_range.h Tue Jul 21 13:37:12 2015
> @@ -20,6 +20,7 @@
> #define LLVM_ADT_ITERATOR_RANGE_H
>
> #include <utility>
> +#include <iterator>
>
> namespace llvm {
>
> @@ -32,6 +33,12 @@ class iterator_range {
> IteratorT begin_iterator, end_iterator;
>
> public:
> + //TODO: Add SFINAE to test that the Container's iterators match the range's
> + // iterators.
> + template <typename Container>
> + iterator_range(Container &&c)
> + //TODO: Consider ADL/non-member begin/end calls.
> + : begin_iterator(c.begin()), end_iterator(c.end()) {}
> iterator_range(IteratorT begin_iterator, IteratorT end_iterator)
> : begin_iterator(std::move(begin_iterator)),
> end_iterator(std::move(end_iterator)) {}
> @@ -51,6 +58,11 @@ template <class T> iterator_range<T> mak
> template <typename T> iterator_range<T> make_range(std::pair<T, T> p) {
> return iterator_range<T>(std::move(p.first), std::move(p.second));
> }
> +
> +template<typename T>
> +iterator_range<decltype(begin(std::declval<T>()))> drop_begin(T &&t, int n) {
> + return make_range(std::next(begin(t), n), end(t));
Sorry for the commit necromancy, but should these be std::begin and
std::end, or perhaps have locally scoped using directives? As is this
doesn't seem to work for llvm:: types like SmallVector.
> +}
> }
>
> #endif
>
>
> _______________________________________________
> llvm-commits mailing list
> llvm-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits
More information about the llvm-commits
mailing list