Skip to content

Commit

Permalink
TODO: [MISC] deprecate seqan3::views::to_upper
Browse files Browse the repository at this point in the history
  • Loading branch information
marehr authored and MitraDarja committed Apr 22, 2021
1 parent 0357d00 commit 59ed624
Show file tree
Hide file tree
Showing 4 changed files with 20 additions and 3 deletions.
3 changes: 3 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -199,6 +199,9 @@ regression test suite and patches at https://github.com/seqan/seqan3/tree/master
* We made `seqan3::views::convert` NOAPI and moved it to `seqan3/utility/views/convert.hpp`. You can still use
`seqan3::views::convert` in the meantime, but we encourage using `std::views::transform` instead as shown in our
[Cookbook](https://docs.seqan.de/seqan/3.0.3/cookbook.html#cookbook_convert_alphabet_range).
* We deprecated `seqan3::views::to_upper` and it will be removed in 3.1.0, use
`std::views::transform([](auto && chr){return std::toupper(chr)})`.
([\#2540](https://github.com/seqan/seqan3/pull/2538))

#### Search

Expand Down
10 changes: 7 additions & 3 deletions include/seqan3/range/views/to_upper.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@

/*!\file
* \author Tobias Loka <LokaT AT rki.de>
* \brief Provides seqan3::views::to_upper.
* \brief [DEPRECATED] Provides seqan3::views::to_upper.
*/

#pragma once
Expand Down Expand Up @@ -63,13 +63,17 @@ namespace seqan3::views
* ### Example
* \include test/snippet/range/views/to_upper.cpp
* \hideinitializer
*
* \deprecated Use std::views::transform([](auto && chr){return std::toupper(chr)});
*/
inline auto const to_upper = deep{std::views::transform([] (auto const in) noexcept
#ifdef SEQAN3_DEPRECATED_310
SEQAN3_DEPRECATED_310 inline auto const to_upper = deep{std::views::transform([] (auto const in) noexcept
{
static_assert(builtin_character<std::remove_cvref_t<decltype(in)>>,
"The value type of seqan3::views::to_upper must model the seqan3::builtin_character.");
"The value type of seqan3::views::to_upper must model the seqan3::builtin_character.");
return seqan3::to_upper(in);
})};
#endif // SEQAN3_DEPRECATED_310

//!\}

Expand Down
5 changes: 5 additions & 0 deletions test/snippet/range/views/to_upper.cpp
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
#ifdef SEQAN3_DEPRECATED_310
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wdeprecated-declarations"
#include <string>
#include <vector>

Expand All @@ -14,3 +17,5 @@ int main()
seqan3::debug_stream << v1 << '\n'; // => "CHANGED!"
seqan3::debug_stream << v2 << '\n'; // => ["CHANGED", "UNCHANGED!"]
}
#pragma GCC diagnostic pop
#endif // SEQAN3_DEPRECATED_310
5 changes: 5 additions & 0 deletions test/unit/range/views/to_upper_test.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,9 @@
#include <seqan3/range/views/to_upper.hpp>
#include <seqan3/test/expect_range_eq.hpp>

#ifdef SEQAN3_DEPRECATED_310
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wdeprecated-declarations"

using seqan3::operator""_dna5;

Expand Down Expand Up @@ -95,3 +98,5 @@ TEST(view_to_upper, concepts)
EXPECT_FALSE((std::ranges::output_range<decltype(upper_view), char>));
EXPECT_FALSE(std::ranges::contiguous_range<decltype(upper_view)>);
}
#pragma GCC diagnostic pop
#endif // SEQAN3_DEPRECATED_310

0 comments on commit 59ed624

Please sign in to comment.