[cfe-commits] r160412 - in /cfe/trunk: lib/Sema/SemaTemplateDeduction.cpp test/SemaObjCXX/arc-templates.mm
Douglas Gregor
dgregor at apple.com
Tue Jul 17 17:14:59 PDT 2012
Author: dgregor
Date: Tue Jul 17 19:14:59 2012
New Revision: 160412
URL: http://llvm.org/viewvc/llvm-project?rev=160412&view=rev
Log:
When performing the deduced/actual argument type check for C++
[temp.deduct.call]p4 under Objective-C++ ARC, make sure to adjust the
qualifiers to introduce the implicit strong lifetime when
needed. Fixes <rdar://problem/11825671>.
Modified:
cfe/trunk/lib/Sema/SemaTemplateDeduction.cpp
cfe/trunk/test/SemaObjCXX/arc-templates.mm
Modified: cfe/trunk/lib/Sema/SemaTemplateDeduction.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaTemplateDeduction.cpp?rev=160412&r1=160411&r2=160412&view=diff
==============================================================================
--- cfe/trunk/lib/Sema/SemaTemplateDeduction.cpp (original)
+++ cfe/trunk/lib/Sema/SemaTemplateDeduction.cpp Tue Jul 17 19:14:59 2012
@@ -2436,6 +2436,16 @@
Qualifiers AQuals = A.getQualifiers();
Qualifiers DeducedAQuals = DeducedA.getQualifiers();
+
+ // Under Objective-C++ ARC, the deduced type may have implicitly been
+ // given strong lifetime. If so, update the original qualifiers to
+ // include this strong lifetime.
+ if (S.getLangOpts().ObjCAutoRefCount &&
+ DeducedAQuals.getObjCLifetime() == Qualifiers::OCL_Strong &&
+ AQuals.getObjCLifetime() == Qualifiers::OCL_None) {
+ AQuals.setObjCLifetime(Qualifiers::OCL_Strong);
+ }
+
if (AQuals == DeducedAQuals) {
// Qualifiers match; there's nothing to do.
} else if (!DeducedAQuals.compatiblyIncludes(AQuals)) {
Modified: cfe/trunk/test/SemaObjCXX/arc-templates.mm
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/SemaObjCXX/arc-templates.mm?rev=160412&r1=160411&r2=160412&view=diff
==============================================================================
--- cfe/trunk/test/SemaObjCXX/arc-templates.mm (original)
+++ cfe/trunk/test/SemaObjCXX/arc-templates.mm Tue Jul 17 19:14:59 2012
@@ -3,6 +3,8 @@
@interface A
@end
+ at class NSString;
+
template<typename T, typename U>
struct is_same {
static const bool value = false;
@@ -266,3 +268,18 @@
float &fr = (f)(ap);
}
}
+
+namespace rdar10862386 {
+ // More deduction with lifetime qualifiers.
+ template <typename T>
+ int testing(const T &) {
+ return 1;
+ }
+
+ void test() {
+ testing(1);
+ testing("hi");
+ testing<NSString *>(@"hi");
+ testing(@"hi");
+ }
+}
More information about the cfe-commits
mailing list