88 lines
1.8 KiB
C++
88 lines
1.8 KiB
C++
/*
|
|
* Copyright (C) 2018-2023 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: MIT
|
|
*
|
|
*/
|
|
|
|
#pragma once
|
|
#include <iterator>
|
|
|
|
namespace NEO {
|
|
|
|
template <typename DataType>
|
|
struct Range {
|
|
using iterator = DataType *;
|
|
using const_iterator = const DataType *;
|
|
using reverse_iterator = std::reverse_iterator<iterator>;
|
|
using const_reverse_iterator = std::reverse_iterator<const_iterator>;
|
|
|
|
Range()
|
|
: begIt(nullptr), endIt(nullptr) {
|
|
}
|
|
|
|
explicit Range(DataType *base, size_t count = 1)
|
|
: begIt(base), endIt(base + count) {
|
|
}
|
|
|
|
template <typename SequentialContainerT, typename BeginT = decltype(((SequentialContainerT *)nullptr)->size())>
|
|
Range(SequentialContainerT &container)
|
|
: Range(&*container.begin(), container.size()) {
|
|
}
|
|
|
|
template <typename T, size_t size>
|
|
Range(T (&base)[size])
|
|
: Range(&base[0], size) {
|
|
}
|
|
Range &operator=(const Range &) = delete;
|
|
|
|
iterator begin() {
|
|
return begIt;
|
|
}
|
|
|
|
iterator end() {
|
|
return endIt;
|
|
}
|
|
|
|
const_iterator begin() const {
|
|
return begIt;
|
|
}
|
|
|
|
const_iterator end() const {
|
|
return endIt;
|
|
}
|
|
|
|
reverse_iterator rbegin() {
|
|
return reverse_iterator(end());
|
|
}
|
|
|
|
const_reverse_iterator rbegin() const {
|
|
return const_reverse_iterator(end());
|
|
}
|
|
|
|
reverse_iterator rend() {
|
|
return reverse_iterator(end()) + (endIt - begIt);
|
|
}
|
|
|
|
const_reverse_iterator rend() const {
|
|
return const_reverse_iterator(end()) + (endIt - begIt);
|
|
}
|
|
|
|
bool empty() const {
|
|
return begIt == endIt;
|
|
}
|
|
|
|
size_t size() const {
|
|
return endIt - begIt;
|
|
}
|
|
|
|
iterator begIt;
|
|
iterator endIt;
|
|
};
|
|
|
|
template <typename T>
|
|
inline Range<T> createRange(T *base, size_t count) {
|
|
return Range<T>(base, count);
|
|
}
|
|
} // namespace NEO
|