[clang] [clang] Add covariance tests that make sure we return an error when return value is different in pointer / lvalue ref / rvalue ref (PR #112853)
Vlad Serebrennikov via cfe-commits
cfe-commits at lists.llvm.org
Mon Oct 21 05:38:07 PDT 2024
================
@@ -93,6 +93,38 @@ struct B : A {
} // namespace example2
} // namespace cwg952
+namespace cwg960 { // cwg960: 2.8
+struct a {};
+class A {
+#if __cplusplus >= 201103L
+ // Check lvalue ref vs rvalue ref vs pointer.
+ virtual a& rvalue_ref();
+ virtual a&& lvalue_ref();
+ virtual a& rvalue_vs_lvalue_ref(); // expected-note{{overridden virtual function is here}}
+ virtual a&& lvalue_vs_rvalue_ref(); // expected-note{{overridden virtual function is here}}
+ virtual a& rvalue_ref_vs_pointer(); // expected-note{{overridden virtual function is here}}
+ virtual a* pointer_vs_rvalue_ref(); // expected-note{{overridden virtual function is here}}
+ virtual a&& lvalue_ref_vs_pointer(); // expected-note{{overridden virtual function is here}}
+ virtual a* pointer_vs_lvalue_ref(); // expected-note{{overridden virtual function is here}}
+#endif
+};
+
+class B : A {
+#if __cplusplus >= 201103L
+ // Check lvalue ref vs rvalue ref vs pointer.
+ a& rvalue_ref() override;
+ a&& lvalue_ref() override;
+ a&& rvalue_vs_lvalue_ref() override; // expected-error{{virtual function 'rvalue_vs_lvalue_ref' has a different return type ('a &&') than the function it overrides (which has return type 'a &')}}
----------------
Endilll wrote:
```suggestion
a&& rvalue_vs_lvalue_ref() override;
// since-cxx11-error at -1 {{virtual function 'rvalue_vs_lvalue_ref' has a different return type ('a &&') than the function it overrides (which has return type 'a &')}}
// since-cxx11-note@#cwg960-rvalue_vs_lvalue_ref {{overridden virtual function is here}}
```
https://github.com/llvm/llvm-project/pull/112853
More information about the cfe-commits
mailing list