1 //===----------------- Self contained ArrayRef type -------------*- C++ -*-===//
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7 //===----------------------------------------------------------------------===//
11 #include <stddef.h> // For size_t.
13 namespace __llvm_libc {
16 // The implementations of ArrayRef and MutualArrayRef in this file are based
17 // on the implementations of the types with the same names in
18 // llvm/ADT/ArrayRef.h. The implementations in this file are of a limited
19 // functionality, but can be extended in an as needed basis.
21 template <typename T> class ArrayRef {
23 using iterator = const T *;
26 const T *Data = nullptr;
34 ArrayRef(const Array<T, N> &Arr) : Data(Arr.Data), Length(N) {}
36 // Construct an ArrayRef from a single element.
37 explicit ArrayRef(const T &OneElt) : Data(&OneElt), Length(1) {}
39 // Construct an ArrayRef from a pointer and length.
40 ArrayRef(const T *data, size_t length) : Data(data), Length(length) {}
42 // Construct an ArrayRef from a range.
43 ArrayRef(const T *begin, const T *end) : Data(begin), Length(end - begin) {}
45 // Construct an ArrayRef from a C array.
47 constexpr ArrayRef(const T (&Arr)[N]) : Data(Arr), Length(N) {}
49 iterator begin() const { return Data; }
50 iterator end() const { return Data + Length; }
52 bool empty() const { return Length == 0; }
54 const T *data() const { return Data; }
56 size_t size() const { return Length; }
58 const T &operator[](size_t Index) const { return Data[Index]; }
61 template <typename T> class MutableArrayRef : public ArrayRef<T> {
66 template <size_t N> MutableArrayRef(Array<T, N> &Arr) : ArrayRef<T>(Arr) {}
68 // Construct from a single element.
69 explicit MutableArrayRef(T &OneElt) : ArrayRef<T>(OneElt) {}
71 // Construct from a pointer and length.
72 MutableArrayRef(T *data, size_t length) : ArrayRef<T>(data, length) {}
74 // Construct from a range.
75 MutableArrayRef(T *begin, T *end) : ArrayRef<T>(begin, end) {}
77 // Construct from a C array.
79 constexpr MutableArrayRef(T (&Arr)[N]) : ArrayRef<T>(Arr) {}
81 T *data() const { return const_cast<T *>(ArrayRef<T>::data()); }
83 iterator begin() const { return data(); }
84 iterator end() const { return data() + size(); }
86 T &operator[](size_t Index) const { return data()[Index]; }
90 } // namespace __llvm_libc