summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2009-08-16 03:53:54 +0000
committerAnders Carlsson <andersca@mac.com>2009-08-16 03:53:54 +0000
commit1c83debc36c16b69d7cb79f90e991c64bdfd5447 (patch)
treeb02f30f62580f5cccf001996c479ee8759fe5e8b
parent8c84c206d95e8641921f70cf66ba9682c5b8e0a4 (diff)
downloadbcm5719-llvm-1c83debc36c16b69d7cb79f90e991c64bdfd5447.tar.gz
bcm5719-llvm-1c83debc36c16b69d7cb79f90e991c64bdfd5447.zip
Call MaybeBindToTemporary when constructing functino call operator calls.
llvm-svn: 79172
-rw-r--r--clang/lib/Sema/SemaOverload.cpp2
-rw-r--r--clang/test/CodeGenCXX/temp-1.cpp15
2 files changed, 15 insertions, 2 deletions
diff --git a/clang/lib/Sema/SemaOverload.cpp b/clang/lib/Sema/SemaOverload.cpp
index 2b507fb303a..d4187f2ce1b 100644
--- a/clang/lib/Sema/SemaOverload.cpp
+++ b/clang/lib/Sema/SemaOverload.cpp
@@ -4555,7 +4555,7 @@ Sema::BuildCallToObjectOfClassType(Scope *S, Expr *Object,
if (CheckFunctionCall(Method, TheCall.get()))
return true;
- return TheCall.release();
+ return MaybeBindToTemporary(TheCall.release()).release();
}
/// BuildOverloadedArrowExpr - Build a call to an overloaded @c operator->
diff --git a/clang/test/CodeGenCXX/temp-1.cpp b/clang/test/CodeGenCXX/temp-1.cpp
index 1edcae4acfc..737bf65b473 100644
--- a/clang/test/CodeGenCXX/temp-1.cpp
+++ b/clang/test/CodeGenCXX/temp-1.cpp
@@ -35,10 +35,23 @@ struct C {
};
// RUN: grep "call void @_ZN1CC1Ev" %t | count 1 &&
-// RUN: grep "call void @_ZN1CD1Ev" %t | count 2
+// RUN: grep "call void @_ZN1CD1Ev" %t | count 2 &&
void f3() {
C().f();
}
+// Function call operator
+struct D {
+ D();
+ ~D();
+
+ D operator()();
+};
+
+// RUN: grep "call void @_ZN1DC1Ev" %t | count 1 &&
+// RUN: grep "call void @_ZN1DD1Ev" %t | count 2
+void f4() {
+ D()();
+}
OpenPOWER on IntegriCloud