]> granicus.if.org Git - clang/commitdiff
Implement name mangling for scalar value initialization. Reported on IRC by Xeo.
authorRichard Smith <richard-llvm@metafoo.co.uk>
Mon, 6 Feb 2012 02:54:51 +0000 (02:54 +0000)
committerRichard Smith <richard-llvm@metafoo.co.uk>
Mon, 6 Feb 2012 02:54:51 +0000 (02:54 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@149854 91177308-0d34-0410-b5e6-96231b3b80d8

lib/AST/ItaniumMangle.cpp
test/CodeGenCXX/mangle-exprs.cpp

index 9c697ed9b1e74224b0a98515d56b26e73794283d..37ae62668365dd85d36c270e097d91892d449b66 100644 (file)
@@ -2247,7 +2247,6 @@ recurse:
   case Expr::ImplicitValueInitExprClass:
   case Expr::InitListExprClass:
   case Expr::ParenListExprClass:
-  case Expr::CXXScalarValueInitExprClass:
     llvm_unreachable("unexpected statement kind");
 
   // FIXME: invent manglings for all these.
@@ -2427,6 +2426,12 @@ recurse:
     break;
   }
 
+  case Expr::CXXScalarValueInitExprClass:
+    Out <<"cv";
+    mangleType(E->getType());
+    Out <<"_E";
+    break;
+
   case Expr::UnaryExprOrTypeTraitExprClass: {
     const UnaryExprOrTypeTraitExpr *SAE = cast<UnaryExprOrTypeTraitExpr>(E);
     
index c5f72d83c75016861135e14eac284c0bc700aac1..bad564f80f17499e731788047d61a1b5e9f88f14 100644 (file)
@@ -28,6 +28,10 @@ namespace Casts {
   void auto_(decltype(new auto(T()))) {
   }
 
+  template< typename T >
+  void scalar_(decltype(T(), int())) {
+  }
+
   // FIXME: Test const_cast, reinterpret_cast, dynamic_cast, which are
   // a bit harder to use in template arguments.
   template <unsigned N> struct T {};
@@ -48,6 +52,9 @@ namespace Casts {
 
   // CHECK: define weak_odr void @_ZN5Casts5auto_IiEEvDTnw_DapicvT__EEE(
   template void auto_<int>(int*);
+
+  // CHECK: define weak_odr void @_ZN5Casts7scalar_IiEEvDTcmcvT__Ecvi_EE(
+  template void scalar_<int>(int);
 }
 
 namespace test1 {