@@ -13197,6 +13197,7 @@ tsubst_copy_and_build (tree t,
if (TREE_HAS_CONSTRUCTOR (t))
return finish_compound_literal (type, r);
+ TREE_TYPE (r) = type;
return r;
}
@@ -13316,6 +13317,12 @@ tsubst_copy_and_build (tree t,
return build_lambda_object (r);
}
+ case TARGET_EXPR:
+ /* We can get here for a constant initializer of non-dependent type.
+ FIXME stop folding in cp_parser_initializer_clause. */
+ gcc_assert (TREE_CONSTANT (t));
+ return get_target_expr (RECUR (TARGET_EXPR_INITIAL (t)));
+
default:
/* Handle Objective-C++ constructs, if appropriate. */
{
new file mode 100644
@@ -0,0 +1,13 @@
+// PR c++/46420
+// { dg-options -std=c++0x }
+
+template<typename> class vector { };
+struct A{};
+template <class T1>
+void complete_test(vector<T1> data1){
+ A drop=A();
+}
+int main(){
+ vector<double> vect1;
+ complete_test(vect1);
+}