https://gcc.gnu.org/g:9a1cb52cae2d48d2fc18d01b534bf4e3203f0cc1

commit r15-6447-g9a1cb52cae2d48d2fc18d01b534bf4e3203f0cc1
Author: Arsen Arsenović <ar...@aarsen.me>
Date:   Tue Dec 24 12:50:28 2024 +0100

    libstdc++: add missing return in generator assignment operator [PR118196]
    
    libstdc++-v3/ChangeLog:
    
            PR libstdc++/118196
            * include/std/generator (generator::operator=(generator)): Add
            missing 'return *this;'.
            * testsuite/24_iterators/range_generators/pr118196.cc: New test.

Diff:
---
 libstdc++-v3/include/std/generator                          |  1 +
 .../testsuite/24_iterators/range_generators/pr118196.cc     | 13 +++++++++++++
 2 files changed, 14 insertions(+)

diff --git a/libstdc++-v3/include/std/generator 
b/libstdc++-v3/include/std/generator
index 3a19d535ef86..7d7e9b708657 100644
--- a/libstdc++-v3/include/std/generator
+++ b/libstdc++-v3/include/std/generator
@@ -717,6 +717,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
       {
        swap(__other._M_coro, this->_M_coro);
        swap(__other._M_began, this->_M_began);
+       return *this;
       }
 
       _Iterator
diff --git a/libstdc++-v3/testsuite/24_iterators/range_generators/pr118196.cc 
b/libstdc++-v3/testsuite/24_iterators/range_generators/pr118196.cc
new file mode 100644
index 000000000000..ae161df2a4a6
--- /dev/null
+++ b/libstdc++-v3/testsuite/24_iterators/range_generators/pr118196.cc
@@ -0,0 +1,13 @@
+// { dg-do compile { target c++23 } }
+#include "<generator>"
+
+std::generator<int>
+generator();
+
+void
+try_reassigning()
+{
+  auto gen = generator();
+  auto gen2 = generator();
+  gen = std::move(gen2);
+}

Reply via email to