+2019-12-05 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * typeck2.c (build_functional_cast): Add location_t parameter
+ and use it.
+ * cp-tree.h: Update declaration.
+ * parser.c (cp_parser_functional_cast): Adjust call.
+ * call.c (build_op_delete_call): Likewise.
+ (build_new_method_call_1): Likewise.
+ * decl.c (check_initializer): Likewise.
+ * pt.c (tsubst_copy_and_build): Likewise.
+ * semantics.c (finish_compound_literal): Likewise.
+
2019-12-04 David Edelsohn <dje.gcc@gmail.com>
* cp-gimplify.c: Include tm_p.h.
rtype = cv_unqualified (rtype);
rtype = TYPE_POINTER_TO (rtype);
addr = cp_convert (rtype, oaddr, complain);
- destroying = build_functional_cast (destroying, NULL_TREE,
+ destroying = build_functional_cast (input_location,
+ destroying, NULL_TREE,
complain);
}
basetype, name))
inform (input_location, "for a function-style cast, remove the "
"redundant %<::%D%>", name);
- call = build_functional_cast (basetype, build_tree_list_vec (user_args),
+ call = build_functional_cast (input_location, basetype,
+ build_tree_list_vec (user_args),
complain);
return call;
}
extern tree build_x_arrow (location_t, tree,
tsubst_flags_t);
extern tree build_m_component_ref (tree, tree, tsubst_flags_t);
-extern tree build_functional_cast (tree, tree, tsubst_flags_t);
+extern tree build_functional_cast (location_t, tree, tree,
+ tsubst_flags_t);
extern tree add_exception_specifier (tree, tree, tsubst_flags_t);
extern tree merge_exception_specifiers (tree, tree);
if (CLASS_TYPE_P (type)
&& (!init || TREE_CODE (init) == TREE_LIST))
{
- init = build_functional_cast (type, init, tf_none);
+ init = build_functional_cast (input_location, type,
+ init, tf_none);
if (TREE_CODE (init) == TARGET_EXPR)
TARGET_EXPR_DIRECT_INIT_P (init) = true;
}
release_tree_vector (vec);
}
- cast = build_functional_cast (type, expression_list,
+ /* Create a location of the form:
+ float(i)
+ ^~~~~~~~
+ with caret == start at the start of the type name,
+ finishing at the closing paren. */
+ location_t combined_loc = make_location (start_loc, start_loc,
+ parser->lexer);
+ cast = build_functional_cast (combined_loc, type, expression_list,
tf_warning_or_error);
+ cast.set_location (combined_loc);
+
/* [expr.const]/1: In an integral constant expression "only type
conversions to integral or enumeration type can be used". */
if (TREE_CODE (type) == TYPE_DECL)
NIC_CONSTRUCTOR))
return error_mark_node;
- /* Create a location of the form:
- float(i)
- ^~~~~~~~
- with caret == start at the start of the type name,
- finishing at the closing paren. */
- location_t combined_loc = make_location (start_loc, start_loc, parser->lexer);
- cast.set_location (combined_loc);
return cast;
}
switch (TREE_CODE (t))
{
case CAST_EXPR:
- r = build_functional_cast (type, op, complain);
+ r = build_functional_cast (input_location, type, op, complain);
break;
case REINTERPRET_CAST_EXPR:
r = build_reinterpret_cast (type, op, complain);
that it came from T{} rather than T({}). */
CONSTRUCTOR_IS_DIRECT_INIT (compound_literal) = 1;
compound_literal = build_tree_list (NULL_TREE, compound_literal);
- return build_functional_cast (type, compound_literal, complain);
+ return build_functional_cast (input_location, type,
+ compound_literal, complain);
}
if (TREE_CODE (type) == ARRAY_TYPE
/* Return a tree node for the expression TYPENAME '(' PARMS ')'. */
tree
-build_functional_cast (tree exp, tree parms, tsubst_flags_t complain)
+build_functional_cast (location_t loc, tree exp, tree parms,
+ tsubst_flags_t complain)
{
/* This is either a call to a constructor,
or a C cast in C++'s `functional' notation. */
if (TREE_CODE (type) == ARRAY_TYPE)
{
if (complain & tf_error)
- error ("functional cast to array type %qT", type);
+ error_at (loc, "functional cast to array type %qT", type);
return error_mark_node;
}
if (!CLASS_PLACEHOLDER_TEMPLATE (anode))
{
if (complain & tf_error)
- error ("invalid use of %qT", anode);
+ error_at (loc, "invalid use of %qT", anode);
return error_mark_node;
}
else if (!parms)
if (type == error_mark_node)
{
if (complain & tf_error)
- error ("cannot deduce template arguments for %qT from %<()%>",
- anode);
+ error_at (loc, "cannot deduce template arguments "
+ "for %qT from %<()%>", anode);
return error_mark_node;
}
}
if (TYPE_REF_P (type) && !parms)
{
if (complain & tf_error)
- error ("invalid value-initialization of reference type");
+ error_at (loc, "invalid value-initialization of reference type");
return error_mark_node;
}
+2019-12-05 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * g++.dg/diagnostic/functional-cast-to-array-type-1.C: New.
+ * g++.dg/cpp0x/auto25.C: Check location(s) too.
+ * g++.dg/cpp0x/auto28.C: Likewise.
+ * g++.dg/init/reference2.C: Likewise.
+ * g++.dg/parse/template2.C: Likewise.
+ * g++.dg/template/error8.C: Likewise.
+ * g++.old-deja/g++.ns/crash3.C: Likewise.
+ * g++.old-deja/g++.ns/template7.C: Likewise.
+ * g++.old-deja/g++.pt/crash8.C: Likewise.
+
2019-12-03 Martin Sebor <msebor@redhat.com>
PR middle-end/91582
template<int> struct A
{
- int a[auto(1)]; // { dg-error "invalid use of" }
+ int a[auto(1)]; // { dg-error "9:invalid use of" }
};
template<int> void foo()
{
- int a[auto(1)]; // { dg-error "invalid use of" }
+ int a[auto(1)]; // { dg-error "9:invalid use of" }
}
// PR c++/51404
// { dg-do compile { target c++11 } }
-int i = auto().x; // { dg-error "invalid use of" }
+int i = auto().x; // { dg-error "9:invalid use of" }
--- /dev/null
+typedef int A [1];
+A a = A(1); // { dg-error "7:functional cast to array type" }
void f()
{
typedef int& T;
- T a = T(); // { dg-error "value-initialization of reference" }
+ T a = T(); // { dg-error "9:invalid value-initialization of reference" }
}
}
int main() {
- N::C(); // { dg-error "template|deduction" }
+ N::C(); // { dg-error "6:cannot deduce template arguments" "" { target c++17 } }
+ // { dg-error "7:missing template arguments" "" { target c++14_down } .-1 }
}
template <typename T> struct S {};
void f() {
- throw S (); // { dg-error "template" }
+ throw S (); // { dg-error "9:cannot deduce template arguments" "" { target c++17 } }
+ // { dg-error "11:missing template arguments" "" { target c++14_down } .-1 }
}
void f()
{
- N::S(); // { dg-error "" } invalid use of template
+ N::S(); // { dg-error "6:cannot deduce template arguments" "" { target c++17 } } invalid use of template
+ // { dg-error "7:missing template arguments" "" { target c++14_down } .-1 }
}
}
void baz() {
- foo::bar(); // { dg-error "" } template used as expression
+ foo::bar(); // { dg-error "8:cannot deduce template arguments" "" { target c++17 } } template used as expression
+ // { dg-error "11:missing template arguments" "" { target c++14_down } .-1 }
}
q2 = TestClass2<T>();
TestClass1<T> p1;
- p1 = TestClass1(); // { dg-error "" } template used as expression
+ p1 = TestClass1(); // { dg-error "8:cannot deduce template arguments" "" { target c++17 } } template used as expression
+ // { dg-error "18:missing template arguments" "" { target c++14_down } .-1 }
TestClass2<T> p2;
- p2 = TestClass2(); // { dg-error "" } template used as expression
+ p2 = TestClass2(); // { dg-error "8:cannot deduce template arguments" "" { target c++17 } } template used as expression
+ // { dg-error "18:missing template arguments" "" { target c++14_down } .-1 }
}
int main() {
+2019-12-05 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * libcp1plugin.cc (plugin_build_expression_list_expr): Adjust
+ build_functional_cast call.
+
2019-11-25 Paolo Carlini <paolo.carlini@oracle.com>
* libcp1plugin.cc (plugin_pragma_push_user_expression): Update
case CHARS2 ('c', 'v'): // conversion with parenthesized expression list
gcc_assert (TYPE_P (type));
args = args_to_tree_list (values_in);
- result = build_functional_cast (type, args, tf_error);
+ result = build_functional_cast (input_location, type, args, tf_error);
break;
case CHARS2 ('t', 'l'): // conversion with braced expression list