[cfe-commits] r118314 - in /cfe/trunk: lib/Sema/SemaTemplateDeduction.cpp test/SemaCXX/crashes.cpp
Argyrios Kyrtzidis
akyrtzi at gmail.com
Fri Nov 5 16:25:18 PDT 2010
Author: akirtzidis
Date: Fri Nov 5 18:25:18 2010
New Revision: 118314
URL: http://llvm.org/viewvc/llvm-project?rev=118314&view=rev
Log:
When determining which template partial specialization is more specialized,
make sure to setup the instantiation stack. Fixes rdar://8620775 & http://llvm.org/PR8234
Modified:
cfe/trunk/lib/Sema/SemaTemplateDeduction.cpp
cfe/trunk/test/SemaCXX/crashes.cpp
Modified: cfe/trunk/lib/Sema/SemaTemplateDeduction.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaTemplateDeduction.cpp?rev=118314&r1=118313&r2=118314&view=diff
==============================================================================
--- cfe/trunk/lib/Sema/SemaTemplateDeduction.cpp (original)
+++ cfe/trunk/lib/Sema/SemaTemplateDeduction.cpp Fri Nov 5 18:25:18 2010
@@ -2485,10 +2485,13 @@
Info,
Deduced,
0);
- if (Better1)
+ if (Better1) {
+ InstantiatingTemplate Inst(*this, PS2->getLocation(), PS2,
+ Deduced.data(), Deduced.size(), Info);
Better1 = !::FinishTemplateArgumentDeduction(*this, PS2,
PS1->getTemplateArgs(),
Deduced, Info);
+ }
// Determine whether PS2 is at least as specialized as PS1
Deduced.clear();
@@ -2500,10 +2503,13 @@
Info,
Deduced,
0);
- if (Better2)
+ if (Better2) {
+ InstantiatingTemplate Inst(*this, PS1->getLocation(), PS1,
+ Deduced.data(), Deduced.size(), Info);
Better2 = !::FinishTemplateArgumentDeduction(*this, PS1,
PS2->getTemplateArgs(),
Deduced, Info);
+ }
if (Better1 == Better2)
return 0;
Modified: cfe/trunk/test/SemaCXX/crashes.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/SemaCXX/crashes.cpp?rev=118314&r1=118313&r2=118314&view=diff
==============================================================================
--- cfe/trunk/test/SemaCXX/crashes.cpp (original)
+++ cfe/trunk/test/SemaCXX/crashes.cpp Fri Nov 5 18:25:18 2010
@@ -41,3 +41,30 @@
new Y // expected-error{{no viable conversion}}
};
}
+
+// http://llvm.org/PR8234
+namespace PR8234 {
+template<typename Signature>
+class callback
+{
+};
+
+template<typename R , typename ARG_TYPE0>
+class callback<R( ARG_TYPE0)>
+{
+ public:
+ callback() {}
+};
+
+template< typename ARG_TYPE0>
+class callback<void( ARG_TYPE0)>
+{
+ public:
+ callback() {}
+};
+
+void f()
+{
+ callback<void(const int&)> op;
+}
+}
More information about the cfe-commits
mailing list