commit 9d4393af9d2b37b78eb5b1f84f5d4da3a6f7fba6 Author: Jonathan Wakely Date: Mon Jul 12 16:09:34 2021 libstdc++: Constrain std::as_writable_bytes [PR101411] The std::as_writable_bytes function should be constrained to only accept writable spans. Currently it can be called but then gives an error in the function body. Signed-off-by: Jonathan Wakely libstdc++-v3/ChangeLog: PR libstdc++/101411 * include/std/span (as_writable_bytes): Add requires-clause. * testsuite/23_containers/span/101411.cc: New test. diff --git a/libstdc++-v3/include/std/span b/libstdc++-v3/include/std/span index 63f0a8f6279..21d8f6a43a6 100644 --- a/libstdc++-v3/include/std/span +++ b/libstdc++-v3/include/std/span @@ -425,6 +425,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION } template + requires (!is_const_v<_Type>) inline span diff --git a/libstdc++-v3/testsuite/23_containers/span/101411.cc b/libstdc++-v3/testsuite/23_containers/span/101411.cc new file mode 100644 index 00000000000..05bdd3badbd --- /dev/null +++ b/libstdc++-v3/testsuite/23_containers/span/101411.cc @@ -0,0 +1,15 @@ +// { dg-options "-std=gnu++20" } +// { dg-do compile { xfail c++20 } } +#include + +// PR libstdc++/101411 + +void f(std::span s) +{ + std::as_writable_bytes(s); // { dg-error "no matching function" } +} + +void f1(std::span s) +{ + std::as_writable_bytes(s); // { dg-error "no matching function" } +}