]> granicus.if.org Git - clang/commitdiff
Make sure we correctly treat __is_convertible_to as an unevaluated context. PR11833.
authorEli Friedman <eli.friedman@gmail.com>
Wed, 25 Jan 2012 01:05:57 +0000 (01:05 +0000)
committerEli Friedman <eli.friedman@gmail.com>
Wed, 25 Jan 2012 01:05:57 +0000 (01:05 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@148893 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Sema/SemaExprCXX.cpp
test/SemaCXX/type-traits.cpp

index 1b08aa2159d1b88735a2652755bc7e452e479b06..5c00e70af6dcdbd4329c02180f42ed03a9642f10 100644 (file)
@@ -3166,8 +3166,9 @@ static bool EvaluateBinaryTypeTrait(Sema &Self, BinaryTypeTrait BTT,
     InitializationKind Kind(InitializationKind::CreateCopy(KeyLoc, 
                                                            SourceLocation()));
     
-    // Perform the initialization within a SFINAE trap at translation unit 
-    // scope.
+    // Perform the initialization in an unevaluated context within a SFINAE 
+    // trap at translation unit scope.
+    EnterExpressionEvaluationContext Unevaluated(Self, Sema::Unevaluated);
     Sema::SFINAETrap SFINAE(Self, /*AccessCheckingSFINAE=*/true);
     Sema::ContextRAII TUContext(Self, Self.Context.getTranslationUnitDecl());
     InitializationSequence Init(Self, To, Kind, &FromPtr, 1);
index 2b8714b5e054212e44b0e090986c062d3fbd74eb..c1783dab285e21f6a900050717078a2bd2b587d0 100644 (file)
@@ -1543,6 +1543,12 @@ void is_convertible_to() {
   { int arr[T(__is_convertible_to(X0<int>, X0<float>))]; }
 }
 
+namespace is_convertible_to_instantiate {
+  // Make sure we don't try to instantiate the constructor.
+  template<int x> class A { A(int) { int a[x]; } };
+  int x = __is_convertible_to(int, A<-1>);
+}
+
 void is_trivial()
 {
   { int arr[T(__is_trivial(int))]; }