diff --git a/README.md b/README.md index d7c9c02b6..50c564c75 100644 --- a/README.md +++ b/README.md @@ -69,7 +69,7 @@ The library is intended for any compiler that supports C++98/03/11/14/17/20. - Checksums & hash functions - Variants (a type that can store many types in a type-safe interface) - Choice of asserts, exceptions, error handler or no checks on errors -- Unit tested (currently over 6480 tests), using VS2019, GCC 8.1.0, , GCC 9.3.0, Clang 9.0.0 & 10.0.0 +- Unit tested (currently over 9400 tests), using VS2022, GCC 12, Clang 14. - Many utilities for template support. - Easy to read and documented source. - Free support via email, GitHub and Slack diff --git a/include/etl/span.h b/include/etl/span.h index f1077ea77..7aa11c960 100644 --- a/include/etl/span.h +++ b/include/etl/span.h @@ -272,6 +272,26 @@ namespace etl { pbegin = other.pbegin; return *this; + } + + //************************************************************************* + /// Returns a reference to the value at index 'i'. + //************************************************************************* + ETL_NODISCARD ETL_CONSTEXPR14 reference at(size_t i) + { + ETL_ASSERT(i < size(), ETL_ERROR(array_out_of_range)); + + return pbegin[i]; + } + + //************************************************************************* + /// Returns a const reference to the value at index 'i'. + //************************************************************************* + ETL_NODISCARD ETL_CONSTEXPR14 const_reference at(size_t i) const + { + ETL_ASSERT(i < size(), ETL_ERROR(array_out_of_range)); + + return pbegin[i]; } //************************************************************************* @@ -614,6 +634,26 @@ namespace etl return *this; } + //************************************************************************* + /// Returns a reference to the value at index 'i'. + //************************************************************************* + ETL_NODISCARD ETL_CONSTEXPR14 reference at(size_t i) + { + ETL_ASSERT(i < size(), ETL_ERROR(array_out_of_range)); + + return pbegin[i]; + } + + //************************************************************************* + /// Returns a const reference to the value at index 'i'. + //************************************************************************* + ETL_NODISCARD ETL_CONSTEXPR14 const_reference at(size_t i) const + { + ETL_ASSERT(i < size(), ETL_ERROR(array_out_of_range)); + + return pbegin[i]; + } + //************************************************************************* /// Returns a reference to the indexed value. //************************************************************************* diff --git a/test/test_span_dynamic_extent.cpp b/test/test_span_dynamic_extent.cpp index 3d7df1ec0..300ee58c5 100644 --- a/test/test_span_dynamic_extent.cpp +++ b/test/test_span_dynamic_extent.cpp @@ -445,6 +445,22 @@ namespace CHECK_EQUAL(etldata.data(), cview.data()); } + //************************************************************************* + TEST(test_at) + { + View view(etldata.begin(), etldata.end()); + CView cview(etldata.begin(), etldata.end()); + + for (size_t i = 0UL; i < etldata.size(); ++i) + { + CHECK_EQUAL(etldata.at(i), view.at(i)); + CHECK_EQUAL(etldata.at(i), cview.at(i)); + } + + CHECK_THROW({ int d = view.at(view.size()); (void)d; }, etl::array_out_of_range); + CHECK_THROW({ int d = cview.at(cview.size()); (void)d; }, etl::array_out_of_range); + } + //************************************************************************* TEST(test_index_operator) { diff --git a/test/test_span_fixed_extent.cpp b/test/test_span_fixed_extent.cpp index 157170a09..2c760783a 100644 --- a/test/test_span_fixed_extent.cpp +++ b/test/test_span_fixed_extent.cpp @@ -433,6 +433,22 @@ namespace CHECK_EQUAL(etldata.data(), cview.data()); } + //************************************************************************* + TEST(test_at) + { + View view(etldata.begin(), etldata.end()); + CView cview(etldata.begin(), etldata.end()); + + for (size_t i = 0UL; i < etldata.size(); ++i) + { + CHECK_EQUAL(etldata.at(i), view.at(i)); + CHECK_EQUAL(etldata.at(i), cview.at(i)); + } + + CHECK_THROW({ int d = view.at(view.size()); (void)d; }, etl::array_out_of_range); + CHECK_THROW({ int d = cview.at(cview.size()); (void)d; }, etl::array_out_of_range); + } + //************************************************************************* TEST(test_index_operator) {