diff options
author | Ted Kremenek <kremenek@apple.com> | 2010-09-02 01:12:13 +0000 |
---|---|---|
committer | Ted Kremenek <kremenek@apple.com> | 2010-09-02 01:12:13 +0000 |
commit | cbe6b0b8469062cbfabd2e8e18433d490897d689 (patch) | |
tree | a221eb4ee1d938855dd27c8088044d79ce2f141f /clang/test/SemaCXX/return-stack-addr.cpp | |
parent | 1fcc18c7bcaf89cdf6c65ca4a17e1e92e35bbdc8 (diff) | |
download | bcm5719-llvm-cbe6b0b8469062cbfabd2e8e18433d490897d689.tar.gz bcm5719-llvm-cbe6b0b8469062cbfabd2e8e18433d490897d689.zip |
Enhance return-stack-address check (in Sema) to handle fields that themselves are references. (Fixes PR 7999; fix by Chandler Carruth).
llvm-svn: 112792
Diffstat (limited to 'clang/test/SemaCXX/return-stack-addr.cpp')
-rw-r--r-- | clang/test/SemaCXX/return-stack-addr.cpp | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/clang/test/SemaCXX/return-stack-addr.cpp b/clang/test/SemaCXX/return-stack-addr.cpp index ba647656036..7d4cb964029 100644 --- a/clang/test/SemaCXX/return-stack-addr.cpp +++ b/clang/test/SemaCXX/return-stack-addr.cpp @@ -108,5 +108,16 @@ int* ret_cpp_const_cast(const int x) { return const_cast<int*>(&x); // expected-warning {{address of stack memory}} } +// PR 7999 - handle the case where a field is itself a reference. +template <typename T> struct PR7999 { + PR7999(T& t) : value(t) {} + T& value; +}; + +struct PR7999_X {}; + +PR7999_X& PR7999_f(PR7999<PR7999_X> s) { return s.value; } // no-warning +void test_PR7999(PR7999_X& x) { (void)PR7999_f(x); } // no-warning + // TODO: test case for dynamic_cast. clang does not yet have // support for C++ classes to write such a test case. |