aboutsummaryrefslogtreecommitdiff
path: root/include/gsl/multi_span
diff options
context:
space:
mode:
Diffstat (limited to 'include/gsl/multi_span')
-rw-r--r--include/gsl/multi_span266
1 files changed, 143 insertions, 123 deletions
diff --git a/include/gsl/multi_span b/include/gsl/multi_span
index 3a2d982..f1a909e 100644
--- a/include/gsl/multi_span
+++ b/include/gsl/multi_span
@@ -23,6 +23,7 @@
#include <algorithm> // for transform, lexicographical_compare
#include <array> // for array
+#include <cassert>
#include <cstddef> // for ptrdiff_t, size_t, nullptr_t
#include <cstdint> // for PTRDIFF_MAX
#include <functional> // for divides, multiplies, minus, negate, plus
@@ -48,19 +49,13 @@
#pragma warning(disable : 26473) // in some instantiations we cast to the same type
#pragma warning(disable : 26490) // TODO: bug in parser - attributes and templates
#pragma warning(disable : 26465) // TODO: bug - suppression does not work on template functions
-#pragma warning(disable : 4996) // use of function or classes marked [[deprecated]]
#if _MSC_VER < 1910
#pragma push_macro("constexpr")
#define constexpr /*constexpr*/
-#endif // _MSC_VER < 1910
-#endif // _MSC_VER
-
-#if __clang__ || __GNUC__
-#pragma GCC diagnostic push
-#pragma GCC diagnostic ignored "-Wdeprecated-declarations"
-#endif
+#endif // _MSC_VER < 1910
+#endif // _MSC_VER
// GCC 7 does not like the signed unsigned missmatch (size_t ptrdiff_t)
// While there is a conversion from signed to unsigned, it happens at
@@ -81,18 +76,18 @@ namespace gsl
namespace details
{
template <typename SizeType>
- struct [[deprecated]] SizeTypeTraits
+ struct SizeTypeTraits
{
static const SizeType max_value = std::numeric_limits<SizeType>::max();
};
template <typename... Ts>
- class [[deprecated]] are_integral : public std::integral_constant<bool, true>
+ class are_integral : public std::integral_constant<bool, true>
{
};
template <typename T, typename... Ts>
- class [[deprecated]] are_integral<T, Ts...>
+ class are_integral<T, Ts...>
: public std::integral_constant<bool,
std::is_integral<T>::value && are_integral<Ts...>::value>
{
@@ -100,7 +95,8 @@ namespace details
} // namespace details
template <std::size_t Rank>
-class [[deprecated]] multi_span_index final {
+class multi_span_index final
+{
static_assert(Rank > 0, "Rank must be greater than 0!");
template <std::size_t OtherRank>
@@ -115,7 +111,7 @@ public:
constexpr multi_span_index() noexcept {}
- constexpr multi_span_index(const value_type(&values)[Rank]) noexcept
+ constexpr multi_span_index(const value_type (&values)[Rank]) noexcept
{
GSL_SUPPRESS(bounds.1) // NO-FORMAT: attribute
GSL_SUPPRESS(bounds.3) // NO-FORMAT: attribute
@@ -143,7 +139,7 @@ public:
// Preconditions: component_idx < rank
GSL_SUPPRESS(bounds.2) // NO-FORMAT: attribute
GSL_SUPPRESS(bounds.4) // NO-FORMAT: attribute
- constexpr const_reference operator[](std::size_t component_idx) const
+ constexpr const_reference operator[](std::size_t component_idx) const
{
Expects(component_idx < Rank); // Component index must be less than rank
return elems[component_idx];
@@ -156,7 +152,10 @@ public:
return std::equal(elems, elems + rank, rhs.elems);
}
- constexpr bool operator!=(const multi_span_index& rhs) const { return !(*this == rhs); }
+ constexpr bool operator!=(const multi_span_index& rhs) const
+ {
+ return !(*this == rhs);
+ }
constexpr multi_span_index operator+() const noexcept { return *this; }
@@ -185,7 +184,8 @@ public:
{
GSL_SUPPRESS(bounds.1) // NO-FORMAT: attribute
GSL_SUPPRESS(bounds.3) // NO-FORMAT: attribute
- std::transform(elems, elems + rank, rhs.elems, elems, std::plus<value_type>{});
+ std::transform(elems, elems + rank, rhs.elems, elems,
+ std::plus<value_type>{});
return *this;
}
@@ -240,7 +240,7 @@ private:
#if !defined(_MSC_VER) || _MSC_VER >= 1910
-struct [[deprecated]] static_bounds_dynamic_range_t
+struct static_bounds_dynamic_range_t
{
template <typename T, typename = std::enable_if_t<std::is_integral<T>::value>>
constexpr operator T() const noexcept
@@ -288,22 +288,25 @@ constexpr static_bounds_dynamic_range_t dynamic_range{};
const std::ptrdiff_t dynamic_range = -1;
#endif
-struct [[deprecated]] generalized_mapping_tag
+struct generalized_mapping_tag
+{
+};
+struct contiguous_mapping_tag : generalized_mapping_tag
{
};
-struct[[deprecated]] contiguous_mapping_tag : generalized_mapping_tag{};
namespace details
{
template <std::ptrdiff_t Left, std::ptrdiff_t Right>
- struct [[deprecated]] LessThan
+ struct LessThan
{
static const bool value = Left < Right;
};
template <std::ptrdiff_t... Ranges>
- struct [[deprecated]] BoundsRanges {
+ struct BoundsRanges
+ {
using size_type = std::ptrdiff_t;
static const size_type Depth = 0;
static const size_type DynamicNum = 0;
@@ -342,7 +345,7 @@ namespace details
};
template <std::ptrdiff_t... RestRanges>
- struct[[deprecated]] BoundsRanges<dynamic_range, RestRanges...> : BoundsRanges<RestRanges...>
+ struct BoundsRanges<dynamic_range, RestRanges...> : BoundsRanges<RestRanges...>
{
using Base = BoundsRanges<RestRanges...>;
using size_type = std::ptrdiff_t;
@@ -355,9 +358,8 @@ namespace details
size_type m_bound;
public:
- GSL_SUPPRESS(
- f.23) // NO-FORMAT: attribute // this pointer type is cannot be assigned nullptr - issue in not_null
- GSL_SUPPRESS(bounds.1) // NO-FORMAT: attribute
+ GSL_SUPPRESS(f.23) // NO-FORMAT: attribute // this pointer type is cannot be assigned nullptr - issue in not_null
+ GSL_SUPPRESS(bounds.1) // NO-FORMAT: attribute
constexpr BoundsRanges(const std::ptrdiff_t* const arr)
: Base(arr + 1), m_bound(*arr * this->Base::totalSize())
{
@@ -368,13 +370,13 @@ namespace details
template <std::ptrdiff_t OtherRange, std::ptrdiff_t... RestOtherRanges>
constexpr BoundsRanges(const BoundsRanges<OtherRange, RestOtherRanges...>& other,
- bool /* firstLevel */ = true)
+ bool /* firstLevel */ = true)
: Base(static_cast<const BoundsRanges<RestOtherRanges...>&>(other), false)
, m_bound(other.totalSize())
{}
template <typename T, std::size_t Dim = 0>
- constexpr void serialize(T & arr) const
+ constexpr void serialize(T& arr) const
{
arr[Dim] = elementNum();
this->Base::template serialize<T, Dim + 1>(arr);
@@ -398,19 +400,19 @@ namespace details
return cur < m_bound ? cur + last : -1;
}
- GSL_SUPPRESS(
- c.128) // NO-FORMAT: attribute // no pointers to BoundsRanges should be ever used
- constexpr size_type totalSize() const noexcept { return m_bound; }
+ GSL_SUPPRESS(c.128) // NO-FORMAT: attribute // no pointers to BoundsRanges should be ever used
+ constexpr size_type totalSize() const noexcept
+ {
+ return m_bound;
+ }
- GSL_SUPPRESS(
- c.128) // NO-FORMAT: attribute // no pointers to BoundsRanges should be ever used
+ GSL_SUPPRESS(c.128) // NO-FORMAT: attribute // no pointers to BoundsRanges should be ever used
constexpr size_type elementNum() const noexcept
{
return totalSize() / this->Base::totalSize();
}
- GSL_SUPPRESS(
- c.128) // NO-FORMAT: attribute // no pointers to BoundsRanges should be ever used
+ GSL_SUPPRESS(c.128) // NO-FORMAT: attribute // no pointers to BoundsRanges should be ever used
constexpr size_type elementNum(std::size_t dim) const noexcept
{
if (dim > 0)
@@ -427,7 +429,7 @@ namespace details
};
template <std::ptrdiff_t CurRange, std::ptrdiff_t... RestRanges>
- struct[[deprecated]] BoundsRanges<CurRange, RestRanges...> : BoundsRanges<RestRanges...>
+ struct BoundsRanges<CurRange, RestRanges...> : BoundsRanges<RestRanges...>
{
using Base = BoundsRanges<RestRanges...>;
using size_type = std::ptrdiff_t;
@@ -442,7 +444,7 @@ namespace details
template <std::ptrdiff_t OtherRange, std::ptrdiff_t... RestOtherRanges>
constexpr BoundsRanges(const BoundsRanges<OtherRange, RestOtherRanges...>& other,
- bool firstLevel = true)
+ bool firstLevel = true)
: Base(static_cast<const BoundsRanges<RestOtherRanges...>&>(other), false)
{
GSL_SUPPRESS(type.4) // NO-FORMAT: attribute // TODO: false positive
@@ -450,7 +452,7 @@ namespace details
}
template <typename T, std::size_t Dim = 0>
- constexpr void serialize(T & arr) const
+ constexpr void serialize(T& arr) const
{
arr[Dim] = elementNum();
this->Base::template serialize<T, Dim + 1>(arr);
@@ -459,11 +461,12 @@ namespace details
template <typename T, std::size_t Dim = 0>
constexpr size_type linearize(const T& arr) const
{
- GSL_SUPPRESS(bounds.4) // NO-FORMAT: attribute
+ GSL_SUPPRESS(bounds.4) // NO-FORMAT: attribute
Expects(arr[Dim] >= 0 && arr[Dim] < CurrentRange); // Index is out of range
- GSL_SUPPRESS(bounds.4) // NO-FORMAT: attribute
+ GSL_SUPPRESS(bounds.4) // NO-FORMAT: attribute
const ptrdiff_t d = arr[Dim];
- return this->Base::totalSize() * d + this->Base::template linearize<T, Dim + 1>(arr);
+ return this->Base::totalSize() * d +
+ this->Base::template linearize<T, Dim + 1>(arr);
}
template <typename T, std::size_t Dim = 0>
@@ -475,19 +478,19 @@ namespace details
return this->Base::totalSize() * arr[Dim] + last;
}
- GSL_SUPPRESS(
- c.128) // NO-FORMAT: attribute // no pointers to BoundsRanges should be ever used
+ GSL_SUPPRESS(c.128) // NO-FORMAT: attribute // no pointers to BoundsRanges should be ever used
constexpr size_type totalSize() const noexcept
{
return CurrentRange * this->Base::totalSize();
}
- GSL_SUPPRESS(
- c.128) // NO-FORMAT: attribute // no pointers to BoundsRanges should be ever used
- constexpr size_type elementNum() const noexcept { return CurrentRange; }
+ GSL_SUPPRESS(c.128) // NO-FORMAT: attribute // no pointers to BoundsRanges should be ever used
+ constexpr size_type elementNum() const noexcept
+ {
+ return CurrentRange;
+ }
- GSL_SUPPRESS(
- c.128) // NO-FORMAT: attribute // no pointers to BoundsRanges should be ever used
+ GSL_SUPPRESS(c.128) // NO-FORMAT: attribute // no pointers to BoundsRanges should be ever used
constexpr size_type elementNum(std::size_t dim) const noexcept
{
if (dim > 0)
@@ -503,40 +506,43 @@ namespace details
};
template <typename SourceType, typename TargetType>
- struct[[deprecated]] BoundsRangeConvertible
+ struct BoundsRangeConvertible
: public std::integral_constant<bool, (SourceType::TotalSize >= TargetType::TotalSize ||
TargetType::TotalSize == dynamic_range ||
SourceType::TotalSize == dynamic_range ||
- TargetType::TotalSize == 0)>{};
+ TargetType::TotalSize == 0)>
+ {
+ };
template <typename TypeChain>
- struct [[deprecated]] TypeListIndexer {
+ struct TypeListIndexer
+ {
const TypeChain& obj_;
- constexpr TypeListIndexer(const TypeChain& obj) : obj_(obj) {}
+ TypeListIndexer(const TypeChain& obj) : obj_(obj) {}
template <std::size_t N>
- constexpr const TypeChain& getObj(std::true_type)
+ const TypeChain& getObj(std::true_type)
{
return obj_;
}
template <std::size_t N, typename MyChain = TypeChain,
typename MyBase = typename MyChain::Base>
- constexpr auto getObj(std::false_type)
- ->decltype(TypeListIndexer<MyBase>(static_cast<const MyBase&>(obj_)).template get<N>())
+ auto getObj(std::false_type)
+ -> decltype(TypeListIndexer<MyBase>(static_cast<const MyBase&>(obj_)).template get<N>())
{
return TypeListIndexer<MyBase>(static_cast<const MyBase&>(obj_)).template get<N>();
}
template <std::size_t N>
- constexpr auto get()->decltype(getObj<N - 1>(std::integral_constant<bool, N == 0>()))
+ auto get() -> decltype(getObj<N - 1>(std::integral_constant<bool, N == 0>()))
{
return getObj<N - 1>(std::integral_constant<bool, N == 0>());
}
};
template <typename TypeChain>
- constexpr TypeListIndexer<TypeChain> createTypeListIndexer(const TypeChain& obj)
+ TypeListIndexer<TypeChain> createTypeListIndexer(const TypeChain& obj)
{
return TypeListIndexer<TypeChain>(obj);
}
@@ -549,23 +555,24 @@ namespace details
for (std::size_t i = 0; i < Rank - 1; ++i)
{
GSL_SUPPRESS(bounds.4) // NO-FORMAT: attribute
- ret[i] = other[i + 1];
+ ret[i] = other[i + 1];
}
return ret;
}
} // namespace details
template <typename IndexType>
-class [[deprecated]] bounds_iterator;
+class bounds_iterator;
template <std::ptrdiff_t... Ranges>
-class [[deprecated]] static_bounds {
+class static_bounds
+{
public:
static_bounds(const details::BoundsRanges<Ranges...>&) {}
};
template <std::ptrdiff_t FirstRange, std::ptrdiff_t... RestRanges>
-class[[deprecated]] static_bounds<FirstRange, RestRanges...>
+class static_bounds<FirstRange, RestRanges...>
{
using MyRanges = details::BoundsRanges<FirstRange, RestRanges...>;
@@ -597,10 +604,10 @@ public:
template <std::size_t Rank, typename SourceType, typename TargetType,
typename Ret = BoundsRangeConvertible2<typename SourceType::Base,
typename TargetType::Base, Rank>>
- static auto helpBoundsRangeConvertible(SourceType, TargetType, std::true_type)->Ret;
+ static auto helpBoundsRangeConvertible(SourceType, TargetType, std::true_type) -> Ret;
template <std::size_t Rank, typename SourceType, typename TargetType>
- static auto helpBoundsRangeConvertible(SourceType, TargetType, ...)->std::false_type;
+ static auto helpBoundsRangeConvertible(SourceType, TargetType, ...) -> std::false_type;
template <typename SourceType, typename TargetType, std::size_t Rank>
struct BoundsRangeConvertible2
@@ -717,7 +724,10 @@ public:
return !(*this == rhs);
}
- constexpr const_iterator begin() const noexcept { return const_iterator(*this, index_type{}); }
+ constexpr const_iterator begin() const noexcept
+ {
+ return const_iterator(*this, index_type{});
+ }
constexpr const_iterator end() const noexcept
{
@@ -726,7 +736,7 @@ public:
};
template <std::size_t Rank>
-class [[deprecated]] strided_bounds {
+class strided_bounds {
template <std::size_t OtherRank>
friend class strided_bounds;
@@ -750,13 +760,14 @@ public:
constexpr strided_bounds& operator=(const strided_bounds&) noexcept = default;
- constexpr strided_bounds(const value_type(&values)[rank], index_type strides)
+ constexpr strided_bounds(const value_type (&values)[rank], index_type strides)
: m_extents(values), m_strides(std::move(strides))
{}
constexpr strided_bounds(const index_type& extents, const index_type& strides) noexcept
: m_extents(extents), m_strides(strides)
- {}
+ {
+ }
constexpr index_type strides() const noexcept { return m_strides; }
@@ -828,14 +839,21 @@ private:
};
template <typename T>
-struct[[deprecated]] is_bounds : std::integral_constant<bool, false>{};
+struct is_bounds : std::integral_constant<bool, false>
+{
+};
template <std::ptrdiff_t... Ranges>
-struct[[deprecated]] is_bounds<static_bounds<Ranges...>> : std::integral_constant<bool, true>{};
+struct is_bounds<static_bounds<Ranges...>> : std::integral_constant<bool, true>
+{
+};
template <std::size_t Rank>
-struct[[deprecated]] is_bounds<strided_bounds<Rank>> : std::integral_constant<bool, true>{};
+struct is_bounds<strided_bounds<Rank>> : std::integral_constant<bool, true>
+{
+};
template <typename IndexType>
-class [[deprecated]] bounds_iterator {
+class bounds_iterator
+{
public:
static const std::size_t rank = IndexType::rank;
using iterator_category = std::random_access_iterator_tag;
@@ -956,6 +974,7 @@ public:
return curr_ == rhs.curr_;
}
+
constexpr bool operator!=(const bounds_iterator& rhs) const noexcept { return !(*this == rhs); }
constexpr bool operator<(const bounds_iterator& rhs) const noexcept
@@ -969,15 +988,16 @@ public:
constexpr bool operator>=(const bounds_iterator& rhs) const noexcept { return !(rhs > *this); }
- void swap(bounds_iterator & rhs) noexcept
+ void swap(bounds_iterator& rhs) noexcept
{
std::swap(boundary_, rhs.boundary_);
std::swap(curr_, rhs.curr_);
}
private:
+
GSL_SUPPRESS(bounds.4) // NO-FORMAT: attribute
- constexpr bool less(index_type & one, index_type & other) const noexcept
+ constexpr bool less(index_type& one, index_type& other) const noexcept
{
for (std::size_t i = 0; i < rank; ++i)
{
@@ -1072,17 +1092,17 @@ namespace details
} // namespace details
template <typename Span>
-class [[deprecated]] contiguous_span_iterator;
+class contiguous_span_iterator;
template <typename Span>
-class [[deprecated]] general_span_iterator;
+class general_span_iterator;
template <std::ptrdiff_t DimSize = dynamic_range>
-struct [[deprecated]] dim_t
+struct dim_t
{
static const std::ptrdiff_t value = DimSize;
};
template <>
-struct [[deprecated]] dim_t<dynamic_range>
+struct dim_t<dynamic_range>
{
static const std::ptrdiff_t value = dynamic_range;
const std::ptrdiff_t dvalue;
@@ -1103,30 +1123,28 @@ constexpr dim_t<N> dim(std::ptrdiff_t n) noexcept
template <typename ValueType, std::ptrdiff_t FirstDimension = dynamic_range,
std::ptrdiff_t... RestDimensions>
-class [[deprecated("gsl::multi_span is deprecated because it is not in the C++ Core Guidelines")]] multi_span;
-
+class multi_span;
template <typename ValueType, std::size_t Rank>
-class [[deprecated("gsl::strided_span is deprecated because it is not in the C++ Core Guidelines")]] strided_span;
+class strided_span;
namespace details
{
template <typename T, typename = std::true_type>
- struct [[deprecated]] SpanTypeTraits
+ struct SpanTypeTraits
{
using value_type = T;
using size_type = std::size_t;
};
template <typename Traits>
- struct [[deprecated]] SpanTypeTraits<
- Traits, typename std::is_reference<typename Traits::span_traits&>::type>
+ struct SpanTypeTraits<Traits, typename std::is_reference<typename Traits::span_traits&>::type>
{
using value_type = typename Traits::span_traits::value_type;
using size_type = typename Traits::span_traits::size_type;
};
template <typename T, std::ptrdiff_t... Ranks>
- struct [[deprecated]] SpanArrayTraits
+ struct SpanArrayTraits
{
using type = multi_span<T, Ranks...>;
using value_type = T;
@@ -1135,7 +1153,7 @@ namespace details
using reference = T&;
};
template <typename T, std::ptrdiff_t N, std::ptrdiff_t... Ranks>
- struct [[deprecated]] SpanArrayTraits<T[N], Ranks...> : SpanArrayTraits<T, Ranks..., N>
+ struct SpanArrayTraits<T[N], Ranks...> : SpanArrayTraits<T, Ranks..., N>
{
};
@@ -1159,7 +1177,7 @@ namespace details
totalSize, std::integral_constant<bool, BoundsType::dynamic_rank == 1>());
}
- struct [[deprecated]] Sep
+ struct Sep
{
};
@@ -1182,35 +1200,36 @@ namespace details
}
template <typename... Dimensions>
- struct [[deprecated]] static_as_multi_span_static_bounds_helper
+ struct static_as_multi_span_static_bounds_helper
{
using type = static_bounds<(Dimensions::value)...>;
};
template <typename T>
- struct [[deprecated]] is_multi_span_oracle : std::false_type
+ struct is_multi_span_oracle : std::false_type
{
};
template <typename ValueType, std::ptrdiff_t FirstDimension, std::ptrdiff_t... RestDimensions>
- struct [[deprecated]] is_multi_span_oracle<multi_span<ValueType, FirstDimension, RestDimensions...>>
+ struct is_multi_span_oracle<multi_span<ValueType, FirstDimension, RestDimensions...>>
: std::true_type
{
};
template <typename ValueType, std::ptrdiff_t Rank>
- struct [[deprecated]] is_multi_span_oracle<strided_span<ValueType, Rank>> : std::true_type
+ struct is_multi_span_oracle<strided_span<ValueType, Rank>> : std::true_type
{
};
template <typename T>
- struct [[deprecated]] is_multi_span : is_multi_span_oracle<std::remove_cv_t<T>>
+ struct is_multi_span : is_multi_span_oracle<std::remove_cv_t<T>>
{
};
} // namespace details
template <typename ValueType, std::ptrdiff_t FirstDimension, std::ptrdiff_t... RestDimensions>
-class [[deprecated("gsl::multi_span is deprecated because it is not in the C++ Core Guidelines")]] multi_span {
+class multi_span
+{
// TODO do we still need this?
template <typename ValueType2, std::ptrdiff_t FirstDimension2,
std::ptrdiff_t... RestDimensions2>
@@ -1243,7 +1262,8 @@ private:
public:
// default constructor - same as constructing from nullptr_t
GSL_SUPPRESS(type.6) // NO-FORMAT: attribute // TODO: false positive
- constexpr multi_span() noexcept : multi_span(nullptr, bounds_type{})
+ constexpr multi_span() noexcept
+ : multi_span(nullptr, bounds_type{})
{
static_assert(bounds_type::dynamic_rank != 0 ||
(bounds_type::dynamic_rank == 0 && bounds_type::static_size == 0),
@@ -1253,7 +1273,8 @@ public:
// construct from nullptr - get an empty multi_span
GSL_SUPPRESS(type.6) // NO-FORMAT: attribute // TODO: false positive
- constexpr multi_span(std::nullptr_t) noexcept : multi_span(nullptr, bounds_type{})
+ constexpr multi_span(std::nullptr_t) noexcept
+ : multi_span(nullptr, bounds_type{})
{
static_assert(bounds_type::dynamic_rank != 0 ||
(bounds_type::dynamic_rank == 0 && bounds_type::static_size == 0),
@@ -1277,7 +1298,8 @@ public:
// construct from a single element
GSL_SUPPRESS(type.6) // NO-FORMAT: attribute // TODO: false positive
- constexpr multi_span(reference data) noexcept : multi_span(&data, bounds_type{1})
+ constexpr multi_span(reference data) noexcept
+ : multi_span(&data, bounds_type{1})
{
static_assert(bounds_type::dynamic_rank > 0 || bounds_type::static_size == 0 ||
bounds_type::static_size == 1,
@@ -1286,14 +1308,17 @@ public:
}
// prevent constructing from temporaries for single-elements
- constexpr multi_span(value_type &&) = delete;
+ constexpr multi_span(value_type&&) = delete;
// construct from pointer + length
GSL_SUPPRESS(type.6) // NO-FORMAT: attribute // TODO: false positive
- constexpr multi_span(pointer ptr, size_type size) : multi_span(ptr, bounds_type{size}) {}
+ constexpr multi_span(pointer ptr, size_type size)
+ : multi_span(ptr, bounds_type{size})
+ {}
// construct from pointer + length - multidimensional
- constexpr multi_span(pointer data, bounds_type bounds) : data_(data), bounds_(std::move(bounds))
+ constexpr multi_span(pointer data, bounds_type bounds)
+ : data_(data), bounds_(std::move(bounds))
{
Expects((bounds_.size() > 0 && data != nullptr) || bounds_.size() == 0);
}
@@ -1311,7 +1336,7 @@ public:
// construct from n-dimensions static array
template <typename T, std::size_t N, typename Helper = details::SpanArrayTraits<T, N>>
- constexpr multi_span(T(&arr)[N])
+ constexpr multi_span(T (&arr)[N])
: multi_span(reinterpret_cast<pointer>(arr), bounds_type{typename Helper::bounds_type{}})
{
static_assert(std::is_convertible<typename Helper::value_type(*)[], value_type(*)[]>::value,
@@ -1332,7 +1357,7 @@ public:
// construct from std::array
template <typename T, std::size_t N>
- constexpr multi_span(std::array<T, N> & arr)
+ constexpr multi_span(std::array<T, N>& arr)
: multi_span(arr.data(), bounds_type{static_bounds<N>{}})
{
static_assert(
@@ -1356,7 +1381,7 @@ public:
// prevent constructing from temporary std::array
template <typename T, std::size_t N>
- constexpr multi_span(std::array<T, N> && arr) = delete;
+ constexpr multi_span(std::array<T, N>&& arr) = delete;
// construct from containers
// future: could use contiguous_iterator_traits to identify only contiguous containers
@@ -1364,11 +1389,11 @@ public:
template <typename Cont, typename DataType = typename Cont::value_type,
typename = std::enable_if_t<
!details::is_multi_span<Cont>::value &&
- std::is_convertible<DataType(*)[], value_type(*)[]>::value &&
+ std::is_convertible<DataType (*)[], value_type (*)[]>::value &&
std::is_same<std::decay_t<decltype(std::declval<Cont>().size(),
*std::declval<Cont>().data())>,
DataType>::value>>
- constexpr multi_span(Cont & cont)
+ constexpr multi_span(Cont& cont)
: multi_span(static_cast<pointer>(cont.data()),
details::newBoundsHelper<bounds_type>(narrow_cast<size_type>(cont.size())))
{}
@@ -1377,11 +1402,11 @@ public:
template <typename Cont, typename DataType = typename Cont::value_type,
typename = std::enable_if_t<
!details::is_multi_span<Cont>::value &&
- std::is_convertible<DataType(*)[], value_type(*)[]>::value &&
+ std::is_convertible<DataType (*)[], value_type (*)[]>::value &&
std::is_same<std::decay_t<decltype(std::declval<Cont>().size(),
*std::declval<Cont>().data())>,
DataType>::value>>
- explicit constexpr multi_span(Cont && cont) = delete;
+ explicit constexpr multi_span(Cont&& cont) = delete;
// construct from a convertible multi_span
template <typename OtherValueType, std::ptrdiff_t... OtherDimensions,
@@ -1394,7 +1419,7 @@ public:
// trivial copy and move
constexpr multi_span(const multi_span&) = default;
- constexpr multi_span(multi_span &&) = default;
+ constexpr multi_span(multi_span&&) = default;
// trivial assignment
constexpr multi_span& operator=(const multi_span&) = default;
@@ -1468,7 +1493,8 @@ public:
}
// section - creates a non-contiguous, strided multi_span from a contiguous one
- constexpr strided_span<ValueType, Rank> section(index_type origin, index_type extents) const
+ constexpr strided_span<ValueType, Rank> section(index_type origin,
+ index_type extents) const
{
const size_type size = this->bounds().total_size() - this->bounds().linearize(origin);
return {&this->operator[](origin), size,
@@ -1610,8 +1636,8 @@ public:
template <typename OtherValueType, std::ptrdiff_t... OtherDimensions,
typename = std::enable_if_t<std::is_same<std::remove_cv_t<value_type>,
std::remove_cv_t<OtherValueType>>::value>>
- constexpr bool operator>(const multi_span<OtherValueType, OtherDimensions...>& other)
- const noexcept
+ constexpr bool operator>(const multi_span<OtherValueType, OtherDimensions...>& other) const
+ noexcept
{
return (other < *this);
}
@@ -1647,8 +1673,7 @@ constexpr auto as_multi_span(SpanType s, Dimensions2... dims)
// convert a multi_span<T> to a multi_span<const byte>
template <typename U, std::ptrdiff_t... Dimensions>
-multi_span<const byte, dynamic_range>
-as_bytes(multi_span<U, Dimensions...> s) noexcept
+multi_span<const byte, dynamic_range> as_bytes(multi_span<U, Dimensions...> s) noexcept
{
static_assert(std::is_trivial<std::decay_t<U>>::value,
"The value_type of multi_span must be a trivial type.");
@@ -1734,8 +1759,7 @@ constexpr auto as_multi_span(T* arr, std::ptrdiff_t len) ->
}
template <typename T, std::size_t N>
-constexpr auto as_multi_span(T (&arr)[N]) ->
- typename details::SpanArrayTraits<T, N>::type
+constexpr auto as_multi_span(T (&arr)[N]) -> typename details::SpanArrayTraits<T, N>::type
{
return {arr};
}
@@ -1788,7 +1812,7 @@ constexpr auto as_multi_span(std::basic_string<CharT, Traits, Allocator>& str)
// strided_span is an extension that is not strictly part of the GSL at this time.
// It is kept here while the multidimensional interface is still being defined.
template <typename ValueType, std::size_t Rank>
-class [[deprecated("gsl::strided_span is deprecated because it is not in the C++ Core Guidelines")]] strided_span
+class strided_span
{
public:
using bounds_type = strided_bounds<Rank>;
@@ -2031,7 +2055,8 @@ private:
};
template <class Span>
-class [[deprecated]] contiguous_span_iterator {
+class contiguous_span_iterator
+{
public:
using iterator_category = std::random_access_iterator_tag;
using value_type = typename Span::value_type;
@@ -2047,8 +2072,7 @@ private:
const Span* m_validator;
GSL_SUPPRESS(bounds.1) // NO-FORMAT: attribute
- void validateThis() const
- {
+ void validateThis() const {
// iterator is out of range of the array
Expects(data_ >= m_validator->data_ && data_ < m_validator->data_ + m_validator->size());
}
@@ -2137,7 +2161,7 @@ public:
bool operator>(const contiguous_span_iterator& rhs) const { return rhs < *this; }
bool operator>=(const contiguous_span_iterator& rhs) const { return !(rhs > *this); }
- void swap(contiguous_span_iterator & rhs) noexcept
+ void swap(contiguous_span_iterator& rhs) noexcept
{
std::swap(data_, rhs.data_);
std::swap(m_validator, rhs.m_validator);
@@ -2152,7 +2176,7 @@ contiguous_span_iterator<Span> operator+(typename contiguous_span_iterator<Span>
}
template <typename Span>
-class [[deprecated]] general_span_iterator {
+class general_span_iterator {
public:
using iterator_category = std::random_access_iterator_tag;
using value_type = typename Span::value_type;
@@ -2235,7 +2259,7 @@ public:
bool operator<=(const general_span_iterator& rhs) const { return !(rhs < *this); }
bool operator>(const general_span_iterator& rhs) const { return rhs < *this; }
bool operator>=(const general_span_iterator& rhs) const { return !(rhs > *this); }
- void swap(general_span_iterator & rhs) noexcept
+ void swap(general_span_iterator& rhs) noexcept
{
std::swap(m_itr, rhs.m_itr);
std::swap(m_container, rhs.m_container);
@@ -2266,8 +2290,4 @@ general_span_iterator<Span> operator+(typename general_span_iterator<Span>::diff
#pragma GCC diagnostic pop
#endif // __GNUC__ > 6
-#if __clang__ || __GNUC__
-#pragma GCC diagnostic pop
-#endif
-
#endif // GSL_MULTI_SPAN_H