[llvm] [ArrayRef] Add constructor from iterator_range<U*> (NFC). (PR #137796)
Florian Hahn via llvm-commits
llvm-commits at lists.llvm.org
Wed Apr 30 02:15:29 PDT 2025
================
@@ -149,6 +149,13 @@ namespace llvm {
* = nullptr)
: Data(Vec.data()), Length(Vec.size()) {}
+ /// Construct an ArrayRef<T> from iterator_range<U*>. This uses SFINAE
+ /// to ensure that this is only used for iterator ranges over plain pointer
+ /// iterators.
+ template <typename U, typename = std::enable_if_t<std::is_same_v<U *, T *>>>
----------------
fhahn wrote:
Yep, this should use `is_convertible` I think, to support creating `ArrayRef<const X>` from `iterator_range<X *>`, also added a test
https://github.com/llvm/llvm-project/pull/137796
More information about the llvm-commits
mailing list