diff options
author | Richard Biener <rguenther@suse.de> | 2022-09-22 15:18:47 +0200 |
---|---|---|
committer | Richard Biener <rguenther@suse.de> | 2022-09-22 15:19:44 +0200 |
commit | 44dba051d72587828882cbb31118934a4fb06c1a (patch) | |
tree | 657d24f6ebda2a9f41a34bd5972bbaea1807fe4d | |
parent | 32d8123cd6ce87acb557aec230e8359051316f9f (diff) | |
download | gcc-44dba051d72587828882cbb31118934a4fb06c1a.zip gcc-44dba051d72587828882cbb31118934a4fb06c1a.tar.gz gcc-44dba051d72587828882cbb31118934a4fb06c1a.tar.bz2 |
tree-optimization/102801 - testcase for uninit diagnostic
The following testcase is fixed in GCC 12+
PR tree-optimization/102801
gcc/testsuite/
* g++.dg/warn/Wuninitialized-33.C: New testcase.
-rw-r--r-- | gcc/testsuite/g++.dg/warn/Wuninitialized-33.C | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/gcc/testsuite/g++.dg/warn/Wuninitialized-33.C b/gcc/testsuite/g++.dg/warn/Wuninitialized-33.C new file mode 100644 index 0000000..1bb0639 --- /dev/null +++ b/gcc/testsuite/g++.dg/warn/Wuninitialized-33.C @@ -0,0 +1,55 @@ +// PR102801 +// { dg-do compile } +// { dg-require-effective-target c++17 } +// { dg-options "-O2 -Wall" } + +#include <algorithm> +#include <memory> +#include <optional> +#include <string> +#include <utility> +#include <vector> + +class C { + bool b{}; // { dg-bogus "uninitialized" } + + struct Shared {}; + using SharedPtr = std::shared_ptr<const Shared>; + + SharedPtr shared; + +public: + C() = delete; + C(bool bIn) : b(bIn) {} + ~C(); + int someMethod() const; +}; + +using OptC = std::optional<C>; + +class C2 { + OptC c; +public: + C2() = default; + C2(const C &cIn) : c(cIn) {} + ~C2(); + void operator()() const; + void swap(C2 &o) { std::swap(c, o.c); } +}; + + +template <typename T> +class Q { + std::vector<T> queue; +public: + void Add(std::vector<T> &items) { + for (T & item : items) { + queue.push_back(T()); + item.swap(queue.back()); + } + } + void Exec(); +}; + +extern void foo(Q<C2> & q, std::vector<C2> &items); +void foo(Q<C2> & q, std::vector<C2> &items) { q.Add(items); q.Exec(); } |