summaryrefslogtreecommitdiff
path: root/gcc/cp/ChangeLog-2019
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/cp/ChangeLog-2019')
-rw-r--r--gcc/cp/ChangeLog-20195679
1 files changed, 5679 insertions, 0 deletions
diff --git a/gcc/cp/ChangeLog-2019 b/gcc/cp/ChangeLog-2019
new file mode 100644
index 00000000000..ec05c379bea
--- /dev/null
+++ b/gcc/cp/ChangeLog-2019
@@ -0,0 +1,5679 @@
+2019-12-30 Marek Polacek <polacek@redhat.com>
+
+ * decl.c (reshape_init_r): Remove assert.
+
+2019-12-30 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl2.c (delete_sanity): Add location_t parameter and use
+ it throughout.
+ * init.c (build_vec_delete_1): Likewise.
+ (build_delete): Likewise.
+ (build_vec_delete): Likewise.
+ (perform_target_ctor): Adjust call.
+ (perform_member_init): Likewise.
+ (build_vec_init): Likewise.
+ * decl.c (cxx_maybe_build_cleanup): Likewise.
+ * pt.c (tsubst_copy_and_build): Likewise.
+ * parser.c (cp_parser_delete_expression): Likewise, pass the
+ combined_loc.
+ * cp-tree.h: Update declarations.
+
+2019-12-29 Marek Polacek <polacek@redhat.com>
+
+ PR c++/88337 - Implement P1327R1: Allow dynamic_cast in constexpr.
+ * constexpr.c (cxx_dynamic_cast_fn_p): New function.
+ (extract_obj_from_addr_offset): New function.
+ (get_component_with_type): New function.
+ (cxx_eval_dynamic_cast_fn): New function.
+ (cxx_eval_call_expression): Call cxx_eval_dynamic_cast_fn for a call
+ to __dynamic_cast.
+ (potential_constant_expression_1): Don't give up on
+ cxx_dynamic_cast_fn_p.
+ * rtti.c (build_dynamic_cast_1): When creating a call to
+ __dynamic_cast, use the location of the original expression.
+
+2019-12-26 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/92438
+ * parser.c (cp_parser_constructor_declarator_p): If open paren
+ is followed by RID_ATTRIBUTE, skip over the attribute tokens and
+ try to parse type specifier.
+
+2019-12-23 Richard Sandiford <richard.sandiford@arm.com>
+
+ PR c++/92789
+ * typeck.c (structural_comptypes): Make sure that two vector types
+ agree on gnu_vector_type_p.
+
+2019-12-23 Richard Sandiford <richard.sandiford@arm.com>
+
+ * cvt.c (ocp_convert): Apply rvalue to the source of vector
+ conversions.
+ * typeck.c (build_reinterpret_cast_1): Likewise.
+
+2019-12-19 Marek Polacek <polacek@redhat.com>
+
+ PR c++/92745 - bogus error when initializing array of vectors.
+ * decl.c (reshape_init_r): For a nested compound literal, do
+ call reshape_init_{class,array,vector}.
+
+ PR c++/92974 - bogus location for enum and non-enum in ?: warning.
+ * tree.c (build_min_non_dep): Use the location of NON_DEP when
+ building the expression.
+
+2019-12-20 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/92965
+ * pt.c (invalid_nontype_parm_type_p): Call structural_type_p with
+ explain=true only if emitting error.
+
+ PR c++/92966
+ * method.c (early_check_defaulted_comparison): Don't set
+ DECL_MAYBE_DELETED when returning false.
+
+ PR c++/92973
+ * method.c (early_check_defaulted_comparison): For C++17 and earlier
+ diagnose defaulted comparison operators.
+
+ PR c++/92666
+ * call.c (convert_arg_to_ellipsis): For floating point or
+ decltype(nullptr) arguments call mark_rvalue_use.
+
+ PR c++/92992
+ * call.c (convert_arg_to_ellipsis): For decltype(nullptr) arguments
+ that have side-effects use cp_build_compound_expr.
+
+2019-12-20 Eric Botcazou <ebotcazou@adacore.com>
+
+ * decl2.c (c_parse_final_cleanups): Always call collect_source_ref on
+ the main input filename.
+
+2019-12-19 Julian Brown <julian@codesourcery.com>
+ Cesar Philippidis <cesar@codesourcery.com>
+
+ * parser.c (cp_parser_omp_clause_name): Support attach and detach
+ clauses.
+ (cp_parser_omp_var_list_no_open): Add ALLOW_DEREF optional parameter.
+ Parse deref if true.
+ (cp_parser_omp_var_list): Add ALLOW_DEREF optional parameter. Pass to
+ cp_parser_omp_var_list_no_open.
+ (cp_parser_oacc_data_clause): Support attach and detach clauses.
+ Update call to cp_parser_omp_var_list_no_open.
+ (cp_parser_oacc_all_clauses): Support attach and detach.
+ (OACC_DATA_CLAUSE_MASK, OACC_ENTER_DATA_CLAUSE_MASK,
+ OACC_KERNELS_CLAUSE_MASK, OACC_PARALLEL_CLAUSE_MASK,
+ OACC_SERIAL_CLAUSE_MASK): Add PRAGMA_OACC_CLAUSE_ATTACH.
+ (OACC_EXIT_DATA_CLAUSE_MASK): Add PRAGMA_OACC_CLAUSE_DETACH.
+ * semantics.c (handle_omp_array_sections_1): Reject subarrays for
+ attach and detach.
+ (handle_omp_array_sections): Use GOMP_MAP_ATTACH_DETACH instead of
+ GOMP_MAP_ALWAYS_POINTER for OpenACC.
+ (cp_oacc_check_attachments): New function.
+ (finish_omp_clauses): Use above function. Allow structure fields and
+ class members to appear in OpenACC data clauses. Support
+ GOMP_MAP_ATTACH_DETACH. Support deref.
+
+2019-12-19 Jason Merrill <jason@redhat.com>
+
+ PR c++/52320 - EH cleanups for partially constructed arrays.
+ * typeck2.c (split_nonconstant_init_1): Add nested parm.
+ Add cleanup for whole array if true.
+
+ PR c++/66139 - EH cleanups for partially constructed aggregates.
+ PR c++/57510
+ * cp-gimplify.c (cp_gimplify_init_expr): Use split_nonconstant_init.
+ * typeck2.c (split_nonconstant_init): Handle non-variable dest.
+ (split_nonconstant_init_1): Clear TREE_SIDE_EFFECTS.
+ * tree.c (is_local_temp): New.
+
+2019-12-18 Jason Merrill <jason@redhat.com>
+
+ PR c++/91165 follow-on tweak
+ * constexpr.c (cxx_eval_call_expression): Use
+ unshare_expr_without_location.
+
+2019-12-19 Julian Brown <julian@codesourcery.com>
+ Maciej W. Rozycki <macro@codesourcery.com>
+ Tobias Burnus <tobias@codesourcery.com>
+ Thomas Schwinge <thomas@codesourcery.com>
+
+ * parser.c (cp_parser_omp_clause_name): Support no_create.
+ (cp_parser_oacc_data_clause): Likewise.
+ (cp_parser_oacc_all_clauses): Likewise.
+ (OACC_DATA_CLAUSE_MASK, OACC_KERNELS_CLAUSE_MASK)
+ (OACC_PARALLEL_CLAUSE_MASK): Add PRAGMA_OACC_CLAUSE_NO_CREATE.
+ * semantics.c (handle_omp_array_sections): Support no_create.
+
+2019-12-18 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * typeck.c (cxx_sizeof_or_alignof_type): Add location_t parameter
+ and use it throughout.
+ (cxx_sizeof_expr): Likewise.
+ (cxx_alignof_expr): Likewise.
+ (cxx_sizeof_or_alignof_expr): Likewise.
+ (cxx_alignas_expr): Update call.
+ * decl.c (fold_sizeof_expr): Likewise.
+ * pt.c (tsubst_copy): Likewise.
+ (tsubst_copy_and_build): Likewise.
+ * except.c (build_throw): Add location_t parameter and use it.
+ (expand_end_catch_block): Update call.
+ * parser.c (cp_parser_unary_expression): Update
+ cxx_sizeof_or_alignof_type and cxx_sizeof_or_alignof_expr calls,
+ pass the compound location.
+ (cp_parser_throw_expression): Likewise pass the combined location
+ to build_throw.
+ * cp-tree.h: Update declarations.
+
+ * semantics.c (finish_handler_parms): Use DECL_SOURCE_LOCATION.
+ * decl2.c (check_classfn): Likewise.
+
+ * except.c (is_admissible_throw_operand_or_catch_parameter):
+ Exploit cp_expr_loc_or_input_loc in one place.
+
+ * except.c (create_try_catch_expr): Remove, unused.
+
+2019-12-17 Jason Merrill <jason@redhat.com>
+
+ PR c++/12333 - X::~X() with implicit this->.
+ * parser.c (cp_parser_lookup_name): Use lookup_destructor.
+ * typeck.c (lookup_destructor): No longer static.
+
+2019-12-17 Martin Sebor <msebor@redhat.com>
+
+ PR c++/61339
+ * parser.c (cp_parser_maybe_warn_enum_key): New function.
+ (class_decl_loc_t): New class.
+ (cp_parser_elaborated_type_specifier): Call
+ cp_parser_maybe_warn_enum_key.
+ (cp_parser_class_head): Call cp_parser_check_class_key.
+ (cp_parser_check_class_key): Add arguments. Call class_decl_loc_t::add.
+ (c_parse_file): Call class_decl_loc_t::diag_mismatched_tags.
+
+2019-12-17 Jason Merrill <jason@redhat.com>
+
+ PR c++/79592 - missing explanation of invalid constexpr.
+ * constexpr.c (register_constexpr_fundef): Do store the body of a
+ template instantiation that is not potentially constant.
+ (explain_invalid_constexpr_fn): Look it up.
+ (cxx_eval_call_expression): Check fundef->result.
+
+2019-12-17 Jason Merrill <jason@redhat.com>
+
+ PR c++/92576 - redeclaration of variable template.
+ * decl.c (redeclaration_error_message): Recurse for variable
+ templates.
+
+2019-12-17 Jason Merrill <jason@redhat.com>
+
+ * name-lookup.c (get_std_name_hint): Add std::byte.
+
+2019-12-17 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/59655
+ * pt.c (push_tinst_level_loc): If limit_bad_template_recursion,
+ set TREE_NO_WARNING on tldcl.
+ * decl2.c (no_linkage_error): Treat templates with TREE_NO_WARNING
+ as defined during error recovery.
+
+2019-12-13 Jason Merrill <jason@redhat.com>
+
+ PR c++/91165 - verify_gimple ICE with cached constexpr.
+ * constexpr.c (cxx_bind_parameters_in_call): Don't unshare.
+ (cxx_eval_call_expression): Unshare all args if we're caching.
+
+2019-12-12 Jason Merrill <jason@redhat.com>
+
+ PR c++/92496 - ICE with <=> and no #include <compare>.
+ * typeck.c (cp_build_binary_op): Handle error from spaceship_type.
+
+2019-12-11 David Malcolm <dmalcolm@redhat.com>
+
+ * cxx-pretty-print.c (cxx_pretty_printer::clone): New vfunc
+ implementation.
+ * cxx-pretty-print.h (cxx_pretty_printer::clone): New vfunc decl.
+ * error.c (cxx_format_postprocessor::clone): New vfunc.
+
+2019-12-11 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/92869
+ * class.c (finish_struct): For C++17 and earlier, check
+ type_has_user_provided_or_explicit_constructor rather than
+ TYPE_HAS_USER_CONSTRUCTOR whether to set CLASSTYPE_NON_AGGREGATE.
+
+2019-12-11 Marek Polacek <polacek@redhat.com>
+
+ PR c++/92878 - Parenthesized init of aggregates in new-expression.
+ * init.c (build_new_1): Handle parenthesized initialization of
+ aggregates in new-expression.
+
+2019-12-11 Jason Merrill <jason@redhat.com>
+
+ PR c++/92105 - decltype(decltype) error cascade.
+ * parser.c (cp_parser_decltype_expr): Don't tentative_firewall here.
+ (cp_parser_decltype): Do it here. Remember a non-tentative error.
+
+ PR c++/57082 - new X{} and private destructor.
+ * init.c (build_new_1): Also pass tf_no_cleanup to
+ build_special_member_call.
+
+ PR c++/92774 - ICE with implicitly deleted operator<=>.
+ * method.c (comp_info::~comp_info): Factor out of...
+ (build_comparison_op): Here. Handle error return from build_new_op.
+
+ PR c++/92859 - ADL and bit-field.
+ * name-lookup.c: Use unlowered_expr_type.
+
+ PR c++/92446 - deduction of class NTTP.
+ * pt.c (deducible_expression): Look through VIEW_CONVERT_EXPR.
+
+2019-12-10 Jason Merrill <jason@redhat.com>
+
+ PR c++/92847 - C++20 comparison ambiguity with class template.
+ * call.c (cand_parms_match): Handle all templated functions.
+
+ Fix C++20 structural type vs. private base.
+ * class.c (build_base_field_1): Take access parameter.
+ (build_base_field): Likewise.
+ (build_base_fields, layout_virtual_bases): Pass it.
+ * tree.c (structural_type_p): Improve private base diagnostic.
+
+ PR c++/92560 - ICE with decltype and rewritten operator.
+ * call.c (build_new_op_1): Clear tf_decltype on inner call.
+
+2019-12-09 David Malcolm <dmalcolm@redhat.com>
+
+ * error.c (range_label_for_type_mismatch::get_text): Replace
+ label_text ctor calls with label_text::borrow.
+
+2019-12-09 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * typeck.c (check_for_casting_away_constness): Add location_t
+ parameter and use it.
+ (maybe_warn_about_useless_cast): Likewise.
+ (maybe_warn_about_cast_ignoring_quals): Likewise.
+ (build_static_cast_1): Likewise.
+ (build_static_cast): Likewise; sets the location of the returned tree.
+ (build_reinterpret_cast_1): Likewise.
+ (build_reinterpret_cast): Likewise; sets the location of the returned
+ tree.
+ (build_const_cast_1): Likewise.
+ (build_const_cast): Likewise; sets the location of the returned tree.
+ (cp_build_c_cast): Likewise.
+ (build_c_cast): Adjust.
+ (build_ptrmemfunc): Adjust calls.
+ (cp_build_unary_op): Pass the location to invert_truthvalue_loc.
+ * rtti.c (build_dynamic_cast_1): Add location_t parameter and
+ use it.
+ (build_dynamic_cast): Likewise.
+ * cp-tree.h: Adjust declarations.
+ * parser.c (cp_parser_postfix_expression): Pass cp_cast_loc to
+ the various build_*_cast functions.
+ (get_cast_suggestion): Adjust calls.
+ (cp_parser_builtin_offsetof): Likewise.
+ * decl.c (reshape_init): Adjust call.
+ * method.c (forward_parm): Likewise.
+ (build_comparison_op): Likewise.
+ * pt.c (tsubst_copy_and_build): Likewise.
+ * semantics.c (finish_omp_reduction_clause): Likewise.
+ (cp_omp_finish_iterators): Likewise.
+ * tree.c (cp_stabilize_reference): Likewise.
+ (move): Likewise.
+ * typeck2.c (build_functional_cast): Likewise.
+
+ * typeck2.c (build_functional_cast_1): New.
+ (build_functional_cast_1): Calls the latter and sets the location
+ of the returned tree.
+
+2019-12-08 Jakub Jelinek <jakub@redhat.com>
+
+ * cvt.c (maybe_warn_nodiscard): Add workaround for GCC 3.4-4.4 - cast
+ msg to (const char *) in conditional expressions. Formatting fixes.
+
+2019-12-07 Jason Merrill <jason@redhat.com>
+ Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/92831
+ * call.c (build_conditional_expr_1): For ?: with omitted middle
+ operand use cp_stabilize_reference if arg1 is glvalue_p rather than
+ just if it is lvalue_p.
+
+2019-12-06 Jakub Jelinek <jakub@redhat.com>
+
+ * parser.c (cp_parser_diagnose_invalid_type_name): Mention
+ that concept is also available with -std=c++2a.
+
+ PR c++/92831 - CWG 1299, not extending temporary lifetime for ?:
+ * cp-tree.h (extend_ref_init_temps): Add a new argument with NULL
+ default arg.
+ * call.c (set_up_extended_ref_temp): Add COND_GUARD argument, pass it
+ down to extend_ref_init_temps. Before pushing cleanup, if COND_GUARD
+ is non-NULL, create a bool temporary if needed, initialize to false
+ and guard the cleanup with the temporary being true.
+ (extend_ref_init_temps_1): Add COND_GUARD argument, pass it down
+ to recursive calls and set_up_extended_ref_temp. Handle COND_EXPR.
+ (extend_ref_init_temps): Add COND_GUARD argument, pass it down to
+ recursive calls and to extend_ref_init_temps_1.
+
+2019-12-06 Richard Sandiford <richard.sandiford@arm.com>
+
+ * decl.c (start_decl_1): Use verify_type_context to check whether
+ the target allows variables of a particular type to have static
+ or thread-local storage duration.
+ (check_array_initializer): Use verify_type_context to check whether
+ the target allows a particular type to be used as an array element.
+ (create_array_type_for_decl): Likewise.
+ (cp_finish_decl): Use verify_type_context to check whether
+ the target allows static member variables of a particular type.
+ (grokdeclarator): Likewise. Also use verify_type_context to check
+ whether the target allows non-static member variables of a particular
+ type.
+ * except.c: Include target.h.
+ (is_admissible_throw_operand_or_catch_parameter): Use
+ verify_type_context to check whether the target allows particular
+ types to be thrown and caught.
+ * typeck2.c (add_exception_specifier): Likewise.
+ * init.c (build_new_1): Use verify_type_context to check whether
+ the target allows particular types to be dynamically allocated.
+ (build_vec_delete_1, build_delete): Use verify_type_context to check
+ whether the target allows particular types to be deleted.
+ * lambda.c (add_capture): Use verify_type_context to check
+ whether the target allows particular types to be captured by copy.
+ * pt.c: Include target.h.
+ (instantiate_class_template_1): Use verify_type_context to check
+ whether the target allows non-static member variables of a particular
+ type.
+ * typeck.c (cxx_alignof_expr): Use verify_type_context to check
+ whether the target allows the alignment of a particular type
+ to be measured.
+ (pointer_diff, cp_build_unary_op): Use verify_type_context to check
+ whether the target allows arithmetic involving pointers to particular
+ types.
+
+2019-12-05 Marek Polacek <polacek@redhat.com>
+ Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/91353 - P1331R2: Allow trivial default init in constexpr contexts.
+ * class.c (trivial_default_constructor_is_constexpr): Return true in
+ C++20.
+ * constexpr.c (cx_check_missing_mem_inits): Allow missing field
+ initializers in C++20.
+ (cxx_eval_call_expression): Don't clear CONSTRUCTOR_NO_CLEARING for
+ constexpr constructors in C++20.
+ (reduced_constant_expression_p): Don't set FIELD for union and array
+ types. Skip empty class fields without initializers.
+ * decl.c (check_for_uninitialized_const_var): Permit trivial default
+ initialization in constexpr.
+ (next_initializable_field): Don't skip vptr fields.
+ * method.c (walk_field_subobs): Still consider a constructor that
+ doesn't initialize all the members constexpr.
+
+2019-12-05 Marek Polacek <polacek@redhat.com>
+
+ PR c++/92271 - make __is_same alias for __is_same_as.
+ * cxx-pretty-print.c (pp_cxx_trait_expression) <case CPTK_IS_SAME_AS>:
+ Print "__is_same".
+
+2019-12-05 David Edelsohn <dje.gcc@gmail.com>
+
+ * cp-gimplify.c: Include memmodel.h.
+
+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.
+
+2019-12-04 Marek Polacek <polacek@redhat.com>
+
+ * parser.c (enum primary_constraint_error): Remove stray comma.
+
+2019-12-04 Richard Sandiford <richard.sandiford@arm.com>
+
+ * cp-tree.h (CP_AGGREGATE_TYPE_P): Check for gnu_vector_type_p
+ instead of VECTOR_TYPE.
+ * call.c (build_conditional_expr_1): Restrict vector handling
+ to vectors that satisfy gnu_vector_type_p.
+ * cvt.c (ocp_convert): Only allow vectors to be converted
+ to bool if they satisfy gnu_vector_type_p.
+ (build_expr_type_conversion): Only allow conversions from
+ vectors if they satisfy gnu_vector_type_p.
+ * typeck.c (cp_build_binary_op): Only allow binary operators to be
+ applied to vectors if they satisfy gnu_vector_type_p.
+ (cp_build_unary_op): Likewise unary operators.
+ (build_reinterpret_cast_1):
+
+2019-12-03 Jakub Jelinek <jakub@redhat.com>
+
+ * cp-tree.h (enum cp_tree_index): Add CPTI_SOURCE_LOCATION_IMPL.
+ (source_location_impl): Define.
+ (enum cp_built_in_function): Add CP_BUILT_IN_SOURCE_LOCATION.
+ (fold_builtin_source_location): Declare.
+ * cp-gimplify.c: Include output.h, file-prefix-map.h and cgraph.h.
+ (cp_gimplify_expr, cp_fold): Handle CP_BUILT_IN_SOURCE_LOCATION.
+ Formatting fix.
+ (get_source_location_impl_type): New function.
+ (struct source_location_table_entry,
+ struct source_location_table_entry_hash): New types.
+ (source_location_table, source_location_id): New variables.
+ (fold_builtin_source_location): New function.
+ * constexpr.c (cxx_eval_builtin_function_call): Handle
+ CP_BUILT_IN_SOURCE_LOCATION.
+ * tree.c (builtin_valid_in_constant_expr_p): Likewise. Formatting
+ fix.
+ * decl.c (cxx_init_decl_processing): Register
+ __builtin_source_location.
+ * name-lookup.c (get_std_name_hint): Add source_location entry.
+
+2019-12-03 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * typeck.c (cp_build_addr_expr_1): Use the cp_expr_loc_or_input_loc
+ location in a few additional diagnostics; tidy.
+ (check_return_expr): Likewise.
+
+ * typeck.c (cp_build_addr_expr_1): Use tree_strip_any_location_wrapper
+ for the address of main pedwarn.
+
+2019-12-03 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/91369
+ * constexpr.c (struct constexpr_global_ctx): Add cleanups member,
+ initialize it in the ctor.
+ (cxx_eval_constant_expression) <case TARGET_EXPR>: If TARGET_EXPR_SLOT
+ is already in the values hash_map, don't evaluate it again. Put
+ TARGET_EXPR_SLOT into hash_map even if not lval, and push it into
+ save_exprs too. If there is TARGET_EXPR_CLEANUP and not
+ CLEANUP_EH_ONLY, push the cleanup to cleanups vector.
+ <case CLEANUP_POINT_EXPR>: Save outer cleanups, set cleanups to
+ local auto_vec, after evaluating the body evaluate cleanups and
+ restore previous cleanups.
+ <case TRY_CATCH_EXPR>: Don't crash if the first operand is NULL_TREE.
+ (cxx_eval_outermost_constant_expr): Set cleanups to local auto_vec,
+ after evaluating the expression evaluate cleanups.
+
+2019-12-03 Marek Polacek <polacek@redhat.com>
+
+ PR c++/91363 - P0960R3: Parenthesized initialization of aggregates.
+ * call.c (build_new_method_call_1): Handle parenthesized initialization
+ of aggregates by building up a CONSTRUCTOR.
+ (extend_ref_init_temps): Do nothing for CONSTRUCTOR_IS_PAREN_INIT.
+ * cp-tree.h (CONSTRUCTOR_IS_PAREN_INIT, LOOKUP_AGGREGATE_PAREN_INIT):
+ Define.
+ * decl.c (grok_reference_init): Handle aggregate initialization from
+ a parenthesized list of values.
+ (reshape_init): Do nothing for CONSTRUCTOR_IS_PAREN_INIT.
+ (check_initializer): Handle initialization of an array from a
+ parenthesized list of values. Use NULL_TREE instead of NULL.
+ * tree.c (build_cplus_new): Handle BRACE_ENCLOSED_INITIALIZER_P.
+ * typeck2.c (digest_init_r): Set LOOKUP_AGGREGATE_PAREN_INIT if it
+ receives a CONSTRUCTOR with CONSTRUCTOR_IS_PAREN_INIT set. Allow
+ narrowing when LOOKUP_AGGREGATE_PAREN_INIT.
+ (massage_init_elt): Don't lose LOOKUP_AGGREGATE_PAREN_INIT when passing
+ flags to digest_init_r.
+
+2019-12-03 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/92732
+ * typeck2.c (digest_nsdmi_init): For bitfields, use
+ DECL_BIT_FIELD_TYPE instead of TREE_TYPE.
+
+2019-12-03 Jason Merrill <jason@redhat.com>
+ Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/92705
+ * call.c (strip_standard_conversion): New function.
+ (build_new_op_1): Use it for user_conv_p.
+ (compare_ics): Likewise.
+ (source_type): Likewise.
+
+2019-12-03 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/92695
+ * constexpr.c (cxx_bind_parameters_in_call): For virtual calls,
+ adjust the first argument to point to the derived object rather
+ than its base.
+
+2019-12-02 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/92695
+ * constexpr.c (cxx_eval_constant_expression) <case OBJ_TYPE_REF>: Use
+ STRIP_NOPS before checking for ADDR_EXPR.
+
+2019-11-29 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/60228
+ * parser.c (cp_parser_omp_declare_reduction_exprs): If
+ processing_template_decl, wrap the combiner or initializer
+ into EXPR_STMT.
+ * decl.c (start_preparsed_function): Don't start a lambda scope
+ for DECL_OMP_DECLARE_REDUCTION_P functions.
+ (finish_function): Don't finish a lambda scope for
+ DECL_OMP_DECLARE_REDUCTION_P functions, nor cp_fold_function
+ them nor cp_genericize them.
+ * mangle.c (decl_mangling_context): Look through
+ DECL_OMP_DECLARE_REDUCTION_P functions.
+ * semantics.c (expand_or_defer_fn_1): For DECL_OMP_DECLARE_REDUCTION_P
+ functions, use tentative linkage, don't keep their bodies with
+ -fkeep-inline-functions and return false at the end.
+
+2019-11-28 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/92695
+ * decl2.c (mark_used): Don't call note_vague_linkage_fn for pure
+ virtual functions, even if they are declared inline.
+
+2019-11-16 Jason Merrill <jason@redhat.com>
+
+ Implement P1814R0, CTAD for alias templates.
+ * pt.c (rewrite_tparm_list): Factor out of build_deduction_guide.
+ (maybe_aggr_guide): Check for copy-init here.
+ (alias_ctad_tweaks, deduction_guides_for): New.
+ (ctor_deduction_guides_for): Factor out of do_class_deduction.
+ (ctad_template_p): New.
+ * parser.c (cp_parser_simple_type_specifier): Use it.
+ * constraint.cc (append_constraint): New.
+
+2019-11-16 Jason Merrill <jason@redhat.com>
+
+ * cxx-pretty-print.c (pp_cxx_unqualified_id): Handle alias
+ template-id.
+ * pt.c (complex_alias_template_p): True if constraints.
+ (get_underlying_template, tsubst): Check alias constraints.
+ (push_template_decl_real): Set alias constraints here.
+ * parser.c (cp_parser_alias_declaration): Not here.
+ * constraint.cc (get_constraints): Take const_tree.
+
+2019-11-12 Jason Merrill <jason@redhat.com>
+
+ PR c++/92206 - ICE with typedef to dependent alias.
+ * pt.c (dependent_alias_template_spec_p)
+ (alias_template_specialization_p): Add transparent_typedefs
+ parameter.
+ (iterative_hash_template_arg, any_template_parm_r)
+ (primary_template_specialization_p, tsubst, dependent_type_p_r):
+ Adjust.
+ * decl.c (check_elaborated_type_specifier): Adjust.
+ * error.c (dump_template_bindings, dump_aggr_type): Adjust.
+
+2019-11-27 Andrew Sutton <asutton@lock3software.com>
+
+ PR c++/92236
+ Defer evaluation of concept checks so that static assertions can
+ emit more detailed diagnostics.
+ * constexpr.c (cxx_eval_call_expression): Handle concept checks.
+ (cxx_eval_constant_expression): Diagnose misuse of function concepts
+ as template-id expressions. Follow the usual return path for results.
+ (cxx_eval_outermost_constant_expr): Avoid calling
+ cp_get_callee_fndecl_nofold for function concepts.
+ * constraint.cc (build_function_check): Fully type the concept check
+ so that we don't ICE in conversions.
+ * cp-gimplify.c (cp_genericize_r) [CALL_EXPR]: Handle concept checks.
+ [TEMPLATE_ID_EXPR] Likewise.
+ * cvt.c (convert_to_void): Always evaluate concept checks so we don't
+ accidentally ignore them. Substitution during satisfaction can make
+ a program ill-formed (example in g++.dg/cpp2a/concepts6.C).
+ * pt.c (tsubst_copy_and_build): [CALL_EXPR]: Don't evaluate concepts.
+ [TEMPLATE_ID_EXPR]: Likewise.
+ * semantics.c (finish_call_expr): Don't evaluate concepts.
+ (finish_id_expression_1): Likewise.
+ (finish_static_assert): Preserve the original condition so we can
+ diagnose concept errors when a check returns false.
+
+2019-11-27 Andrew Sutton <asutton@lock3software.com>
+
+ PR c++/92439
+ Improve quality of diagnostics for subexpressions that need parens.
+ * parser.c (cp_parser_requires_clause_opt): Add a flag to indicate
+ when parsing a requires-clause before lambda parameters, and...
+ (cp_parser_lambda_declarator_opt): ... use that here ...
+ (cp_parser_type_parameter): ... and here ...
+ (cp_parser_late_return_type_opt): ... and here ...
+ (cp_parser_explicit_template_declaration): ... and here.
+ (cp_parser_diagnose_ungrouped_constraint_plain): Adjust the message
+ because this can apply to subexpressions that are not immediately
+ after a requires-clause.
+ (cp_parser_diagnose_ungrouped_constraint_rich): Likewise.
+ (primary_constraint_error): New.
+ (cp_parser_constraint_requires_parens): New.
+ (cp_parser_unary_constraint_requires_parens): New.
+ (cp_parser_constraint_primary_expression): Check for unary expressions
+ before parsing the primary expression. Also check for binary and
+ postfix operators after a successful parse of the primary expression.
+ Force a re-parse if the result would form a lower-precedence string.
+ (cp_parser_constraint_logical_and_expression): Propagate lambda flag;
+ move checks for ill-formed constraints into the constraint primary
+ expression.
+ (cp_parser_constraint_logical_or_expression): Likewise.
+ (cp_parser_requires_clause_expression): Propagate lambda flag.
+
+2019-11-27 Andrew Sutton <asutton@lock3software.com>
+
+ PR c++/88395
+ * constraint.cc (satisfy_declaration_constraints): Push tinst levels
+ around satisfaction.
+
+2019-11-27 Andrew Sutton <asutton@lock3software.com>
+
+ Diagnose certain constraint errors as hard errors, but otherwise treat
+ them the same as normal SFINAE-type errors. Also, generally clean up
+ the satisfaction functions.
+
+ * constexpr.c (cxx_eval_constant_expression): Use
+ evaluate_concept_check.
+ * constraint.cc (normalize_concept_definition): Accept a diagnostic
+ flag and only cache when not diagnosing errors.
+ (decl_satisfied_cache): Map to trees instead of bools.
+ (satisfy_atom): Guarantee a location for the errors, propagate complain
+ flags to force_rvalue, and emit errors for non-boolean constraints.
+ (get_normalized_constraints_and_args): New overloads. Factored out of
+ satisfy_constraint_expression and satisfy_declaration_constraints.
+ (satisfy_constraint_expression): Propagate diagnostic info to
+ normalization.
+ (satisfy_declaration_constraints): New. Factored out of
+ constraints_satisfied_p.
+ (constraint_satisfaction_value): New. Calls
+ satisfy_constraint_expression or satisfy_declaration_constraints.
+ (constraints_satisfied_p): Call constraint_satisfaction_value.
+ (evaluate_concept_check): Don't take tsubst_falgs_t. Replay
+ satisfaction if an error is encountered.
+ (current_failed_constraint): Moved from pt.c.
+ (diagnose_constraints): Call constraint_satisfaction_value.
+ * cp-tree.h: Update declarations.
+ * pt.c (current_failed_constraint): Moved to constraint.cc.
+ * semantics.c (finish_id_expression_1): Remove a duplicate case.
+
+2019-11-27 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/92524
+ * tree.c (replace_placeholders_r): Don't walk constructor elts with
+ RANGE_EXPR indexes.
+
+2019-11-26 Jason Merrill <jason@redhat.com>
+
+ * pt.c (tsubst_copy_and_build) [TEMPLATE_ID_EXPR]: Remember the
+ location of a variable template-id.
+ * constexpr.c (cxx_eval_constant_expression): Get expr location
+ before stripping location wrappers.
+ (non_const_var_error): Take location argument.
+
+2019-11-26 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * typeck.c (cp_build_unary_op): Consistently use the accurate
+ location in seven additional diagnostic messages.
+ (cp_build_compound_expr): Use cp_expr_loc_or_input_loc in one place.
+
+2019-11-26 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/92648
+ * parser.c (cp_parser_std_attribute): For unknown attributes,
+ skip balanced token seq instead of trying to parse
+ attribute-argument-clause as expression list. Formatting fix.
+
+ PR c++/61414
+ * class.c (enum_to_min_precision): New hash_map.
+ (enum_min_precision): New function.
+ (check_bitfield_decl): Use it.
+
+2019-11-25 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * typeck.c (cp_build_indirect_ref_1): Add location_t parameter
+ and use it in error messages.
+ (build_x_indirect_ref): Adjust call.
+ (build_indirect_ref): Likewise.
+ (cp_build_fold_indirect_ref): Likewise.
+ (cp_build_array_ref): Likewise.
+ * call.c (build_new_op_1): Likewise.
+ * semantics.c (finish_omp_clauses): Likewise.
+ (finish_omp_depobj): Likewise.
+ * typeck2.c (build_x_arrow): Likewise.
+ * cp-tree.h (cp_build_indirect_ref): Update declaration.
+
+ * call.c (build_new_op_1): Use location argument in warning_at.
+
+ * typeck.c (cp_build_modify_expr): Consistently use the
+ location_t argument.
+
+2019-11-23 Bernd Edlinger <bernd.edlinger@hotmail.de>
+
+ PR c++/92365
+ * name-lookup.c (check_local_shadow): Use can_convert_arg
+ instead of can_convert.
+
+2019-11-22 Marek Polacek <polacek@redhat.com>
+
+ PR c++/88337 - P1327R1: Allow polymorphic typeid in constexpr.
+ * constexpr.c (potential_constant_expression_1): Allow a typeid
+ expression whose operand is of polymorphic type in constexpr in
+ C++20.
+ * rtti.c (build_typeid): Remove obsolete FIXME comment.
+
+2019-11-22 Jakub Jelinek <jakub@redhat.com>
+
+ PR c/90677
+ * cp-objcp-common.c (identifier_global_tag): Define.
+
+ PR c++/92458
+ * init.c (nsdmi_inst): Change type to
+ decl_tree_cache_map * from tree_cache_map *.
+ * constraint.cc (decl_constraints): Likewise.
+ * decl.c (get_tuple_decomp_init): Likewise.
+ * pt.c (defarg_inst, explicit_specifier_map): Likewise.
+ (tsubst_default_argument, store_explicit_specifier): Use
+ decl_tree_cache_map::create_ggc rather than
+ tree_cache_map::create_ggc.
+ * cp-objcp-common.c (debug_type_map): Change type to
+ type_tree_cache_map * from tree_cache_map *.
+
+2019-11-21 Marek Polacek <polacek@redhat.com>
+
+ PR c++/92450 - ICE with invalid nested name specifier.
+ * parser.c (cp_parser_member_declaration): Don't attempt to print
+ erroneous bit-field diagnostic if grokdeclarator returns
+ error_mark_node.
+
+2019-11-21 Jakub Jelinek <jakub@redhat.com>
+ Jason Merrill <jason@redhat.com>
+
+ PR c++/90842
+ * parser.c (cp_parser_decl_specifier_seq): For concept or typedef
+ break early if CP_PARSER_FLAGS_ONLY_MUTABLE_OR_CONSTEXPR.
+ For type specifiers, set CP_PARSER_FLAGS_NO_TYPE_DEFINITIONS
+ if CP_PARSER_FLAGS_ONLY_MUTABLE_OR_CONSTEXPR is set.
+
+2019-11-20 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * typeck2.c (build_x_arrow): Early return if decay_conversion
+ returns error_mark_node.
+
+2019-11-20 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/90767
+ * call.c (complain_about_no_candidates_for_method_call): If
+ conv->from is not a type, pass to complain_about_bad_argument
+ lvalue_type of conv->from.
+
+2019-11-20 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * cvt.c (ocp_convert): Use additional warning sentinel.
+
+2019-11-19 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/92414
+ * constexpr.c (cxx_eval_outermost_constant_expr): If DECL_INITIAL
+ on object is erroneous, return t without trying to evaluate
+ a constexpr dtor.
+
+2019-11-12 Jason Merrill <jason@redhat.com>
+
+ * call.c (same_fn_or_template): Change to cand_parms_match.
+ (joust): Adjust.
+ (print_z_candidate): Mark rewritten/reversed candidates.
+ (build_new_op_1): Warn about recursive call with reversed arguments.
+
+2019-11-15 Andrew Sutton <asutton@lock3software.com>
+
+ PR c++/89913
+ * pt.c (get_underlying_template): Exit loop if the original type
+ of the alias is null.
+
+2019-11-19 Andrew Sutton <asutton@lock3software.com>
+
+ PR c++/92078
+ * pt.c (maybe_new_partial_specialization): Apply access to newly
+ created partial specializations. Update comment style.
+
+2019-11-19 Andrew Sutton <asutton@lock3software.com>
+
+ PR c++/92078
+ * pt.c (maybe_new_partial_specialization): Apply access to newly
+ created partial specializations. Update comment style.
+
+2019-11-19 Andrew Sutton <asutton@lock3software.com>
+
+ PR c++/92403
+ Suppress diagnostics substituting into a requires-expression.
+ * pt.c (tsubst_copy_and_build): Perform the first substitution without
+ diagnostics and a second only if tsubst_requries_expr returns an error.
+
+2019-11-19 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/92504
+ * semantics.c (handle_omp_for_class_iterator): Don't call
+ cp_fully_fold on cond.
+
+2019-11-18 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * typeck.c (cp_build_addr_expr_1): Use cp_expr_loc_or_input_loc
+ in three places.
+ (cxx_sizeof_expr): Use it in one additional place.
+ (cxx_alignof_expr): Likewise.
+ (lvalue_or_else): Likewise.
+
+2019-11-18 Marek Polacek <polacek@redhat.com>
+
+ PR c++/91962 - ICE with reference binding and qualification conversion.
+ * call.c (convert_like_real) <case ck_ref_bind>: Check need_temporary_p.
+
+2019-11-17 Jakub Jelinek <jakub@redhat.com>
+
+ * method.c (lookup_comparison_result): Use %qD instead of %<%T::%D%>
+ to print the decl.
+ (lookup_comparison_category): Use %qD instead of %<std::%D%> to print
+ the decl.
+
+2019-11-15 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * typeck.c (cp_truthvalue_conversion): Add tsubst_flags_t parameter
+ and use it in calls; also pass the location_t of the expression to
+ cp_build_binary_op and c_common_truthvalue_conversion.
+ * rtti.c (build_dynamic_cast_1): Adjust call.
+ * cvt.c (ocp_convert): Likewise.
+ * cp-gimplify.c (cp_fold): Likewise.
+ * cp-tree.h (cp_truthvalue_conversion): Update declaration.
+
+2019-11-14 Jason Merrill <jason@redhat.com>
+
+ Implement P1816R0, class template argument deduction for aggregates.
+ * pt.c (maybe_aggr_guide, collect_ctor_idx_types): New.
+ (is_spec_or_derived): Split out from do_class_deduction.
+ (build_deduction_guide): Handle aggregate guide.
+ * class.c (finish_struct): Set CLASSTYPE_NON_AGGREGATE in a
+ template.
+ * cp-tree.h (CP_AGGREGATE_TYPE_P): An incomplete class is not an
+ aggregate.
+
+2019-11-14 Richard Sandiford <richard.sandiford@arm.com>
+
+ * call.c (build_conditional_expr_1): Use truth_type_for instead
+ of build_same_sized_truth_vector_type.
+ * typeck.c (build_vec_cmp): Likewise.
+
+2019-11-14 Jakub Jelinek <jakub@redhat.com>
+
+ * parser.c (cp_parser_omp_context_selector): Don't require score
+ argument to fit into shwi, just to be INTEGER_CST. Diagnose
+ negative score.
+ * pt.c (tsubst_attribute): Likewise.
+
+ * parser.c (cp_parser_omp_context_selector): Rename
+ CTX_PROPERTY_IDLIST to CTX_PROPERTY_NAME_LIST, add CTX_PROPERTY_ID.
+ Use CTX_PROPERTY_ID for atomic_default_mem_order, only allow a single
+ identifier in that. For CTX_PROPERTY_NAME_LIST, allow identifiers
+ and string literals.
+ * pt.c (tsubst_attribute): Fix up STRING_CST handling if allow_string.
+
+2019-11-13 Marek Polacek <polacek@redhat.com>
+
+ PR c++/89070 - bogus [[nodiscard]] warning in SFINAE.
+ * cvt.c (convert_to_void): Guard maybe_warn_nodiscard calls with
+ tf_warning.
+
+2019-11-13 Richard Sandiford <richard.sandiford@arm.com>
+
+ PR c++/92206
+ * cp-tree.h (STF_STRIP_DEPENDENT): New constant.
+ * tree.c (strip_typedefs): Add STF_STRIP_DEPENDENT to the flags
+ when calling strip_typedefs recursively on a DECL_ORIGINAL_TYPE.
+ Don't apply the fix for DR1558 in that case; allow aliases with
+ dependent template parameters to be stripped instead.
+
+2019-11-12 Nathan Sidwell <nathan@acm.org>
+
+ * name-lookup.c (lookup_using_decl): New function, merged from ...
+ (do_class_using_decl): ... here. Call it. And ...
+ (finish_nonmember_using_decl): ... here. Call it.
+
+2019-11-12 Martin Liska <mliska@suse.cz>
+
+ * name-lookup.c: Do not include params.h.
+ * typeck.c: Likewise.
+
+2019-11-12 Martin Liska <mliska@suse.cz>
+
+ * name-lookup.c (namespace_hints::namespace_hints): Replace old
+ parameter syntax with the new one, include opts.h if needed. Use
+ SET_OPTION_IF_UNSET macro.
+ * typeck.c (comptypes): Likewise.
+
+2019-11-12 Maciej W. Rozycki <macro@codesourcery.com>
+ Frederik Harwath <frederik@codesourcery.com>
+
+ gcc/cp/
+ * constexpr.c (potential_constant_expression_1): Handle
+ OACC_SERIAL.
+ * parser.c (OACC_SERIAL_CLAUSE_MASK): New macro.
+ (cp_parser_oacc_kernels_parallel): Rename function to...
+ (cp_parser_oacc_compute): ... this. Handle PRAGMA_OACC_SERIAL.
+ (cp_parser_omp_construct): Update accordingly.
+ (cp_parser_pragma): Handle PRAGMA_OACC_SERIAL. Fix alphabetic
+ order.
+ * pt.c (tsubst_expr): Handle OACC_SERIAL.
+
+2019-11-11 Jason Merrill <jason@redhat.com>
+
+ Implement P1946R0, Allow defaulting comparisons by value.
+ * method.c (early_check_defaulted_comparison): Accept by-value,
+ reject mixed by-value and by-reference parms.
+ * decl.c (grokdeclarator): Set funcdef_flag for defaulted friend.
+ * decl2.c (grokfield): Don't SET_DECL_FRIEND_CONTEXT.
+
+ * typeck.c (cp_build_binary_op): Sorry about <=> on VECTOR_TYPE.
+
+2019-11-11 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/92447
+ * decl.c (finish_function): Move ctype initialization before
+ DECL_DELETED_FN handling.
+
+ * semantics.c (finish_translation_unit): Diagnose declare target
+ without corresponding end declare target.
+
+2019-11-10 Jason Merrill <jason@redhat.com>
+
+ Implement D1957R0, T* to bool should be considered narrowing.
+ * typeck2.c (check_narrowing): Treat pointer->bool as a narrowing
+ conversion with -std=c++2a.
+
+2019-11-08 Marek Polacek <polacek@redhat.com>
+
+ PR c++/92215 - flawed diagnostic for bit-field with non-integral type.
+ * parser.c (cp_parser_member_declaration): Add a diagnostic for
+ bit-fields with non-integral types.
+
+2019-11-08 Jakub Jelinek <jakub@redhat.com>
+
+ * init.c (build_vec_delete_1): Fix a comment typo - mist -> must.
+
+2019-11-07 Jason Merrill <jason@redhat.com>
+
+ Implement D1959R0, remove weak_equality and strong_equality.
+ * method.c (enum comp_cat_tag, comp_cat_info): Remove *_equality.
+ (genericize_spaceship, common_comparison_type): Likewise.
+ * typeck.c (cp_build_binary_op): Move SPACESHIP_EXPR to be with the
+ relational operators, exclude other types no longer supported.
+
+2019-11-06 Jason Merrill <jason@redhat.com>
+
+ Implement D1907R1 "structural type".
+ * tree.c (structural_type_p): New.
+ * pt.c (invalid_nontype_parm_type_p): Use it.
+ * class.c (build_base_field_1): Take binfo. Copy TREE_PRIVATE.
+ (build_base_field): Pass binfo.
+
+ PR c++/92150 - partial specialization with class NTTP.
+ * pt.c (unify): Handle VIEW_CONVERT_EXPR.
+
+ * pt.c (use_pack_expansion_extra_args_p): Still do substitution if
+ all packs are simple pack expansions.
+ (add_extra_args): Check that the extra args aren't dependent.
+
+2019-11-06 Andrew Sutton <asutton@lock3software.com>
+
+ Use satisfaction with nested requirements.
+ * constraint.cc (build_parameter_mapping): Use
+ current_template_parms when the declaration is not available.
+ (norm_info::norm_info) Make explicit.
+ (normalize_constraint_expression): Factor into a separate overload
+ that takes arguments, and use that in the original function.
+ (tsubst_nested_requirement): Use satisfy_constraint instead of
+ trying to evaluate this as a constant expression.
+ (finish_nested_requirement): Keep the normalized constraint and the
+ original normalization arguments with the requirement.
+ (diagnose_nested_requirement): Use satisfy_constraint. Tentatively
+ implement more comprehensive diagnostics, but do not enable.
+ * parser.c (cp_parser_requires_expression): Relax requirement that
+ requires-expressions can live only inside templates.
+ * pt.c (any_template_parm_r): Look into type of PARM_DECL.
+
+2019-11-06 Jason Merrill <jason@redhat.com>
+
+ C++20 NB CA378 - Remove constrained non-template functions.
+ * decl.c (grokfndecl): Reject constraints on non-templated function.
+
+2019-11-06 Matthias Kretz <m.kretz@gsi.de>
+
+ * parser.c (cp_parser_operator): Parse operator?: as an
+ attempt to overload the conditional operator.
+
+2019-11-05 Jason Merrill <jason@redhat.com>
+
+ Implement C++20 operator<=>.
+ * cp-tree.h (struct lang_decl_fn): Add maybe_deleted bitfield.
+ (DECL_MAYBE_DELETED): New.
+ (enum special_function_kind): Add sfk_comparison.
+ (LOOKUP_REWRITTEN, LOOKUP_REVERSED): New.
+ * call.c (struct z_candidate): Add rewritten and reversed methods.
+ (add_builtin_candidate): Handle SPACESHIP_EXPR.
+ (add_builtin_candidates): Likewise.
+ (add_candidates): Don't add a reversed candidate if the parms are
+ the same.
+ (add_operator_candidates): Split out from build_new_op_1. Handle
+ rewritten and reversed candidates.
+ (add_candidate): Swap conversions of reversed candidate.
+ (build_new_op_1): Swap them back. Build a second operation for
+ rewritten candidates.
+ (extract_call_expr): Handle rewritten calls.
+ (same_fn_or_template): New.
+ (joust): Handle rewritten and reversed candidates.
+ * class.c (add_implicitly_declared_members): Add implicit op==.
+ (classtype_has_op, classtype_has_defaulted_op): New.
+ * constexpr.c (cxx_eval_binary_expression): Handle SPACESHIP_EXPR.
+ (cxx_eval_constant_expression, potential_constant_expression_1):
+ Likewise.
+ * cp-gimplify.c (genericize_spaceship): New.
+ (cp_genericize_r): Use it.
+ * cp-objcp-common.c (cp_common_init_ts): Handle SPACESHIP_EXPR.
+ * decl.c (finish_function): Handle deleted function.
+ * decl2.c (grokfield): SET_DECL_FRIEND_CONTEXT on defaulted friend.
+ (mark_used): Check DECL_MAYBE_DELETED. Remove assumption that
+ defaulted functions are non-static members.
+ * error.c (dump_expr): Handle SPACESHIP_EXPR.
+ * method.c (type_has_trivial_fn): False for sfk_comparison.
+ (enum comp_cat_tag, struct comp_cat_info_t): New types.
+ (comp_cat_cache): New array variable.
+ (lookup_comparison_result, lookup_comparison_category)
+ (is_cat, cat_tag_for, spaceship_comp_cat)
+ (spaceship_type, genericize_spaceship)
+ (common_comparison_type, early_check_defaulted_comparison)
+ (comp_info, build_comparison_op): New.
+ (synthesize_method): Handle sfk_comparison. Handle deleted.
+ (get_defaulted_eh_spec, maybe_explain_implicit_delete)
+ (explain_implicit_non_constexpr, implicitly_declare_fn)
+ (defaulted_late_check, defaultable_fn_check): Handle sfk_comparison.
+ * name-lookup.c (get_std_name_hint): Add comparison categories.
+ * tree.c (special_function_p): Add sfk_comparison.
+ * typeck.c (cp_build_binary_op): Handle SPACESHIP_EXPR.
+
+2019-11-05 Tim van Deurzen <tim@kompiler.org>
+
+ Add new tree code for the spaceship operator.
+ * cp-tree.def: Add new tree code.
+ * operators.def: New binary operator.
+ * parser.c: Add new token and tree code.
+
+2019-09-15 Jason Merrill <jason@redhat.com>
+
+ * call.c (build_new_op_1): Don't apply any standard conversions to
+ the operands of a built-in operator. Don't suppress conversions in
+ cp_build_unary_op.
+ * typeck.c (cp_build_unary_op): Do integral promotions for enums.
+
+2019-11-04 Jason Merrill <jason@redhat.com>
+
+ Use vec instead of raw array for built-in candidates.
+ * call.c (build_builtin_candidate): Take args in a vec.
+ (add_builtin_candidate, add_builtin_candidates): Likewise.
+ (build_conditional_expr_1, build_new_op_1): Adjust.
+
+2019-11-04 Jason Merrill <jason@redhat.com>
+
+ * constexpr.c (explain_invalid_constexpr_fn): Show location of fn.
+
+ * pt.c (maybe_instantiate_noexcept): Only update clones if we
+ instantiated.
+
+ * typeck.c (contextual_conv_bool): New.
+
+ * name-lookup.c (lookup_qualified_name): Add wrapper overload taking
+ C string rather than identifier.
+ * parser.c (cp_parser_userdef_numeric_literal): Use it.
+ * rtti.c (emit_support_tinfos): Use it.
+ * cp-tree.h (ovl_op_identifier): Change to inline functions.
+ (build_x_binary_op): Add wrapper with fewer parms.
+
+2019-11-05 Jason Merrill <jason@redhat.com>
+
+ * decl2.c (mark_used): Diagnose use of a function with unsatisfied
+ constraints here.
+ * typeck.c (cp_build_function_call_vec): Not here.
+
+2019-11-05 Nathan Sidwell <nathan@acm.org>
+
+ PR c++/92370
+ * parser.c (cp_parser_error_1): Check EOF and UNKNOWN_LOCATION
+ when skipping over version control marker.
+
+2019-11-05 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/92343
+ * constexpr.c (potential_constant_expression_1): Return true rather
+ than false for PREDICT_EXPR.
+
+ * decl.c (omp_declare_variant_finalize_one): Call
+ declare_simd_adjust_this not just on the context, but also on the
+ variant-id expression for methods. Don't call
+ cp_get_callee_fndecl_nofold, call cp_get_callee and only if it is
+ safe cp_get_fndecl_from_callee. Don't try to print as %qD
+ NULL in diagnostics.
+ * pt.c (tsubst_attribute): Handle "omp declare variant base"
+ attribute.
+ (tsubst_function_decl): Call omp_declare_variant_finalize
+ if there are any "omp declare variant base" attributes left.
+
+2019-11-04 Kamlesh Kumar <kamleshbhalui@gmail.com>
+
+ PR c++/91979 - mangling nullptr expression
+ * mangle.c (write_template_arg_literal): Handle nullptr
+ mangling.
+
+2019-11-04 Jason Merrill <jason@redhat.com>
+
+ * typeck.c (check_return_expr): Avoid redundant error.
+
+2019-11-02 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * typeck.c (composite_pointer_type): Add a const op_location_t&
+ parameter and use it in diagnostics.
+ (composite_pointer_error): Likewise.
+ (composite_pointer_type_r): Add a const op_location_t&
+ parameter and forward it.
+ (cp_build_binary_op): Adjust calls.
+ (common_pointer_type): Likewise.
+ * call.c (add_builtin_candidate): Likewise.
+ (build_conditional_expr_1): Likewise.
+ * cp-tree.h (composite_pointer_type): Update declaration.
+
+ * typeck.c (cxx_sizeof_expr): Use cp_expr_loc_or_input_loc
+ in permerror.
+ (cxx_alignof_expr): Likewise.
+ (lvalue_or_else): Likewise.
+
+2019-11-02 Jakub Jelinek <jakub@redhat.com>
+
+ * decl.c (omp_declare_variant_finalize_one): Use
+ omp_get_context_selector instead of c_omp_get_context_selector.
+
+ PR c++/89640
+ * parser.c (cp_parser_decl_specifier_seq): Don't parse attributes
+ if CP_PARSER_FLAGS_ONLY_MUTABLE_OR_CONSTEXPR.
+
+ PR c++/88335 - Implement P1073R3: Immediate functions
+ * cp-tree.h (struct lang_decl_fn): Add immediate_fn_p bit.
+ (DECL_IMMEDIATE_FUNCTION_P, SET_DECL_IMMEDIATE_FUNCTION_P): Define.
+ (enum cp_decl_spec): Add ds_consteval.
+ (fold_non_dependent_expr): Add another tree argument defaulted to
+ NULL_TREE.
+ * name-lookup.h (struct cp_binding_level): Add immediate_fn_ctx_p
+ member.
+ * parser.c (cp_keyword_starts_decl_specifier_p): Adjust comments
+ for C++11 and C++20 specifiers. Handle RID_CONSTEVAL.
+ (CP_PARSER_FLAGS_ONLY_MUTABLE_OR_CONSTEXPR): Adjust comment.
+ (CP_PARSER_FLAGS_CONSTEVAL): New.
+ (cp_parser_skip_balanced_tokens): New forward declaration.
+ (cp_parser_lambda_declarator_opt): Handle ds_consteval. Set
+ current_binding_level->immediate_fn_ctx_p before parsing parameter
+ list if decl-specifier-seq contains consteval specifier.
+ (cp_parser_decl_specifier_seq): Handle RID_CONSTEVAL.
+ (cp_parser_explicit_instantiation): Diagnose explicit instantiation
+ with consteval specifier.
+ (cp_parser_init_declarator): For consteval or into flags
+ CP_PARSER_FLAGS_CONSTEVAL.
+ (cp_parser_direct_declarator): If CP_PARSER_FLAGS_CONSTEVAL, set
+ current_binding_level->immediate_fn_ctx_p in the sk_function_parms
+ scope.
+ (set_and_check_decl_spec_loc): Add consteval entry, formatting fix.
+ * call.c (build_addr_func): For direct calls to immediate functions
+ use build_address rather than decay_conversion.
+ (build_over_call): Evaluate immediate function invocations.
+ * error.c (dump_function_decl): Handle DECL_IMMEDIATE_FUNCTION_P.
+ * semantics.c (expand_or_defer_fn_1): Use tentative linkage and don't
+ call mark_needed for immediate functions.
+ * typeck.c (cxx_sizeof_or_alignof_expr): Likewise. Formatting fix.
+ (cp_build_addr_expr_1): Reject taking address of immediate function
+ outside of immediate function.
+ * decl.c (validate_constexpr_redeclaration): Diagnose consteval
+ vs. non-consteval or vice versa redeclaration. Use
+ SET_DECL_IMMEDIATE_FUNCTION_P if new_decl is immediate function.
+ (check_tag_decl): Use %qs with keyword string to simplify translation.
+ Handle ds_consteval.
+ (start_decl): Adjust diagnostics for static or thread_local variables
+ in immediate functions.
+ (grokfndecl): Call sorry_at on virtual consteval. Use %qs with keyword
+ to string to simplify translation. Diagnose consteval main. Use
+ SET_DECL_IMMEDIATE_FUNCTION_P for consteval.
+ (grokdeclarator): Handle consteval. Use %qs with keyword strings to
+ simplify translation. Use separate ifs instead of chained else if
+ for invalid specifiers. For constinit clear constinit_p rather than
+ constexpr_p.
+ * constexpr.c (find_immediate_fndecl): New function.
+ (cxx_eval_outermost_constant_expr): Allow consteval calls returning
+ void. Diagnose returning address of immediate function from consteval
+ evaluation.
+ (fold_non_dependent_expr_template): Add OBJECT argument, pass it
+ through to cxx_eval_outermost_constant_expr.
+ (fold_non_dependent_expr): Add OBJECT argument, pass it through to
+ fold_non_dependent_expr_template.
+ (fold_non_dependent_init): Adjust fold_non_dependent_expr_template
+ caller.
+ * method.c (defaulted_late_check): Adjust diagnostics for consteval.
+ * lambda.c (maybe_add_lambda_conv_op): Copy over
+ DECL_DECLARED_CONSTEXPR_P and DECL_IMMEDIATE_FUNCTION_P bits from
+ callop to both artificial functions.
+ * init.c (build_value_init): Don't do further processing if
+ build_special_member_call returned a TREE_CONSTANT. Formatting fix.
+
+ PR c++/91369 - Implement P0784R7: constexpr new
+ * cp-tree.h (CALL_FROM_NEW_OR_DELETE_P): Define.
+ * init.c (build_new_1, build_vec_delete_1, build_delete): Set
+ CALL_FROM_NEW_OR_DELETE_P on the CALL_EXPR to allocator functions.
+ * constexpr.c (is_std_allocator_allocate): Only allow
+ global replaceable allocator functions if CALL_FROM_NEW_OR_DELETE_P
+ or in std::allocate<T>::{,de}allocate.
+ (potential_constant_expression_1): Likewise.
+
+2019-11-01 Nathan Sidwell <nathan@acm.org>
+
+ * class.c (check_field_decls): Refactor.
+
+2019-10-31 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/90947
+ * cp-tree.h (type_initializer_zero_p): Declare.
+ * decl.c (reshape_init_array_1): Formatting fix.
+ * tree.c (type_initializer_zero_p): New function. Moved from
+ ../tree.c, use next_initializable_field, formatting fix. Return
+ false for TYPE_NON_AGGREGATE_CLASS types.
+
+2019-10-30 Jason Merrill <jason@redhat.com>
+
+ PR c++/92268 - hard error satisfying return-type-requirement
+ * constraint.cc (type_deducible_p): Check for substitution failure.
+ (diagnose_compound_requirement): Adjust diagnostic.
+ * pt.c (do_auto_deduction): Don't pass cargs to
+ constraints_satisfied_p.
+
+2019-10-30 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/91369 - Implement P0784R7: constexpr new
+ * constexpr.c (cxx_replaceable_global_alloc_fn): Don't return true
+ for placement new.
+ (cxx_placement_new_fn, is_std_construct_at): New functions.
+ (cxx_eval_call_expression): Allow placement new in std::construct_at.
+ (potential_constant_expression_1): Likewise.
+
+ * typeck.c (decl_in_std_namespace_p): Return true also for decls
+ in inline namespaces inside of std namespace.
+
+2019-10-30 Bernd Edlinger <bernd.edlinger@hotmail.de>
+
+ PR c++/92024
+ * name-lookup.c (check_local_shadow): Shadowing TYPE_DECLs
+ is always a -Wshadow=compatible-local warning, unless
+ -Wshadow is used.
+
+2019-10-30 Jason Merrill <jason@redhat.com>
+
+ * cxx-pretty-print.c (get_fold_operator): Use OVL_OP_INFO.
+
+2019-10-30 Marek Polacek <polacek@redhat.com>
+
+ PR c++/92134 - constinit malfunction in static data member.
+ * decl2.c (grokfield): Set LOOKUP_CONSTINIT.
+
+2019-10-30 Jakub Jelinek <jakub@redhat.com>
+
+ * cp-tree.h (omp_declare_variant_finalize, build_local_temp): Declare.
+ * decl.c: Include omp-general.h.
+ (declare_simd_adjust_this): Add forward declaration.
+ (omp_declare_variant_finalize_one, omp_declare_variant_finalize): New
+ function.
+ (cp_finish_decl, finish_function): Call omp_declare_variant_finalize.
+ * parser.c (cp_finish_omp_declare_variant): Adjust parsing of the
+ variant id-expression and propagate enough information to
+ omp_declare_variant_finalize_one in the attribute so that it can
+ finalize it.
+ * class.c (finish_struct): Call omp_declare_variant_finalize.
+ * tree.c (build_local_temp): No longer static, remove forward
+ declaration.
+
+2019-10-30 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * typeck.c (cp_build_modify_expr): Prefer error + inform to
+ error + error in one place.
+ (get_delta_difference_1): Likewise.
+ (get_delta_difference): Likewise, in two places.
+
+2019-10-29 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * typeck.c (build_x_unary_op): Use the location_t argument in
+ three error_at.
+
+2019-10-29 Marek Polacek <polacek@redhat.com>
+
+ PR c++/90998 - ICE with copy elision in init by ctor and -Wconversion.
+ * call.c (joust): Don't attempt to warn if ->second_conv is null.
+
+2019-10-29 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/92201
+ * cp-gimplify.c (cp_gimplify_expr): If gimplify_to_rvalue changes the
+ function pointer type, re-add cast to the original one.
+
+2019-10-29 Marek Polacek <polacek@redhat.com>
+
+ PR c++/91548 - fix detecting modifying const objects for ARRAY_REF.
+ * constexpr.c (cxx_eval_store_expression): Don't call
+ modifying_const_object_p for ARRAY_REF.
+
+2019-10-29 Richard Sandiford <richard.sandiford@arm.com>
+
+ * cp-objcp-common.h (cxx_simulate_enum_decl): Declare.
+ (LANG_HOOKS_SIMULATE_ENUM_DECL): Define to the above.
+ * decl.c (cxx_simulate_enum_decl): New function.
+
+2019-10-29 Richard Sandiford <richard.sandiford@arm.com>
+
+ * cp-tree.h (cxx_simulate_builtin_function_decl): Declare.
+ * decl.c (cxx_simulate_builtin_function_decl): New function.
+ * cp-objcp-common.h (LANG_HOOKS_SIMULATE_BUILTIN_FUNCTION_DECL):
+ Define to the above.
+
+2019-10-28 Martin Sebor <msebor@redhat.com>
+
+ PR c/66970
+ * cp-objcp-common.c (names_builtin_p): Define new function.
+
+2019-10-28 Nathan Sidwell <nathan@acm.org>
+
+ * parser.h (struct cp_token): Drop {ENUM,BOOL}_BITFIELD C-ism.
+ Add tree_check_p flag, use as nested union discriminator.
+ (struct cp_lexer): Add saved_type & saved_keyword fields.
+ * parser.c (eof_token): Delete.
+ (cp_lexer_new_main): Always init last_token to last token of
+ buffer.
+ (cp_lexer_new_from_tokens): Overlay EOF token at end of range.
+ (cp_lexer_destroy): Restore token under the EOF.
+ (cp_lexer_previous_token_position): No check for eof_token here.
+ (cp_lexer_get_preprocessor_token): Clear tree_check_p.
+ (cp_lexer_peek_nth_token): Check CPP_EOF not eof_token.
+ (cp_lexer_consume_token): Assert not CPP_EOF, no check for
+ eof_token.
+ (cp_lexer_purge_token): Likewise.
+ (cp_lexer_purge_tokens_after): No check for EOF token.
+ (cp_parser_nested_name_specifier, cp_parser_decltype)
+ (cp_parser_template_id): Set tree_check_p.
+
+2019-10-24 Jakub Jelinek <jakub@redhat.com>
+
+ * decl2.c (cplus_decl_attributes): Add "omp declare target block"
+ attribute in between declare target and end declare target
+ pragmas.
+
+ * call.c (convert_arg_to_ellipsis): Add missing space in string
+ literal.
+
+2019-10-24 Marek Polacek <polacek@redhat.com>
+
+ * decl.c (reshape_init_r): Add missing space.
+
+2019-10-24 Nathan Sidwell <nathan@acm.org>
+
+ * pt.c (reduce_template_parm_level): Attach the new TPI to the new
+ DECL.
+ (convert_generic_types_to_packs): Pass the copied type to
+ reduce_templatE_parm_level.
+
+2019-10-23 Nathan Sidwell <nathan@acm.org>
+
+ * cp-tree.c (CPTI_STD_IDENTIFIER): Delete.
+ (std_identifier): Delete.
+ (DECL_NAME_SPACE_STD_P): Compare against std_node.
+ * decl.c (initialize_predefined_identifiers): 'std' is not needed.
+ (cxx_init_decl_processing): Adjust creation of ::std. Use
+ {push,pop}_nested_namespace.
+ (cxx_builtin_function): Use {push,pop}_nested_namespace.
+ * except.c (init_exception_processing): Likewise.
+ * rtti.c (init_rtti_processing): Likewise.
+
+2019-10-23 Jason Merrill <jason@redhat.com>
+
+ Implement P1286R2, Contra CWG1778
+ * method.c (defaulted_late_check): Don't check explicit
+ exception-specification on defaulted function.
+ (after_nsdmi_defaulted_late_checks): Remove.
+ * parser.h (struct cp_unparsed_functions_entry): Remove classes.
+ * parser.c (unparsed_classes): Remove.
+ (push_unparsed_function_queues, cp_parser_class_specifier_1):
+ Adjust.
+
+2019-10-23 Jakub Jelinek <jakub@redhat.com>
+
+ * constexpr.c (cxx_eval_constant_expression) <case CLEANUP_STMT>:
+ Temporarily change input_location to CLEANUP_STMT location.
+
+2019-10-22 Jakub Jelinek <jakub@redhat.com>
+
+ PR tree-optimization/85887
+ * decl.c (expand_static_init): Drop ECF_LEAF from __cxa_guard_acquire
+ and __cxa_guard_release.
+
+2019-10-22 Marc Glisse <marc.glisse@inria.fr>
+
+ PR c++/85746
+ * constexpr.c (cxx_eval_builtin_function_call): Only set
+ force_folding_builtin_constant_p if manifestly_const_eval.
+
+2019-10-22 Richard Sandiford <richard.sandiford@arm.com>
+
+ * cp-tree.h (STF_USER_VISIBLE): New constant.
+ (strip_typedefs, strip_typedefs_expr): Take a flags argument.
+ * tree.c (strip_typedefs, strip_typedefs_expr): Likewise,
+ updating mutual calls accordingly. When STF_USER_VISIBLE is true,
+ only look through typedefs if user_facing_original_type_p.
+ * error.c (dump_template_bindings, type_to_string): Pass
+ STF_USER_VISIBLE to strip_typedefs.
+ (dump_type): Likewise, unless pp_c_flag_gnu_v3 is set.
+
+2019-10-21 Kamlesh Kumar <kamleshbhalui@gmail.com>
+ Jason Merrill <jason@redhat.com>
+
+ PR c++/83534 - typeinfo of noexcept function
+ * rtti.c (get_tinfo_decl_dynamic): Do not call
+ TYPE_MAIN_VARIANT for function.
+ (get_typeid): Likewise.
+
+2019-10-21 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * parser.c (cp_parser_class_head): Improve error recovery upon
+ extra qualification error.
+
+2019-10-21 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/92015
+ * constexpr.c (cxx_eval_component_reference, cxx_eval_bit_field_ref):
+ Use STRIP_ANY_LOCATION_WRAPPER on CONSTRUCTOR elts.
+
+2019-10-21 Marek Polacek <polacek@redhat.com>
+
+ PR c++/92062 - ODR-use ignored for static member of class template.
+ * pt.c (has_value_dependent_address): Strip location wrappers.
+
+2019-10-21 Marek Polacek <polacek@redhat.com>
+
+ PR c++/92106 - ICE with structured bindings and -Wreturn-local-addr.
+ * typeck.c (maybe_warn_about_returning_address_of_local): Avoid
+ recursing on null initializer and return false instead.
+
+2019-10-17 JeanHeyd Meneide <phdofthehouse@gmail.com>
+
+ Implement p1301 [[nodiscard("should have a reason")]] + p1771 DR
+ * tree.c (handle_nodiscard_attribute): Handle C++2a nodiscard
+ string message.
+ (std_attribute_table) Increase nodiscard argument handling
+ max_length from 0 to 1.
+ * parser.c (cp_parser_check_std_attribute): Add requirement
+ that nodiscard only be seen once in attribute-list.
+ (cp_parser_std_attribute): Check that empty parenthesis lists are
+ not specified for attributes that have max_length > 0 (e.g.
+ [[attr()]]).
+ * cvt.c (maybe_warn_nodiscard): Add nodiscard message to
+ output, if applicable.
+ (convert_to_void): Allow constructors to be nodiscard-able (P1771).
+
+2019-10-18 Nathan Sidwell <nathan@acm.org>
+
+ * cp-tree.h (struct lang_type): Remove was_anonymous.
+ (TYPE_WAS_UNNAMED): Implement by checking TYPE_DECL &
+ TYPE_STUB_DECL.
+ * decl.c (name_unnamed_type): Don't set TYPE_WAS_UNNAMED.
+
+2019-10-17 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (grokfndecl): Remove redundant use of in_system_header_at.
+ (compute_array_index_type_loc): Likewise.
+ (grokdeclarator): Likewise.
+ * error.c (cp_printer): Likewise.
+ * lambda.c (add_default_capture): Likewise.
+ * parser.c (cp_parser_primary_expression): Likewise.
+ (cp_parser_selection_statement): Likewise.
+ (cp_parser_toplevel_declaration): Likewise.
+ (cp_parser_enumerator_list): Likewise.
+ (cp_parser_using_declaration): Likewise.
+ (cp_parser_member_declaration): Likewise.
+ (cp_parser_exception_specification_opt): Likewise.
+ (cp_parser_std_attribute_spec): Likewise.
+ * pt.c (do_decl_instantiation): Likewise.
+ (do_type_instantiation): Likewise.
+ * typeck.c (cp_build_unary_op): Likewise.
+
+ * decl.c (check_tag_decl): Pass to in_system_header_at the same
+ location used for the permerror.
+ (grokdeclarator): Likewise.
+
+ * decl.c (check_tag_decl): Use locations[ds_typedef] in error_at.
+
+2019-10-17 Jason Merrill <jason@redhat.com>
+
+ * cp-gimplify.c (cp_gimplify_expr): Use get_initialized_tmp_var.
+ (gimplify_to_rvalue): Remove default NULL argument.
+
+2019-10-17 Nathan Sidwell <nathan@acm.org>
+
+ * decl.c (builtin_function_1): Merge into ...
+ (cxx_builtin_function): ... here. Nadger the decl before maybe
+ copying it. Set the context.
+ (cxx_builtin_function_ext_scope): Push to top level, then call
+ cxx_builtin_function.
+
+2019-10-16 Luis Machado <luis.machado@linaro.org>
+
+ * cp-gimplify.c: Fix reference to non-existing tree-gimple.c file.
+
+2019-10-16 Jakub Jelinek <jakub@redhat.com>
+
+ * decl.c (cxx_maybe_build_cleanup): When clearing location of cleanup,
+ if cleanup is a nop, clear location of its operand too.
+
+2019-10-15 Andrew Sutton <asutton@lock3software.com>
+
+ Finish moving constraint and logic functionality of out pt.c.
+ Reimplement and re-enable subsumption caching.
+
+ * config-lang.in (gtfiles): Add logic.cc.
+ * constraint.cc (atomic_constraints_identical_p): Add assertions.
+ (hash_atomic_constraint): Likewise.
+ (constraints_equivalent_p): New.
+ (inchash::add_constraint): New.
+ (iterative_hash_constraint): New.
+ (decl_constraints): Moved from pt.c.
+ (get_constraints): Likewise.
+ (set_constraints): Likewise.
+ (remove_constraints): Likewise.
+ * cp-tree.h (CONSTR_P): New.
+ (init_constraint_processing): Remove.
+ (constraints_equivalent_p, iterative_hash_constraint): Declare.
+ * decl.c (cxx_init_decl_processing): Don't initialize constraints.
+ * logic.cc (subsumption_entry): Moved from pt.c.
+ (subsumption_hasher): Likewise.
+ (subsumption_cache): Likewise.
+ (lookup_subsumption): Likewise.
+ (save_subsumption): Likewise.
+ (subsumes_constraints_nonnull): Use subsumption cache.
+ * pt.c: Move aforementioned declarations out of this file.
+ (init_constraint_processing): Remove.
+
+2019-10-15 Andrew Sutton <asutton@lock3software.com>
+
+ * parser.c (cp_parser_constructor_declarator_p): Pass an empty
+ decl-specifier-seq to make sure we parse type constraints as part
+ of a type-specifier.
+
+2019-10-15 Nathan Sidwell <nathan@acm.org>
+
+ * class.c (build_clones): Break out of clone_function_decl. Just
+ build the clones.
+ (clone_function_decl): Call build_clones, then maybe add them to
+ the method vector.
+
+ * class.c (build_clone): Refactor to clarify recursiveness.
+
+2019-10-14 Jason Merrill <jason@redhat.com>
+
+ PR c++/91930 - ICE with constrained inherited default ctor.
+ * name-lookup.c (do_class_using_decl): Set TYPE_HAS_USER_CONSTRUCTOR
+ for inherited constructor.
+
+2019-10-14 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (check_tag_decl): Use DECL_SOURCE_LOCATION.
+
+2019-10-14 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/92084
+ * semantics.c (handle_omp_array_sections_1): Temporarily disable
+ -fstrong-eval-order also for in_reduction and task_reduction clauses.
+
+ * parser.c (cp_parser_omp_all_clauses): Change bool NESTED_P argument
+ into int NESTED, if it is 2, diagnose missing commas in between
+ clauses.
+ (cp_parser_omp_context_selector): Pass 2 as last argument to
+ cp_parser_omp_all_clauses.
+
+2019-10-12 Jakub Jelinek <jakub@redhat.com>
+
+ * parser.c (cp_parser_omp_context_selector): Improve error recovery.
+ For simd properties, put them directly into TREE_VALUE.
+ (cp_finish_omp_declare_variant): Add "omp declare variant base"
+ attribute rather than "omp declare variant".
+
+2019-10-11 Marek Polacek <polacek@redhat.com>
+
+ PR c++/92049 - extra error with -fchecking=2.
+ * pt.c (build_non_dependent_expr): Call fold_non_dependent_expr
+ with tf_none.
+
+2019-10-11 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * typeck.c (cp_build_binary_op): Do not handle RROTATE_EXPR and
+ LROTATE_EXPR.
+ * constexpr.c (cxx_eval_constant_expression): Likewise.
+ (potential_constant_expression_1): Likewise.
+ * pt.c (tsubst_copy): Likewise.
+
+2019-10-11 Jason Merrill <jason@redhat.com>
+
+ * decl2.c (mark_used): Don't clobber DECL_SOURCE_LOCATION on
+ explicitly defaulted functions.
+ * method.c (synthesize_method): Likewise.
+
+2019-10-11 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/91987
+ * decl2.c (grok_array_decl): For -fstrong-eval-order, when array ref
+ operands have been swapped and at least one operand has side-effects,
+ revert the swapping before calling build_array_ref.
+ * typeck.c (cp_build_array_ref): For non-ARRAY_TYPE array ref with
+ side-effects on the index operand, if -fstrong-eval-order use
+ save_expr around the array operand.
+ (cp_build_binary_op): For shifts with side-effects in the second
+ operand, wrap first operand into SAVE_EXPR and evaluate it before
+ the shift.
+ * semantics.c (handle_omp_array_sections_1): Temporarily disable
+ flag_strong_eval_order during OMP_CLAUSE_REDUCTION array section
+ processing.
+ * cp-gimplify.c (gimplify_to_rvalue): New function.
+ (cp_gimplify_expr): Use it.
+
+2019-10-10 Marek Polacek <polacek@redhat.com>
+
+ * typeck.c (comp_ptr_ttypes_real): Change the return type to bool.
+ Use false instead of 0.
+
+2019-10-10 Jakub Jelinek <jakub@redhat.com>
+
+ * parser.h (struct cp_omp_declare_simd_data): Add variant_p member.
+ * parser.c (cp_ensure_no_omp_declare_simd): Handle both declare simd
+ and declare variant.
+ (cp_parser_oacc_all_clauses): Formatting fix.
+ (cp_parser_omp_all_clauses): Add NESTED_P argument, if true, terminate
+ processing on closing paren and don't skip to end of pragma line.
+ (cp_parser_omp_declare_simd): Add VARIANT_P argument. Handle also
+ declare variant.
+ (omp_construct_selectors, omp_device_selectors,
+ omp_implementation_selectors, omp_user_selectors): New variables.
+ (cp_parser_omp_context_selector,
+ cp_parser_omp_context_selector_specification,
+ cp_finish_omp_declare_variant): New functions.
+ (cp_parser_late_parsing_omp_declare_simd): Handle also declare variant.
+ (cp_parser_omp_declare): Handle declare variant.
+
+2019-10-09 Jason Merrill <jason@redhat.com>
+
+ * cp-tree.h (template_info_decl_check): Check ENABLE_TREE_CHECKING.
+
+2019-10-09 Marek Polacek <polacek@redhat.com>
+
+ PR c++/91364 - P0388R4: Permit conversions to arrays of unknown bound.
+ PR c++/69531 - DR 1307: Differently bounded array parameters.
+ PR c++/88128 - DR 330: Qual convs and pointers to arrays of pointers.
+ * call.c (build_array_conv): Build ck_identity at the beginning
+ of the conversion.
+ (standard_conversion): Pass bounds_none to comp_ptr_ttypes_const.
+ (maybe_warn_array_conv): New.
+ (convert_like_real): Call it. Add an error message about converting
+ from arrays of unknown bounds.
+ (conv_get_original_expr): New.
+ (nelts_initialized_by_list_init): New.
+ (conv_binds_to_array_of_unknown_bound): New.
+ (compare_ics): Implement list-initialization ranking based on
+ array sizes, as specified in DR 1307 and P0388R.
+ * cp-tree.h (comp_ptr_ttypes_const): Adjust declaration.
+ (compare_bounds_t): New enum.
+ * typeck.c (comp_array_types): New bool and compare_bounds_t
+ parameters. Use them.
+ (structural_comptypes): Adjust the call to comp_array_types.
+ (similar_type_p): Handle ARRAY_TYPE.
+ (build_const_cast_1): Pass bounds_none to comp_ptr_ttypes_const.
+ (comp_ptr_ttypes_real): Don't check cv-quals of ARRAY_TYPEs. Use
+ comp_array_types to compare array types. Look through arrays as per
+ DR 330.
+ (comp_ptr_ttypes_const): Use comp_array_types to compare array types.
+ Look through arrays as per DR 330.
+
+2019-10-09 Marek Polacek <polacek@redhat.com>
+
+ PR c++/92032 - DR 1601: Promotion of enum with fixed underlying type.
+ * call.c (standard_conversion): When converting an enumeration with
+ a fixed underlying type to the underlying type, give it the cr_promotion
+ rank.
+ (compare_ics): Implement a tiebreaker as per CWG 1601.
+
+2019-10-08 Andrew Sutton <asutton@lock3software.com>
+ Jason Merrill <jason@redhat.com>
+
+ Update the concepts implementation to conform to the C++20
+ specification, improve compile times, and generally clean up
+ the implementation.
+ * call.c (build_new_function_call): Don't evaluate concepts here.
+ (constraint_failure): Don't record the template.
+ (print_z_candidate): Don't extract the template.
+ * class.c (add_method): When overloading, hide ineligible special
+ member fns.
+ (check_methods): Set TYPE_HAS_COMPLEX_* here.
+ * constexpr.c (cxx_eval_constant_expression): Evaluate concepts.
+ (maybe_initialize_fundef_copies_table): Remove.
+ (get_fundef_copy): Use hash_map_safe_get_or_insert.
+ (clear_cv_and_fold_caches): Clear the satisfaction cache.
+ * constraint.cc (known_non_bool_p): New.
+ (parsing_constraint_expression_sentinel): Renamed from
+ expanding_constraint_sentinel.
+ (check_constraint_operands): New.
+ (check_constraint_atom): New.
+ (finish_constraint_binary_op): New.
+ (finish_constraint_or_expr): Likewise.
+ (finish_constraint_and_expr): Likewise.
+ (finish_constraint_primary_expr): Likewise.
+ (combine_constraint_expressions): New.
+ (finish_requires_expr): Add location parm.
+ (get_concept_definition): Return the initializer of concept definitions.
+ (get_template_head_requirements): New.
+ (get_trailing_function_requirements): New.
+ (deduce_constrained_parameter): Check if the identifier or template-id
+ is a concept definition.
+ (resolve_concept_definition_check): Removed.
+ (resolve_variable_concept_check): Removed.
+ (resolve_concept_check): New.
+ (resolve_constraint_check): Handle concept definitions.
+ converting arguments.
+ (function_concept_check_p): Removed.
+ (variable_concept_check_p): Removed.
+ (unpack_concept_check): New.
+ (get_concept_check_template): New.
+ (build_call_check): Moved and renamed to build_function_check.
+ (build_concept_check_arguments): make static.
+ (build_function_check): Always do overload resolution
+ in order to force conversion of template arguments (i.e., actually
+ check that the use of a concept is valid).
+ (build_standard_check): Renamed from build_real_concept_check.
+ (build_real_concept_check): Build checks for C++2a concepts by
+ (build_wildcard_concept_check): New.
+ (build_concept_check): Use build_real_concept_check. New overload.
+ (build_constraints): Save expressions, not normalized constraints.
+ (build_concept_id): New. Pass tf_warning_or_error.
+ (build_type_constraint): New.
+ (finish_type_constraints): New.
+ (associate_classtype_constraints): Also add constraints to union
+ types. Note the original declaration in errors. Don't return
+ error_mark_node in order to avoid an assertion later.
+ (push_down_pack_expansion): Remove.
+ (finish_shorthand_constraint): Make fold expressions, not naked
+ parameter packs. Always apply the constraint to each template argument.
+ (check_introduction_list): New. Fail if not enough
+ names are introduced.
+ (finish_template_introduction): Don't normalize constraints. Pass
+ tsubst flags. Check for insufficient introductions.
+ (placeholder_extract_concept_and_args): Handle the template-id case.
+ Unpack function concept checks correctly.
+ (tsubst_simple_requirement): Return errors if they occur. Don't
+ process as a template.
+ (tsubst_type_requirement): Likewise.
+ (type_deducible_p): New. Wrap the input expression in parens for the
+ purpose of deduction.
+ (expression_convertible_t): New.
+ (tsubst_compound_requirement): Use new deduction, conversion predicates.
+ (tsubst_nested_requirement): Return errors if they occur. Don't
+ process as a template. Instantiate and evaluate the nested requirement.
+ (tsubst_valid_expression_requirement): New.
+ (tsubst_simple_requirement): Use tsubst_valid_expression_requirement.
+ (tsubst_compound_requirement): Use tsubst_valid_expression_requirement.
+ (check_constaint_variables): New.
+ (tsubst_constraint_variables): Check that type substitutions are valid.
+ (tsubst_requires_expr): Likewise. Produce new requires-exprs during
+ template substitution. Copy the previous local specialization stack,
+ so references to non-local parameters can be found. Use cp_unevaluated.
+ (tsubst_constraint): New. Don't evaluate concept checks.
+ (subst_info): New.
+ (norm_info): New. Used to build a normalization tree for concept check
+ diagnostics.
+ (debug_parameter_mapping): New.
+ (debug_argument_list): New.
+ (expand_concept): Removed.
+ (normalize_logical_operation): Pass subst_info through call.
+ (normalize_pack_expansion): Remove.
+ (normalize_simple_requirement): Removed
+ (normalize_type_requirement): Removed
+ (normalize_compound_requirement): Removed
+ (normalize_nested_requirement): Removed
+ (normalize_requirement): Removed
+ (normalize_requirements): Removed
+ (normalize_requires_expression): Removed
+ (normalize_variable_concept_check): Removed.
+ (normalize_function_concept_check): Removed.
+ (normalize_concept_check): Merged all normalize_*_check here.
+ Substitute through written template arguments before normalizing the
+ definition. Only substitute the innermost template arguments.
+ (check_for_logical_overloads): Delete.
+ (map_arguments): New. Associate template parameters with arguments.
+ (build_parameter_mapping): New. Extract used parameters.
+ (normalize_expression): Rewrite.
+ (normalize_conjunction): Removed
+ (normalize_disjunction): Removed
+ (normalize_predicate_constraint): Removed
+ (normalize_parameterized_constraint): Removed
+ (normalized_map): New variable.
+ (get_normalized_constraints): New entry point for normalization.
+ Establishes a timer.
+ (get_normalized_constraints_from_info): New.
+ (get_normalized_constraints_from_decl): New. Turn on template processing
+ prior to normalization. Handle inheriting ctors. Build the
+ normalization arguments from the full set of template parameters of the
+ most general template. This guarantees that we have no concrete arguments
+ in the parameter mapping (e.g., from template members of class
+ templates). Cache normalizations.
+ (normalize_concept_definition): New. Cache normalizations.
+ (normalize_template_requirements): New.
+ (normalize_nontemplate_requirements): New.
+ (normalize_constraint_expression): New.
+ (tsubst_parameter_mapping): New.
+ (get_mapped_args): New.
+ (parameter_mapping_equivalent_p): New. Use template_args_equal.
+ (atomic_constraints_identical_p): New.
+ (hash_atomic_constraint): New.
+ (satisfying_constraint_p): New. Guard against recursive evaluation of
+ constraints during satisfaction.
+ (satisfy_conjunction): New.
+ (satisfy_disjunction): New.
+ (sat_entry): New class for hashing satisfaction results.
+ (sat_hasher): New hash traits.
+ (sat_cache): New.
+ (get_satisfaction): New. Returns cached satisfaction result.
+ (save_satisfaction): New. Caches a satisfaction result.
+ (clear_satisfaction_cache): New.
+ (satisfaction_cache): New. Helps manage satisfaction cache requests.
+ (decl_satisfied_cache): New.
+ (satisfy_atom): New.
+ (satisfy_constraint_r): New.
+ (satisfy_constraint): Use new satisfaction algorithm.
+ (evaluate_concept_check): New.
+ (evaluate_concept): Removed.
+ (evaluate_function_concept): Removed.
+ (evaluate_variable_concept): Removed.
+ (satisfy_constraint_expression): New.
+ (constraint_expression_satisfied_p): New.
+ (constraints_satisfied_p): Use strip_inheriting_ctors. Use
+ push_/pop_access_scope.
+ (more_constrained): Normalize before calling out to subsumption. Allow
+ classes as arguments.
+ (strictly_subsumes): Allow non-templates as arguments. Accept a new
+ template argument.
+ (weakly_subsumes): New.
+ (at_least_as_constrained): Removed.
+ (diagnose_other_expression): Removed.
+ (diagnose_predicate_constraint): Removed.
+ (diagnose_pack_expansion): Removed.
+ (diagnose_check_constraint): Removed.
+ (diagnose_logical_constraint): Removed.
+ (diagnose_expression_constraint): Removed.
+ (diagnose_type_constraint): Removed.
+ (diagnose_implicit_conversion_constraint): Removed.
+ (diagnose_argument_deduction_constraint): Removed.
+ (diagnose_exception_constraint): Removed.
+ (diagnose_parameterized_constraint): Removed.
+ (diagnose_argument_deduction_constraint): Removed.
+ (diagnose_argument_deduction_constraint): Removed.
+ (diagnose_argument_deduction_constraint): Removed.
+ (diagnose_trait_expr): New.
+ (diagnose_requires_expr): New.
+ (diagnose_atomic_constraint): New.
+ (diagnose_valid_expression) Stop wrongly diagnosing valid expressions.
+ Don't substitute as if in template decls. This causes substitution
+ to generate expressions that aren't suitable for use with the noexcept
+ routines.
+ (diagnose_valid_type) Likewise.
+ (diagnose_compound_requirement) Actually emit diagnostics for
+ the causes of errors.Call force_paren_expr_uneval.
+ (diagnose_declaration_constraints): Turn on template processing to
+ suppress certain analyses.
+ * cp-objcp-common.c (cp_common_init_ts): Make concepts typed.
+ (cp_get_debug_type): Use hash_map_safe_*.
+ * cp-tree.h: New function declarations for semantic actions, other
+ facilities. Remove declaration no longer used or needed. Remove
+ unused _CONSTR macros.
+ (LANG_DECL_HAS_MIN): Add CONCEPT_DECL.
+ (template_info_decl_check): Factor macro check into an inline function.
+ (DECL_TEMPLATE_INFO): Use new check facility.
+ (finish_concept_definition): New. Don't invalid concept declarations
+ with invalid initializers.
+ (find_template_parameters): New.
+ (concept_definition_p): New.
+ (concept_check_p): New.
+ (variable_concept_check_p): New.
+ (force_paren_expr_uneval): New.
+ (ovl_iterator::using_p): A USING_DECL by itself was also
+ introduced by a using-declaration.
+ (struct tree_template_info): Use tree_base instead of
+ tree_common. Add tmpl and args fields.
+ (TI_TEMPLATE, TI_ARGS): Adjust.
+ (DECLTYPE_FOR_INIT_CAPTURE): Remove.
+ (CONSTR_CHECK, CONSTR_INFO, CONSTR_EXPR, CONSTR_CONTEXT): New.
+ (ATOMIC_CONSTR_MAP, TRAIT_EXPR_LOCATION): New.
+ (struct tree_trait_expr): Add locus field.
+ (enum tsubst_flags): Add tf_norm as a hint to generate normalization
+ context when diagnosing constraint failure.
+ * cp-tree.def: Remove unused _CONSTR nodes and rename PRED_CONSTR
+ to ATOMIC_CONSTR.
+ (CONCEPT_DECL): New.
+ * cxx-pretty-print.c: Remove constraint printing code.
+ (pp_cxx_concept_definition): New.
+ (pp_cxx_template_declaration): Print concept definitions.
+ (pp_cxx_check_constraint): Update printing for concept definitions.
+ (pp_cxx_nested_name_specifier): Fix a weird
+ case where we're printing '::::' for concepts.
+ (simple_type_specifier): Print requirements for placeholder types.
+ (pp_cxx_constrained_type_spec): Print the associated requirements of
+ a placeholder type.
+ (pp_cxx_compound_requirement): Add space before the '->'.
+ (pp_cxx_parameter_mapping): Print the parameter mapping.
+ (pp_cxx_atomic_constraint): Use the function above.
+ * decl.c (redeclaration_error_message): New error for concepts.
+ (grokdeclarator): Check for and disallow decltype(auto) in parameter
+ declarations.
+ (grokfndecl): Don't normalize constraints. Add check for constraints
+ on declaration.
+ (grokvardecl): Don't normalize constraints.
+ (grok_special_member_properties): Don't set TYPE_HAS_COMPLEX_*.
+ (function_requirements_equivalent_p): New. Compare trailing
+ requires clauses. Compare combined constraints in pre-C++20 mode.
+ (decls_match): Compare trailing requires clauses. Compare template
+ heads for function templates. Remove old constraint comparison.
+ Simplify comparison of functions, function templates.
+ (duplicate_function_template_decls): New. Refactor a nasty if
+ condition into a single predicate.
+ (require_deduced_type): Don't complain if we already complained about
+ deduction failure.
+ (finish_function): Perform auto deduction to ensure that constraints
+ are checked even when functions contain no return statements. Only do
+ auto deduction if we haven't previously seen any return statements.
+ This prevents multiple diagnostics of the same error.
+ (store_decomp_type): Remove.
+ (cp_finish_decomp): Use hash_map_safe_put.
+ * error.c: Remove constraint printing code.
+ (dump_decl): Dump concept definitions. Handle wildcard declarations.
+ (dump_template_decl): Likewise.
+ (dump_type): Print associated requirements for placeholder
+ types.
+ (rebuild_concept_check): New.
+ (maybe_print_single_constraint_context): New.
+ (maybe_print_constraint_context): Recursively print nested contexts.
+ * init.c (get_nsdmi): Use hash_map_safe_*.
+ * lambda.c (maybe_add_lambda_conv_op): Bail if deduction failed.
+ (add_capture): Copy parameter packs from init.
+ (lambda_capture_field_type): Always use auto for init-capture.
+ * logic.cc: Completely rewrite.
+ (constraint_hash): New.
+ (clause/ctor): Save atoms in the hash table.
+ (replace): Save atoms during replacement.
+ (insert): Save atoms during insertion.
+ (contains): Only search the hash table for containment.
+ (clause): Keep a hash of atomic constraints.
+ (clause::clause): Explicitly copy the hash table when copying.
+ (disjunction_p, conjunction_p, atomic_p, dnf_size, cnf_size): New.
+ (diagnose_constraint_size): New.
+ (subsumes_constraints_nonnull): Compare the sizes of normalized formula
+ to determine the cheapest decomposition.
+ * name-lookup.c (diagnose_name_conflict): Diagnose name issues with
+ concepts.
+ (matching_fn_p): Check constraints.
+ (push_class_level_binding_1): Move overloaded functions case down,
+ accept FUNCTION_DECL as target_decl.
+ * parser.c (enum required_token): New required token for auto.
+ (make_location): Add overload taking lexer as last parm.
+ (cp_parser_required_error): Diagnose missing auto.
+ (cp_parser_diagnose_ungrouped_constraint_plain): New.
+ (cp_parser_diagnose_ungrouped_constraint_plain): New.
+ (cp_parser_constraint_primary_expression): New. Tentatively parse the
+ primary expression. If that fails tentatively parse a lower
+ precedence expression in order to diagnose the error.
+ (cp_parser_check_non_logical_constraint): New. Performs a trial
+ parse of the right-hand-side of non-logical operators in order to
+ generate good diagnostics.
+ (cp_parser_constraint_logical_and_expression): New.
+ (cp_parser_constraint_logical_or_expression): New.
+ (cp_parser_requires_clause_expression): New.
+ (cp_parser_requires_clause): Renamed to cp_parser_constraint_expression.
+ (cp_parser_requires_clause_opt): Parse the requires-clause differently
+ in -fconcepts and -std=c++2a modes.
+ (cp_parser_requirement_list): Rename to cp_parser_requirement_seq.
+ Rewrite so that semicolons are parsed
+ along with requirements, not the sequence.
+ (cp_parser_simple_requirement): Expect a semicolon at end.
+ (cp_parser_compound_requirement): Expect a semicolon at end. Only
+ allow trailing-return-type with -fconcepts-ts.
+ (cp_parser_nested_requirement): Expect a semicolon at end. Parse
+ constraint-expressions.
+ (cp_parser_concept_definition): New. Don't fail parsing the concept
+ definition if the initializer is ill-formed. Don't declare the concept
+ before parsing the initializer.
+ (cp_parser_constraint_expression): Declare earlier.
+ (cp_parser_type_requirement): Current scope is not valid.
+ (cp_parser_requires_expression): Commit to the tentative parse.
+ (cp_parser_decl_specifier_seq): Warn when concept appears to be used
+ as a decl-specifier.
+ (cp_parser_template_declaration_after_parameters): Parse concept
+ definitions.
+ (cp_parser_template_id): Don't try to resolve a concept template-id yet.
+ (cp_parser_template_id_expr): Resolve it as a concept check.
+ (cp_parser_decl_specifier_seq): Warn on 'concept bool'.
+ (cp_parser_type_parameter): Combine expressions not
+ constraints.
+ (cp_parser_explicit_template_declaration): Combine expressions not
+ constraints.
+ (cp_parser_maybe_concept_name): Removed.
+ (cp_parser_simple_type_specifier): Handle an error condition of
+ a bad constrained type specifier. Expect auto or decltype after
+ a concept name. Also handle the case where we have a template-id
+ as a concept check.
+ (cp_parser_template_introduction): Diagnose errors on invalid
+ introductions. Give up if it doesn't start with a concept name.
+ Pedwarn if not -fconcepts-ts.
+ (synthesize_implicit_template_parm): Don't do consistent binding.
+ Use a new flag for constrained parameters. Combine expressions,
+ not constraints. Fail if we get a placeholder in block scope.
+ Placeholders that do not constrain types are not allowed in parameter
+ declarations, so don't handle them.
+ (cp_parser_placeholder_type_specifier): New. Implement parsing of
+ placeholder type specifiers following a concept name or partial
+ concept check. Disallow decltype(auto) parameters.
+ (cp_parser_nested_name_specifier_opt): If the token is already
+ CPP_NESTED_NAME_SPECIFIER, leave it alone.
+ (cp_parser_id_expression, cp_parser_unqualified_id): Call
+ cp_parser_template_id_expr.
+ (cp_parser_placeholder_type_specifier): Add tentative parm. Don't
+ expect a WILDCARD_DECL.
+ (cp_parser_trait_expr): Pass trait_loc down.
+ (cp_parser_postfix_expression): Do set location of dependent member
+ call.
+ * pt.c (finish_concept_definition): New.
+ (push_template_decl_real): Handle concept definitions.
+ (start_concept_definition): Let push_template_decl_real handle the
+ creation of the template.
+ (get_constraints): Return null if the table hasn't been initialized.
+ (tsubst_copy_and_build): Build template-id expressions for concept
+ checks.
+ [TRAIT_EXPR]: Pass trait_loc down.
+ (lookup_template_class_1): Add the template name to the constraint
+ failure diagnostic.
+ (lookup_and_finish_template_variable): Build concept checks
+ with the correct arguments.
+ (tsubst_function_decl): Don't substitute through constraints.
+ Always associate constraints with functions.
+ (template_parm_level_and_index): Make non-static.
+ (for_each_template_parm_r): Handle requires expressions.
+ (keep_template_parm): New.
+ (find_template_parameters): New.
+ (more_specialized_fn): Change how winners and losers are chosen.
+ (make_constrained_auto): Don't normalize constraints.
+ (template_parameters_equivalent_p): New. Compare template
+ parameters. Add a comparison for implicitly vs. explicitly declared
+ parameters.
+ (template_parameter_lists_equivalent_p): New. Compare template
+ parameter lists.
+ (template_requirements_equivalent_p): New.
+ (template_heads_equivalent_p): New. Compare template heads.
+ (template_parameter_constraints_equivalent_p): New.
+ (is_compatible_template_arg): Use weakly_subsumes.
+ (maybe_new_partial_specialization): Use new constraint comparison
+ for finding specializations.
+ (process_partial_specialization): Pass main template as argument.
+ (more_specialized_partial_spec): Don't immediately return when
+ detecting a winner.
+ (make_constrained_auto): Handle concept definitions.
+ (do_auto_deduction): Update auto deduction for new concept model.
+ Extract the function concept correctly; rename constr to check to
+ reflect the kind of node.
+ (tsubst): Adjust wildcard argument during substitution.
+ [DECLTYPE_TYPE]: Remove init-capture handling.
+ (tsubst_copy_and_build): Build concept checks, not template ids.
+ Defer checks of function concepts. Handle concepts before variable
+ templates. Handle calls to function concepts explicitly.
+ (coerce_template_parms): Use concept_definition_p. Handle a deduction
+ error where a potentially empty pack can be supplied after the last
+ parameter of a concept.
+ (finish_template_variable): Don't process concepts here.
+ (instantiation_dependent_r): Use concept_check_p.
+ (tsubst_template_args): Make non-static.
+ (make_constrained_placeholder_type): New. Refactored from
+ make_constrained_auto.
+ (make_constrained_auto) Use make_constrained_placeholder_type.
+ (make_constrained_decltype_auto) New.
+ (tsubst_function_parms): New.
+ (value_dependent_expression_p) [TEMPLATE_ID_EXPR]: Use
+ concept_definition_p.
+ (push_access_scope, pop_access_scope): No longer static.
+ (tsubst_template_parm): Substitute TEMPLATE_PARM_CONSTRAINTS.
+ (tsubst_friend_function): Use tsubst_constraint. Use generic_targs_for.
+ (get_underlying_template) Use generic_targs_for.
+ (uses_parameter_packs): Return tree.
+ (gen_elem_of_pack_expansion_instantiation): Don't push
+ local_specialization_stack.
+ (prepend_one_capture): New.
+ (tsubst_lambda_expr): Use prepend_one_capture. Don't touch
+ local_specializations.
+ (template_parms_level_to_args): No longer static.
+ (add_outermost_template_args): Likewise.
+ (find_template_parameter_info): New. Provide context for finding
+ template parameters.
+ (keep_template_parm): Don't keep parameters declared at depth levels
+ greater than those of the template parameters of the source declaration.
+ Don't propagate cv-qualified types. Return 0, so we find all template
+ parameters, not the just first.
+ (any_template_parm_r): New. Handle cases that are mishandled by
+ for_each_template_parm_r.
+ (generic_targs_for): Factor out of coerce_template_args_for_ttp.
+ (tsubst_argument_pack): Factor out of tsubst_template_args.
+ (constraint_sat_entry): Removed.
+ (constraint_sat_hasher): Removed.
+ (concept_spec_entry): Removed.
+ (concept_spec_hasher): Removed.
+ (constraint_memos): Removed.
+ (concept_memos): Removed.
+ (lookup_constraint_satisfaction): Removed.
+ (memoize_constraint_satisfaction): Removed.
+ (lookup_concept_satisfaction): Removed.
+ (memoize_concept_satisfaction): Removed.
+ (concept_expansions): Removed.
+ (get_concept_expansion): Removed.
+ (save_concept_expansion): Removed.
+ (init_constraint_processing): Remove initialization of non-existing
+ resources.
+ (find_template_requirement): New. Search for the sub-requirement
+ within the associated constraints.
+ (convert_generic_types_to_packs): Also transform the associated
+ constraint and update the current template requirements.
+ (store_defaulted_ttp, lookup_defaulted_ttp): Remove.
+ (add_defaults_to_ttp): Use hash_map_safe_*.
+ * semantics.c (finish_call_expr): Diagnose calls to concepts.
+ Handle concept checks explicitly.
+ (finish_id_expression): Evaluate variable concepts as part of
+ id-expression processing. Don't treat variable concepts as variables,
+ and don't process function concepts as plain id-expressions.
+ (force_paren_expr): Add even_uneval parm.
+ (finish_trait_expr): Add location parm.
+ * tree.c (special_memfn_p): New.
+ (cp_expr_location): Handle TRAIT_EXPR.
+ * typeck.c (check_return_expr): Actually use the diagnostic kind
+ when performing return-type deduction.
+ * typeck2.c (build_functional_cast): Don't rely on the location of
+ 'auto'.
+
+2019-10-09 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (grok_ctor_properties): Use DECL_SOURCE_LOCATION.
+ * typeck.c (cp_build_binary_op): Use the op_location_t argument
+ in many error messages.
+
+2019-10-08 Martin Sebor <msebor@redhat.com>
+
+ PR c++/92001
+ * call.c (maybe_warn_class_memaccess): Handle arrays.
+
+2019-10-07 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * call.c (resolve_args): Use cp_expr_loc_or_input_loc in one place.
+ * decl.c (grokdeclarator): Use id_loc in one place.
+ * decl2.c (build_anon_union_vars): Use DECL_SOURCE_LOCATION.
+ * parser.c (cp_parser_delete_expression): Fix the location of the
+ returned expression.
+ (cp_parser_throw_expression): Likewise.
+ * pt.c (determine_specialization): Use DECL_SOURCE_LOCATION.
+
+2019-10-05 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/91369 - Implement P0784R7: constexpr new
+ * cp-tree.h (enum cp_tree_index): Add CPTI_HEAP_UNINIT_IDENTIFIER,
+ CPTI_HEAP_IDENTIFIER and CPTI_HEAP_DELETED_IDENTIFIER.
+ (heap_uninit_identifier, heap_identifier, heap_deleted_identifier):
+ Define.
+ (type_has_constexpr_destructor, build_new_constexpr_heap_type,
+ cxx_constant_dtor): Declare.
+ * class.c (type_maybe_constexpr_default_constructor): Make static.
+ (type_maybe_constexpr_destructor, type_has_constexpr_destructor): New
+ functions.
+ (finalize_literal_type_property): For c++2a, don't clear
+ CLASSTYPE_LITERAL_P for types without trivial destructors unless they
+ have non-constexpr destructors.
+ (explain_non_literal_class): For c++2a, complain about non-constexpr
+ destructors rather than about non-trivial destructors.
+ * constexpr.c: Include stor-layout.h.
+ (struct constexpr_global_ctx): New type.
+ (struct constexpr_ctx): Add global field, remove values and
+ constexpr_ops_count.
+ (cxx_replaceable_global_alloc_fn): New inline function.
+ (cxx_eval_call_expression): For c++2a allow calls to replaceable
+ global allocation functions, for new return address of a heap uninit
+ var, for delete record its deletion. Change ctx->values->{get,put} to
+ ctx->global->values.{get,put}.
+ (non_const_var_error): Add auto_diagnostic_group sentinel. Emit
+ special diagnostics for heap variables.
+ (cxx_eval_store_expression): Change ctx->values->{get,put} to
+ ctx->global->values.{get,put}.
+ (cxx_eval_loop_expr): Initialize jump_target if NULL. Change
+ new_ctx.values->remove to ctx->global->values.remove.
+ (cxx_eval_constant_expression): Change *ctx->constexpr_ops_count
+ to ctx->global->constexpr_ops_count. Change ctx->values->{get,put} to
+ ctx->global->values.{get,put}.
+ <case NOP_EXPR>: Formatting fix. On cast of replaceable global
+ allocation function to some pointer type, adjust the type of
+ the heap variable and change name from heap_uninit_identifier
+ to heap_identifier.
+ (find_heap_var_refs): New function.
+ (cxx_eval_outermost_constant_expr): Add constexpr_dtor argument,
+ handle evaluation of constexpr dtors and add tracking of heap
+ variables. Use tf_no_cleanup for get_target_expr_with_sfinae.
+ (cxx_constant_value): Adjust cxx_eval_outermost_constant_expr caller.
+ (cxx_constant_dtor): New function.
+ (maybe_constant_value, fold_non_dependent_expr_template,
+ maybe_constant_init_1): Adjust cxx_eval_outermost_constant_expr
+ callers.
+ (potential_constant_expression_1): Ignore clobbers. Allow
+ COND_EXPR_IS_VEC_DELETE for c++2a.
+ * decl.c (initialize_predefined_identifiers): Add heap identifiers.
+ (decl_maybe_constant_destruction): New function.
+ (cp_finish_decl): Don't clear TREE_READONLY for constexpr variables
+ with non-trivial, but constexpr destructors.
+ (register_dtor_fn): For constexpr variables with constexpr non-trivial
+ destructors call cxx_maybe_build_cleanup instead of adding destructor
+ calls at runtime.
+ (expand_static_init): For constexpr variables with constexpr
+ non-trivial destructors call cxx_maybe_build_cleanup.
+ (grokdeclarator): Allow constexpr destructors for c++2a. Formatting
+ fix.
+ (cxx_maybe_build_cleanup): For constexpr variables with constexpr
+ non-trivial destructors call cxx_constant_dtor instead of adding
+ destructor calls at runtime.
+ * init.c: Include stor-layout.h.
+ (build_new_constexpr_heap_type, maybe_wrap_new_for_constexpr): New
+ functions.
+ (build_new_1): For c++2a and new[], add cast around the alloc call
+ to help constexpr evaluation figure out the type of the heap storage.
+ (build_vec_delete_1): Set DECL_INITIAL of tbase and emit a DECL_EXPR
+ for it instead of initializing an uninitialized variable.
+ * method.c: Include intl.h.
+ (SFK_CTOR_P, SFK_DTOR_P, SFK_ASSIGN_P, SFK_COPY_P, SFK_MOVE_P): Move
+ definitions earlier.
+ (process_subob_fn): Add sfk argument, adjust non-constexpr call
+ diagnostics based on it.
+ (walk_field_subobs): Formatting fixes. Adjust process_subob_fn caller.
+ (synthesized_method_base_walk): Likewise.
+ (synthesized_method_walk): Set *constexpr_p to true for dtors in c++2a.
+ Fix up DR number in comment.
+ (implicitly_declare_fn): Formatting fix.
+ * typeck2.c (store_init_value): Don't call cp_fully_fold_init on
+ initializers of automatic non-constexpr variables in constexpr
+ functions.
+
+2019-10-04 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/71504
+ * constexpr.c (cxx_fold_indirect_ref_1): New function.
+ (cxx_fold_indirect_ref): Use it.
+
+ PR c++/91974
+ * cp-gimplify.c (cp_gimplify_expr) <case CALL_EXPR>: For
+ -fstrong-eval-order ensure CALL_EXPR_FN side-effects are evaluated
+ before any arguments. Additionally, ensure CALL_EXPR_FN that isn't
+ invariant nor OBJ_TYPE_REF nor SSA_NAME is forced into a temporary.
+
+2019-10-03 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * init.c (build_new): Use cp_expr_loc_or_input_loc in two places.
+ * name-lookup.c (do_pushdecl): Use DECL_SOURCE_LOCATION.
+ (push_class_level_binding_1): Likewise.
+ (set_decl_namespace): Likewise.
+
+2019-10-03 Jakub Jelinek <jakub@redhat.com>
+
+ * constexpr.c (cxx_eval_constant_expression) <case CLEANUP_STMT>: If
+ not skipping upon entry to body, run cleanup with the same *jump_target
+ as it started to run the cleanup even if the body returns, breaks or
+ continues.
+ (potential_constant_expression_1): Allow CLEANUP_STMT.
+
+ * constexpr.c (cxx_eval_store_expression): Formatting fix. Handle
+ const_object_being_modified with array type.
+
+2019-10-02 Jason Merrill <jason@redhat.com>
+
+ * typeck2.c (store_init_value): Only clear_cv_and_fold_caches if the
+ value is constant.
+
+2019-09-30 Jason Merrill <jason@redhat.com>
+
+ Use hash_map_safe_* functions.
+ * constexpr.c (maybe_initialize_fundef_copies_table): Remove.
+ (get_fundef_copy): Use hash_map_safe_get_or_insert.
+ * cp-objcp-common.c (cp_get_debug_type): Use hash_map_safe_*.
+ * decl.c (store_decomp_type): Remove.
+ (cp_finish_decomp): Use hash_map_safe_put.
+ * init.c (get_nsdmi): Use hash_map_safe_*.
+ * pt.c (store_defaulted_ttp, lookup_defaulted_ttp): Remove.
+ (add_defaults_to_ttp): Use hash_map_safe_*.
+
+2019-10-02 Richard Biener <rguenther@suse.de>
+
+ PR c++/91606
+ * decl.c (build_ptrmemfunc_type): Mark pointer-to-member
+ fat pointer structure members as DECL_NONADDRESSABLE_P.
+
+2019-09-28 Marek Polacek <polacek@redhat.com>
+
+ PR c++/91889 - follow-up fix for DR 2352.
+ * call.c (involves_qualification_conversion_p): New function.
+ (direct_reference_binding): Build a ck_qual if the conversion
+ would involve a qualification conversion.
+ (convert_like_real): Strip the conversion created by the ck_qual
+ in direct_reference_binding.
+
+ PR c++/91921 - stray warning with -Woverloaded-virtual.
+ * class.c (warn_hidden): Only emit the second part of
+ -Woverloaded-virtual if the first part was issued. Use inform instead
+ warning_at.
+
+ PR c++/91923 - failure-to-SFINAE with class type NTTP in C++17.
+ * pt.c (invalid_nontype_parm_type_p): Only emit errors when
+ tf_error.
+
+2019-09-27 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/88203
+ * parser.c (cp_parser_omp_var_list_no_open): Parse predefined
+ variables.
+ * semantics.c (finish_omp_clauses): Allow predefined variables in
+ shared and firstprivate clauses, even when they are predetermined
+ shared.
+ * cp-gimplify.c (cxx_omp_predetermined_sharing_1): Return
+ OMP_CLAUSE_DEFAULT_SHARED for predefined variables.
+
+2019-09-27 Jason Merrill <jason@redhat.com>
+
+ * constexpr.c (cxx_fold_indirect_ref): Use similar_type_p.
+ (cxx_eval_indirect_ref): Likewise. Improve error location.
+
+ * cp-tree.h (class iloc_sentinel): New.
+ * decl.c (grokdeclarator, finish_enum_value_list): Use it.
+ * mangle.c (mangle_decl_string): Use it.
+ * pt.c (perform_typedefs_access_check): Use it.
+
+2019-09-27 Richard Sandiford <richard.sandiford@arm.com>
+
+ * cp-tree.h (build_cxx_call): Take the original function decl
+ as an optional final parameter.
+ (cp_build_function_call_vec): Likewise.
+ * call.c (build_cxx_call): Likewise. Pass all built-in calls to
+ check_builtin_function_arguments.
+ * typeck.c (build_function_call_vec): Take the original function
+ decl as an optional final parameter and pass it to
+ cp_build_function_call_vec.
+ (cp_build_function_call_vec): Take the original function
+ decl as an optional final parameter and pass it to build_cxx_call.
+
+2019-09-25 Marek Polacek <polacek@redhat.com>
+
+ PR c++/91877 - ICE with converting member of packed struct.
+ * call.c (convert_like_real): Use similar_type_p in an assert.
+
+2019-09-25 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * name-lookup.c (check_extern_c_conflict): Use DECL_SOURCE_LOCATION.
+ (check_local_shadow): Use it in three additional places.
+
+2019-09-24 Jason Merrill <jason@redhat.com>
+
+ * parser.c (cp_parser_postfix_expression): Do set location of
+ dependent member call.
+
+2019-09-24 Marek Polacek <polacek@redhat.com>
+
+ PR c++/91868 - improve -Wshadow location.
+ * name-lookup.c (check_local_shadow): Use DECL_SOURCE_LOCATION
+ instead of input_location.
+
+ PR c++/91845 - ICE with invalid pointer-to-member.
+ * expr.c (mark_use): Use error_operand_p.
+ * typeck2.c (build_m_component_ref): Check error_operand_p after
+ calling mark_[lr]value_use.
+
+2019-09-23 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * pt.c (check_explicit_specialization): Use cp_expr_loc_or_input_loc.
+ (process_partial_specialization): Likewise.
+ (convert_nontype_argument_function): Likewise.
+ (invalid_tparm_referent_p): Likewise.
+ (convert_template_argument): Likewise.
+ (check_valid_ptrmem_cst_expr): Tidy.
+
+2019-09-23 Jason Merrill <jason@redhat.com>
+
+ PR c++/91809 - bit-field and ellipsis.
+ * call.c (convert_arg_to_ellipsis): Don't call decay_conversion for
+ arithmetic arguments.
+
+2019-09-23 Marek Polacek <polacek@redhat.com>
+
+ PR c++/91844 - Implement CWG 2352, Similar types and reference binding.
+ * call.c (reference_related_p): Use similar_type_p instead of
+ same_type_p.
+ (reference_compatible_p): Update implementation to match CWG 2352.
+ * cp-tree.h (similar_type_p): Declare.
+ * typeck.c (similar_type_p): New.
+
+2019-09-22 Marek Polacek <polacek@redhat.com>
+
+ PR c++/91819 - ICE with operator++ and enum.
+ * call.c (build_new_op_1): Set arg2_type.
+
+2019-09-17 Jason Merrill <jason@redhat.com>
+
+ * parser.c (cp_parser_statement): Handle [[likely]] on
+ compound-statement.
+
+2019-09-19 Jason Merrill <jason@redhat.com>
+
+ Revert:
+ * call.c (build_new_op_1): Don't apply any standard conversions to
+ the operands of a built-in operator. Don't suppress conversions in
+ cp_build_unary_op.
+ * typeck.c (cp_build_unary_op): Do integral promotions for enums.
+
+2019-09-16 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (grokdeclarator): Use declspecs->locations and
+ declarator->id_loc in a few error messages.
+ * pt.c (finish_member_template_decl): Use DECL_SOURCE_LOCATION.
+ (push_template_decl_real): Likewise.
+
+2019-09-15 Jason Merrill <jason@redhat.com>
+
+ PR c++/30277 - int-width bit-field promotion.
+ PR c++/33819 - long bit-field promotion.
+ * typeck.c (cp_perform_integral_promotions): Handle large bit-fields
+ properly. Handle 32-bit non-int bit-fields properly.
+ (is_bitfield_expr_with_lowered_type): Don't look through NOP_EXPR.
+
+ PR c++/82165 - enum bitfields and operator overloading.
+ * call.c (build_new_op_1): Use unlowered_expr_type.
+
+ * call.c (build_new_op_1): Don't apply any standard conversions to
+ the operands of a built-in operator. Don't suppress conversions in
+ cp_build_unary_op.
+ * typeck.c (cp_build_unary_op): Do integral promotions for enums.
+
+2019-09-15 Marek Polacek <polacek@redhat.com>
+
+ PR c++/91740 - ICE with constexpr call and ?: in ARRAY_REF.
+ * pt.c (build_non_dependent_expr): Call build_non_dependent_expr for
+ the first operand.
+
+2019-09-15 Nathan Sidwell <nathan@acm.org>
+
+ * cp-tree.h (DECL_CLONED_FUNCTION_P): Reimplement using
+ IDENTIFIER_CDTOR_P, correct documentation.
+ (DECL_CLONED_FUNCTION): Directly access field.
+ (decl_cloned_function_p): Delete.
+ * class.c (decl_cloned_function_p): Delete.
+ * pt.c (instantiate_template_1): Check DECL_CHAIN is a decl.
+
+2019-09-11 Nathan Sidwell <nathan@acm.org>
+
+ * c-objcp-common.c (cp-objcp-common.c): Alphababetize and
+ correctly mark all C++ nodes.
+ * decl.c (cp_tree_node_structure): Alphabetize.
+
+2019-09-10 Marek Polacek <polacek@redhat.com>
+
+ PR c++/91673 - ICE with noexcept in alias-declaration.
+ * parser.c (CP_PARSER_FLAGS_DELAY_NOEXCEPT): New parser flag.
+ (cp_parser_lambda_declarator_opt): Pass CP_PARSER_FLAGS_NONE to
+ cp_parser_exception_specification_opt.
+ (cp_parser_direct_declarator): Adjust a call to
+ cp_parser_exception_specification_opt.
+ (cp_parser_member_declaration): Pass CP_PARSER_FLAGS_DELAY_NOEXCEPT
+ to cp_parser_declarator if not processing a friend or typedef
+ declaration.
+ (cp_parser_late_noexcept_specifier): Adjust a call to
+ cp_parser_noexcept_specification_opt.
+ (cp_parser_noexcept_specification_opt): New parameter for parser flags,
+ drop the FRIEND_P parameter. Use the new parameter.
+ (cp_parser_exception_specification_opt): Likewise.
+ (cp_parser_transaction): Adjust a call to
+ cp_parser_noexcept_specification_opt.
+ (cp_parser_transaction_expression): Likewise.
+
+2019-09-10 Marek Polacek <polacek@redhat.com>
+
+ PR c++/91705 - constexpr evaluation rejects ++/-- on floats.
+ * constexpr.c (cxx_eval_increment_expression): Call fold_simple on
+ the offset.
+
+2019-09-10 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (has_designator_problem): Use cp_expr_loc_or_input_loc
+ in error_at.
+ (build_enumerator): Likewise.
+ (cp_finish_decl): Use DECL_SOURCE_LOCATION.
+ (grokdeclarator): Use id_loc in two error_at; change errror
+ message about constinit together constexpr to use two ranges.
+
+2019-09-09 Marek Polacek <polacek@redhat.com>
+
+ PR c++/84374 - diagnose invalid uses of decltype(auto).
+ * decl.c (grokdeclarator): Diagnose wrong usage of decltype(auto) in
+ a function declaration.
+
+2019-09-06 Nathan Sidwell <nathan@acm.org>
+
+ PR c++/91125
+ * cp-tree.h (IDENTIFIER_REPO_CHOSEN, DECL_REPO_AVAILABLE_P): Delete.
+ (struct lang_decl_base): Remove repo_available_p.
+ * decl.c (duplicate_decls): Don't copy DECL_REPO_AVAILABLE_P.
+
+ (Reserve TREE_LANG_FLAG_3 for modules.
+ * cp-tree.h (DECL_CONSTRUCTION_VTABLE_P): Delete.
+ (DECL_NON_TRIVIALLY_INITIALIZED_P): Move to TREE_LANG_FLAG_6.
+ * class.c (build_ctor_vtbl_group): Don't set
+ DECL_CONSTRUCTION_VTABLE_P.
+ * decl2.c (determine_visibility_from_class): Don't check
+ DECL_CONSTRUCTION_VTABLE_P anymore.
+
+2019-09-06 Martin Liska <mliska@suse.cz>
+
+ PR c++/91125
+ * Make-lang.in: Remove repo.o.
+ * config-lang.in: Likewise.
+ * cp-tree.h (init_repo): Remove declarations
+ of repo-related functions.
+ (repo_emit_p): Likewise.
+ (repo_export_class_p): Likewise.
+ (finish_repo): Likewise.
+ * decl2.c (import_export_class): Always
+ set -1 value/
+ (mark_needed): Remove -frepo from comment.
+ (import_export_decl): Similarly here.
+ (c_parse_final_cleanups): Remove call of finish_repo.
+ * lex.c (cxx_init): Remove call to init_repo.
+ * optimize.c (can_alias_cdtor): Remove dead condition.
+ * pt.c (push_template_decl_real): Update comment.
+ (instantiate_decl): Remove dead code used for -frepo.
+ * repo.c: Remove.
+
+2019-09-05 Marek Polacek <polacek@redhat.com>
+
+ PR c++/91644 - ICE with constinit in function template.
+ * decl.c (start_decl): Call retrofit_lang_decl for constinit variables.
+ * pt.c (tsubst_expr): Pass LOOKUP_CONSTINIT down to cp_finish_decl for
+ constinit variables.
+
+2019-09-05 Nathan Sidwell <nathan@acm.org>
+
+ * cp-tree.h (DECL_VTABLE_OR_VTT_P): Forward to DECL_VIRTUAL_P.
+
+2019-09-04 Marek Polacek <polacek@redhat.com>
+
+ * call.c (build_over_call): Remove -fdeduce-init-list implementation.
+ * pt.c (unify): Likewise.
+
+2019-09-01 Marek Polacek <polacek@redhat.com>
+
+ PR c++/91129 - wrong error with binary op in template argument.
+ * typeck.c (warn_for_null_address): Use fold_for_warn instead of
+ fold_non_dependent_expr.
+ (cp_build_binary_op): Likewise.
+
+2019-08-30 Jason Merrill <jason@redhat.com>
+
+ Add source location to TRAIT_EXPR.
+ * cp-tree.h (TRAIT_EXPR_LOCATION): New.
+ (struct tree_trait_expr): Add locus field.
+ * parser.c (cp_parser_trait_expr): Pass trait_loc down.
+ * pt.c (tsubst_copy_and_build) [TRAIT_EXPR]: Likewise.
+ * semantics.c (finish_trait_expr): Add location parm.
+ * tree.c (cp_expr_location): Handle TRAIT_EXPR.
+
+2019-08-29 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (check_var_type): Add location_t parameter and use it.
+ (grokdeclarator): Adjust call.
+ * pt.c (tsubst_decl): Likewise.
+ * cp-tree.h: Adjust declaration.
+
+2019-08-28 Marek Polacek <polacek@redhat.com>
+
+ Implement P1152R4: Deprecating some uses of volatile.
+ PR c++/91361
+ * cp-gimplify.c (cp_fold): Set TREE_THIS_VOLATILE.
+ * decl.c (grokdeclarator): Warn about a volatile-qualified structured
+ binding and return type.
+ (grokparms): Warn about a volatile-qualified function parameter.
+ * expr.c (mark_use) <case MODIFY_EXPR>: Emit a -Wvolatile warning.
+ * typeck.c (cp_build_unary_op): Emit a -Wvolatile warning for pre and
+ post ++/-- on a volatile operand.
+ (genericize_compound_lvalue): Use a better location. Don't lose
+ TREE_THIS_VOLATILE.
+ (cp_build_modify_expr): Emit a -Wvolatile warning for a compound
+ assignment whose LHS is volatile-qualified. Build the assignment with
+ a more precise location.
+
+2019-08-28 Marek Polacek <polacek@redhat.com>
+
+ PR c++/91360 - Implement C++20 P1143R2: constinit.
+ * cp-tree.h (TINFO_VAR_DECLARED_CONSTINIT): Define.
+ (LOOKUP_CONSTINIT): Define.
+ (enum cp_decl_spec): Add ds_constinit.
+ * decl.c (check_tag_decl): Give an error for constinit in type
+ declarations.
+ (check_initializer): Also check LOOKUP_CONSTINIT.
+ (cp_finish_decl): Add checking for a constinit declaration. Set
+ TINFO_VAR_DECLARED_CONSTINIT.
+ (grokdeclarator): Add checking for a declaration with the constinit
+ specifier.
+ * lex.c (init_reswords): Handle D_CXX20.
+ * parser.c (cp_lexer_get_preprocessor_token): Pass a better location
+ to warning_at. Warn about C++20 keywords.
+ (cp_keyword_starts_decl_specifier_p): Handle RID_CONSTINIT.
+ (cp_parser_diagnose_invalid_type_name): Add an inform about constinit.
+ (cp_parser_decomposition_declaration): Maybe pass LOOKUP_CONSTINIT to
+ cp_finish_decl.
+ (cp_parser_decl_specifier_seq): Handle RID_CONSTINIT.
+ (cp_parser_init_declarator): Maybe pass LOOKUP_CONSTINIT to
+ cp_finish_decl.
+ (set_and_check_decl_spec_loc): Add "constinit".
+ * pt.c (tsubst_decl): Set TINFO_VAR_DECLARED_CONSTINIT.
+ (instantiate_decl): Maybe pass LOOKUP_CONSTINIT to cp_finish_decl.
+ * typeck2.c (store_init_value): If a constinit variable wasn't
+ initialized using a constant initializer, give an error.
+
+2019-08-28 Nathan Sidwell <nathan@acm.org>
+
+ PR c++/90613
+ * name-lookup.c (cp_emit_debug_info): Check for builtins during
+ overload iteration.
+
+2019-08-27 Marek Polacek <polacek@redhat.com>
+
+ PR c++/81676 - bogus -Wunused warnings in constexpr if.
+ * semantics.c (maybe_mark_exp_read_r): New function.
+ (finish_if_stmt): Call it on THEN_CLAUSE and ELSE_CLAUSE.
+
+ PR c++/91428 - warn about std::is_constant_evaluated in if constexpr.
+ * cp-tree.h (decl_in_std_namespace_p): Declare.
+ * semantics.c (is_std_constant_evaluated_p): New.
+ (finish_if_stmt_cond): Warn about "std::is_constant_evaluated ()" in
+ an if-constexpr.
+ * typeck.c (decl_in_std_namespace_p): No longer static.
+
+2019-08-26 Jason Merrill <jason@redhat.com>
+
+ * decl.c (duplicate_decls): Always merge DECL_DECLARED_CONSTEXPR_P.
+
+2019-08-26 Marek Polacek <polacek@redhat.com>
+
+ PR c++/91545 - ICE in constexpr store evaluation.
+ * constexpr.c (cxx_eval_store_expression): Check FIELD_DECL instead
+ of DECL_P.
+
+2019-08-24 Nathan Sidwell <nathan@acm.org>
+
+ * class.c (check_for_overrides): Conversion operators need
+ checking too.
+
+2019-08-24 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * semantics.c (finish_switch_cond): Improve error message location.
+
+2019-08-23 Jason Merrill <jason@redhat.com>
+
+ * decl2.c (decl_dependent_p): New.
+ (mark_used): Check it instead of just processing_template_decl.
+
+2019-08-23 Jason Merrill <jason@redhat.com>
+
+ * parser.c (cp_parser_nested_name_specifier_opt): Avoid redundant
+ error.
+
+2019-08-23 Marek Polacek <polacek@redhat.com>
+
+ PR c++/91521 - wrong error with operator->.
+ * decl.c (grokdeclarator): Return error_mark_node for an invalid
+ trailing return type.
+
+ PR c++/79817 - attribute deprecated on namespace.
+ * cp-tree.h (cp_warn_deprecated_use_scopes): Declare.
+ * decl.c (grokdeclarator): Call cp_warn_deprecated_use_scopes.
+ (type_is_deprecated): Likewise.
+ * decl2.c (cp_warn_deprecated_use_scopes): New function.
+ * name-lookup.c (handle_namespace_attrs): Handle attribute deprecated.
+ * parser.c (cp_parser_namespace_alias_definition): Call
+ cp_warn_deprecated_use_scopes.
+ (cp_parser_using_declaration): Likewise.
+ (cp_parser_using_directive): Likewise.
+ * semantics.c (finish_id_expression_1): Likewise.
+
+2019-08-23 Nathan Sidwell <nathan@acm.org>
+
+ * class.c (check_for_override): Checking IDENTIFIER_VIRTUAL_P is
+ sufficient, reorder DECL_OVERRIDE_P check.
+
+2019-08-23 Iain Sandoe <iain@sandoe.co.uk>
+
+ PR pch/61250
+ * parser.c (cp_parser_initial_pragma): Call c_common_no_more_pch ()
+ after determining that the first token is not
+ PRAGMA_GCC_PCH_PREPROCESS.
+
+2019-08-22 Marek Polacek <polacek@redhat.com>
+
+ PR c++/91304 - prefix attributes ignored in condition.
+ * parser.c (cp_parser_condition): Handle prefix attributes.
+
+2019-08-21 Richard Sandiford <richard.sandiford@arm.com>
+
+ PR c++/91505
+ * decl.c (duplicate_decls): Call copy_attributes_to_builtin inside
+ the BUILT_IN_NORMAL block rather than afterward.
+
+2019-08-19 Marek Polacek <polacek@redhat.com>
+
+ PR c++/91264 - detect modifying const objects in constexpr.
+ * constexpr.c (modifying_const_object_error): New function.
+ (cxx_eval_call_expression): Set TREE_READONLY on a CONSTRUCTOR of
+ a const-qualified object after it's been fully constructed.
+ (modifying_const_object_p): New function.
+ (cxx_eval_store_expression): Detect modifying a const object
+ during constant expression evaluation.
+ (cxx_eval_increment_expression): Use a better location when building
+ up the store.
+ (cxx_eval_constant_expression) <case DECL_EXPR>: Mark a constant
+ object's constructor TREE_READONLY.
+
+2019-08-15 Jason Merrill <jason@redhat.com>
+
+ PR c++/90393 - ICE with thow in ?:
+
+ PR c++/64372, DR 1560 - Gratuitous lvalue-to-rvalue conversion in ?:
+ * tree.c (lvalue_kind): Handle throw in one arm.
+ * typeck.c (rationalize_conditional_expr): Likewise.
+ (cp_build_modify_expr): Likewise.
+
+2019-08-14 Jason Merrill <jason@redhat.com>
+
+ Implement P0848R3, Conditionally Trivial Special Member Functions.
+ * tree.c (special_memfn_p): New.
+ * class.c (add_method): When overloading, hide ineligible special
+ member fns.
+ (check_methods): Set TYPE_HAS_COMPLEX_* here.
+ * decl.c (grok_special_member_properties): Not here.
+ * name-lookup.c (push_class_level_binding_1): Move overloaded
+ functions case down, accept FUNCTION_DECL as target_decl.
+
+2019-08-14 Jonathan Wakely <jwakely@redhat.com>
+
+ PR c++/91436
+ * name-lookup.c (get_std_name_hint): Fix min_dialect field for
+ complex_literals and make_unique entries.
+
+2019-08-14 Jakub Jelinek <jakub@redhat.com>
+ Marek Polacek <polacek@redhat.com>
+
+ PR c++/91391 - bogus -Wcomma-subscript warning.
+ * parser.c (cp_parser_postfix_open_square_expression): Don't warn about
+ a deprecated comma here. Pass warn_comma_subscript down to
+ cp_parser_expression.
+ (cp_parser_expression): New bool parameter. Warn about uses of a comma
+ operator within a subscripting expression.
+ (cp_parser_skip_to_closing_square_bracket): Revert to pre-r274121 state.
+ (cp_parser_skip_to_closing_square_bracket_1): Remove.
+
+2019-08-14 Jonathan Wakely <jwakely@redhat.com>
+
+ * name-lookup.c (get_std_name_hint): Add more entries.
+
+2019-08-14 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl2.c (grok_array_decl): Use the location of the open square
+ bracket in error message about invalid types.
+
+2019-08-14 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (grokdeclarator): Check here for typedef a function
+ definition or a member function definition.
+ (start_function): Adjust.
+ (grokmethod): Likewise.
+
+2019-08-13 Richard Sandiford <richard.sandiford@arm.com>
+
+ PR middle-end/91421
+ * decl.c (duplicate_decls): Use copy_decl_built_in_function.
+ * pt.c (declare_integer_pack): Use set_decl_built_in_function.
+
+2019-08-13 Marek Polacek <polacek@redhat.com>
+
+ PR c++/90473 - wrong code with nullptr in default argument.
+ * call.c (null_ptr_cst_p): Update quote from the standard.
+ * decl.c (check_default_argument): Don't return nullptr when the arg
+ has side-effects.
+
+2019-08-13 Marek Polacek <polacek@redhat.com>
+
+ * cp-tree.h (DECL_MUTABLE_P): Use FIELD_DECL_CHECK.
+
+2019-08-10 Jakub Jelinek <jakub@redhat.com>
+
+ * parser.c (cp_parser_omp_clause_name): Parse device_type.
+ (cp_parser_omp_clause_device_type): New function.
+ (cp_parser_omp_all_clauses): Handle PRAGMA_OMP_CLAUSE_DEVICE_TYPE.
+ (OMP_DECLARE_TARGET_CLAUSE_MASK): Add PRAGMA_OMP_CLAUSE_DEVICE_TYPE.
+ (cp_parser_omp_declare_target): Handle device_type clauses. Remove
+ diagnostics for declare target with clauses nested in clause-less
+ declare target declaration-definition-seq.
+ * semantics.c (finish_omp_clauses): Handle OMP_CLAUSE_DEVICE_TYPE.
+
+2019-08-09 Jakub Jelinek <jakub@redhat.com>
+
+ * parser.c (check_no_duplicate_clause): Simplify using
+ omp_find_clause.
+ (cp_parser_omp_clause_if): Fix up printing of target {enter,exit} data
+ directive name modifiers.
+
+ PR c/91401
+ * parser.c (cp_parser_omp_clause_dist_schedule): Comment out the
+ check_no_duplicate_clause call, instead emit a warning for duplicate
+ dist_schedule clauses.
+
+2019-08-08 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (grokdeclarator): Use id_loc and EXPR_LOCATION in
+ a few error messages.
+
+2019-08-08 Marek Polacek <polacek@redhat.com>
+
+ PR c++/87519 - bogus warning with -Wsign-conversion.
+ * typeck.c (cp_build_binary_op): Use same_type_p instead of comparing
+ the types directly.
+
+ * constexpr.c (inline_asm_in_constexpr_error): New.
+ (cxx_eval_constant_expression) <case ASM_EXPR>: Call it.
+ (potential_constant_expression_1) <case ASM_EXPR>: Likewise.
+
+2019-08-08 Jakub Jelinek <jakub@redhat.com>
+
+ * semantics.c (finish_omp_clauses): For C_ORT_OMP
+ OMP_CLAUSE_USE_DEVICE_* clauses use oacc_reduction_head bitmap
+ instead of generic_head to track duplicates.
+
+2019-08-07 Marek Polacek <polacek@redhat.com>
+
+ PR c++/81429 - wrong parsing of constructor with C++11 attribute.
+ * parser.c (cp_parser_constructor_declarator_p): Handle the scenario
+ when a parameter declaration begins with [[attribute]].
+
+2019-08-07 Marek Polacek <polacek@redhat.com>
+
+ PR c++/91346 - Implement P1668R1, allow unevaluated asm in constexpr.
+ * constexpr.c (cxx_eval_constant_expression): Handle ASM_EXPR.
+ (potential_constant_expression_1) <case ASM_EXPR>: Allow.
+ * cp-tree.h (finish_asm_stmt): Adjust.
+ * parser.c (cp_parser_asm_definition): Grab the locaion of "asm" and
+ use it. Change an error to a pedwarn. Allow asm in C++2a, warn
+ otherwise.
+ * pt.c (tsubst_expr): Pass a location down to finish_asm_stmt.
+ * semantics.c (finish_asm_stmt): New location_t parameter. Use it.
+
+2019-08-07 Jakub Jelinek <jakub@redhat.com>
+
+ * parser.c (cp_parser_omp_clause_name): Parse use_device_addr clause.
+ (cp_parser_omp_all_clauses): Handle PRAGMA_OMP_CLAUSE_USE_DEVICE_ADDR.
+ (OMP_TARGET_DATA_CLAUSE_MASK): Add PRAGMA_OMP_CLAUSE_USE_DEVICE_ADDR.
+ (cp_parser_omp_target_data): Handle PRAGMA_OMP_CLAUSE_USE_DEVICE_ADDR
+ like PRAGMA_OMP_CLAUSE_USE_DEVICE_PTR, adjust diagnostics about no
+ map or use_device_* clauses.
+ * semantics.c (finish_omp_clauses): For OMP_CLAUSE_USE_DEVICE_PTR
+ in OpenMP, require pointer or reference to pointer type rather than
+ pointer or array or reference to pointer or array type. Handle
+ OMP_CLAUSE_USE_DEVICE_ADDR.
+ * pt.c (tsubst_omp_clauses): Handle OMP_CLAUSE_USE_DEVICE_ADDR.
+
+2019-08-06 Jason Merrill <jason@redhat.com>
+
+ PR c++/91378 - ICE with noexcept and auto return type.
+ * pt.c (maybe_instantiate_noexcept): push_to_top_level.
+
+2019-08-06 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (check_array_designated_initializer): Use
+ cp_expr_loc_or_input_loc in one place.
+
+2019-08-06 Jakub Jelinek <jakub@redhat.com>
+
+ * parser.c (cp_parser_omp_for_loop): For OMP_LOOP, ignore parallel
+ clauses and predetermine iterator as lastprivate.
+ * semantics.c (handle_omp_for_class_iterator): Use
+ OMP_CLAUSE_LASTPRIVATE_LOOP_IV instead of
+ OMP_CLAUSE_LASTPRIVATE_TASKLOOP_IV, set it for lastprivate also
+ on OMP_LOOP construct. If a clause is missing for class iterator
+ on OMP_LOOP, add firstprivate clause, and if there is private
+ clause, turn it into firstprivate too.
+ (finish_omp_for): Formatting fix. For OMP_LOOP, adjust
+ OMP_CLAUSE_LASTPRIVATE_LOOP_IV clause CP_CLAUSE_INFO, so that it
+ uses copy ctor instead of default ctor.
+ * cp-gimplify.c (cp_gimplify_expr): Handle OMP_LOOP like
+ OMP_DISTRIBUTE etc.
+ (cp_fold_r): Likewise.
+ (cp_genericize_r): Likewise.
+ (cxx_omp_finish_clause): Also finish lastprivate clause with
+ OMP_CLAUSE_LASTPRIVATE_LOOP_IV flag.
+ * pt.c (tsubst_omp_clauses): Handle OMP_CLAUSE_BIND.
+ (tsubst_omp_for_iterator): For OMP_LOOP, ignore parallel
+ clauses and predetermine iterator as lastprivate.
+ * constexpr.c (potential_constant_expression_1): Handle OMP_LOOP
+ like OMP_DISTRIBUTE etc.
+
+2019-08-05 Marek Polacek <polacek@redhat.com>
+
+ DR 2413 - typename in conversion-function-ids.
+ * parser.c (cp_parser_conversion_type_id): Call
+ cp_parser_type_specifier_seq with CP_PARSER_FLAGS_TYPENAME_OPTIONAL
+ instead of CP_PARSER_FLAGS_NONE.
+
+2019-08-05 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * cp-tree.h (cp_expr_loc_or_input_loc): New.
+ (cxx_incomplete_type_diagnostic): Use it.
+ * call.c (build_converted_constant_expr_internal, convert_like_real,
+ convert_arg_to_ellipsis, convert_for_arg_passing, build_over_call,
+ build_cxx_call, perform_implicit_conversion_flags,
+ initialize_reference): Likewise.
+ * constexpr.c (cxx_eval_internal_function, cxx_eval_call_expression,
+ eval_and_check_array_index, cxx_eval_store_expression,
+ cxx_eval_statement_list, cxx_eval_loop_expr,
+ cxx_eval_constant_expression, potential_constant_expression_1):
+ Likewise.
+ * constraint.cc (check_for_logical_overloads,
+ satisfy_predicate_constraint): Likewise.
+ * cp-gimplify.c (cp_gimplify_expr): Likewise.
+ * cvt.c (cp_convert_to_pointer, convert_to_reference,
+ cp_convert_and_check, ocp_convert, maybe_warn_nodiscard): Likewise.
+ * decl.c (pop_switch): Likewise.
+ * decl2.c (delete_sanity): Likewise.
+ * error.c (location_of): Likewise.
+ * init.c (maybe_warn_list_ctor, build_aggr_init,
+ warn_placement_new_too_small, build_new_1, build_vec_init): Likewise.
+ * lex.c (unqualified_name_lookup_error): Likewise.
+ * parser.c (cp_parser_initializer_list, cp_parser_omp_for_cond):
+ Likewise.
+ * pt.c (check_for_bare_parameter_packs, check_valid_ptrmem_cst_expr,
+ unify_arg_conversion, convert_nontype_argument,
+ tsubst_copy_and_build, resolve_typename_type): Likewise.
+ * semantics.c (maybe_convert_cond, finish_call_expr,
+ cp_build_vec_convert): Likewise.
+ * typeck.c (decay_conversion, rationalize_conditional_expr,
+ cp_build_unary_op, build_x_compound_expr_from_list,
+ maybe_warn_about_returning_address_of_local,
+ maybe_warn_pessimizing_move): Likewise.
+ * typeck2.c (check_narrowing, digest_init_r,
+ process_init_constructor_array): Likewise.
+
+2019-08-05 Tom Honermann <tom@honermann.net>
+
+ * parser.c (cp_parser_template_declaration_after_parameters): Enable
+ class template argument deduction for non-type template parameters
+ in literal operator templates.
+
+2019-08-05 Marek Polacek <polacek@redhat.com>
+
+ PR c++/91338 - Implement P1161R3: Deprecate a[b,c].
+ * parser.c (cp_parser_postfix_open_square_expression): Warn about uses
+ of a comma operator within a subscripting expression.
+ (cp_parser_skip_to_closing_square_bracket_1): New function, made out
+ of...
+ (cp_parser_skip_to_closing_square_bracket): ...this.
+
+2019-08-05 Jason Merrill <jason@redhat.com>
+
+ * semantics.c (force_paren_expr): Preserve location.
+
+2019-08-02 Marek Polacek <polacek@redhat.com>
+
+ PR c++/91230 - wrong error with __PRETTY_FUNCTION__ and generic lambda.
+ * pt.c (value_dependent_expression_p): Consider __PRETTY_FUNCTION__
+ inside a template function value-dependent.
+
+2019-08-02 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * tree.c (handle_nodiscard_attribute): Do not warn about nodiscard
+ applied to a constructor.
+
+2019-08-02 Martin Liska <mliska@suse.cz>
+
+ * decl.c (grok_op_properties):
+ Mark DECL_SET_IS_OPERATOR_DELETE for user-provided delete operators.
+
+2019-08-01 Martin Sebor <msebor@redhat.com>
+
+ PR c++/90947
+ * decl.c (reshape_init_array_1): Avoid truncating initializer
+ lists containing string literals.
+
+2019-08-01 Marek Polacek <polacek@redhat.com>
+
+ PR c++/90805 - detect narrowing in case values.
+ * decl.c (case_conversion): Detect narrowing in case values.
+
+2019-07-31 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl2.c (delete_sanity): Improve diagnostic locations, use
+ cp_expr_loc_or_loc in four places.
+
+2019-07-31 Jason Merrill <jason@redhat.com>
+
+ PR c++/90538 - multiple expansions of capture packs
+ * cp-tree.h (DECLTYPE_FOR_INIT_CAPTURE): Remove.
+ * lambda.c (add_capture): Copy parameter packs from init.
+ (lambda_capture_field_type): Always use auto for init-capture.
+ * pt.c (uses_parameter_packs): Return tree.
+ (tsubst) [DECLTYPE_TYPE]: Remove init-capture handling.
+ (gen_elem_of_pack_expansion_instantiation): Don't push
+ local_specialization_stack.
+ (prepend_one_capture): New.
+ (tsubst_lambda_expr): Use it. Don't touch local_specializations.
+ (do_auto_deduction): Avoid redundant error.
+
+ Fix copy_node of TEMPLATE_INFO.
+ * cp-tree.h (struct tree_template_info): Use tree_base instead of
+ tree_common. Add tmpl and args fields.
+ (TI_TEMPLATE, TI_ARGS): Adjust.
+
+2019-07-30 Martin Liska <mliska@suse.cz>
+
+ PR tree-optimization/91270
+ * tree-ssa-dce.c (propagate_necessity): Mark 2nd argument
+ of delete operator as needed.
+
+2019-07-25 Martin Liska <mliska@suse.cz>
+ Dominik Infuhr <dominik.infuehr@theobroma-systems.com>
+
+ PR c++/23383
+ * decl.c (cxx_init_decl_processing): Mark delete operators
+ with DECL_SET_IS_OPERATOR_DELETE.
+
+2019-07-25 Martin Liska <mliska@suse.cz>
+
+ * decl.c (duplicate_decls): Use new macros
+ (e.g. DECL_SET_LAMBDA_FUNCTION and DECL_LAMBDA_FUNCTION_P).
+ (cxx_init_decl_processing): Likewise.
+ (grok_op_properties): Likewise.
+ * parser.c (cp_parser_lambda_declarator_opt): Likewise.
+
+2019-07-24 Martin Sebor <msebor@redhat.com>
+
+ PR driver/80545
+ * decl.c (finish_function): Use lang_mask.
+
+2019-07-20 Jason Merrill <jason@redhat.com>
+
+ * cp-tree.h (ovl_iterator::using_p): A USING_DECL by itself was also
+ introduced by a using-declaration.
+
+2019-07-20 Jason Merrill <jason@redhat.com>
+
+ Reduce memory consumption for push/pop_access_scope.
+ * name-lookup.c (leave_scope): Do add class levels other than
+ previous_class_level to free_binding_level.
+ (invalidate_class_lookup_cache): Move from class.c, add to
+ free_binding_level.
+ * pt.c (saved_access_scope): Change from list to vec.
+
+2019-07-20 Jakub Jelinek <jakub@redhat.com>
+
+ * cp-tree.h (OMP_FOR_GIMPLIFYING_P): Use OMP_LOOPING_CHECK
+ instead of OMP_LOOP_CHECK.
+ * parser.c (cp_parser_omp_clause_name): Handle bind clause.
+ (cp_parser_omp_clause_bind): New function.
+ (cp_parser_omp_all_clauses): Handle PRAGMA_OMP_CLAUSE_BIND.
+ (OMP_LOOP_CLAUSE_MASK): Define.
+ (cp_parser_omp_loop): New function.
+ (cp_parser_omp_parallel, cp_parser_omp_teams): Handle parsing of
+ loop combined with parallel or teams.
+ (cp_parser_omp_construct): Handle PRAGMA_OMP_LOOP.
+ (cp_parser_pragma): Likewise.
+ * pt.c (tsubst_expr): Handle OMP_LOOP.
+ * semantics.c (finish_omp_clauses): Handle OMP_CLAUSE_BIND.
+
+2019-07-19 Jason Merrill <jason@redhat.com>
+
+ PR c++/90101 - dependent class non-type parameter.
+ * pt.c (invalid_nontype_parm_type_p): Check for dependent class type.
+
+2019-07-18 Jason Merrill <jason@redhat.com>
+
+ PR c++/90098 - partial specialization and class non-type parms.
+ PR c++/90099
+ PR c++/90101
+ * call.c (build_converted_constant_expr_internal): Don't copy.
+ * pt.c (process_partial_specialization): Allow VIEW_CONVERT_EXPR
+ around class non-type parameter.
+ (unify) [TEMPLATE_PARM_INDEX]: Ignore cv-quals.
+
+2019-07-16 Jason Merrill <jason@redhat.com>
+
+ * parser.c (make_location): Add overload taking cp_lexer* as last
+ parameter.
+
+ * parser.c (cp_parser_simple_type_specifier): Separate tentative
+ parses for optional type-spec and CTAD.
+
+ * parser.c (cp_parser_nested_name_specifier_opt): If the token is
+ already CPP_NESTED_NAME_SPECIFIER, leave it alone.
+
+2019-07-12 Jakub Jelinek <jakub@redhat.com>
+
+ * parser.c (cp_parser_omp_clause_name): Handle order clause.
+ (cp_parser_omp_clause_order): New function.
+ (cp_parser_omp_all_clauses): Handle PRAGMA_OMP_CLAUSE_ORDER.
+ (OMP_SIMD_CLAUSE_MASK, OMP_FOR_CLAUSE_MASK): Add
+ PRAGMA_OMP_CLAUSE_ORDER.
+ * semantics.c (finish_omp_clauses): Handle OMP_CLAUSE_ORDER.
+ * pt.c (tsubst_omp_clauses): Likewise.
+
+2019-07-10 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (get_type_quals,
+ smallest_type_location (const cp_decl_specifier_seq*)): New.
+ (check_tag_decl): Use smallest_type_location in error_at about
+ multiple types in one declaration.
+ (grokdeclarator): Use locations[ds_complex] in error_at about
+ complex invalid; use locations[ds_storage_class] in error_at
+ about static cdtor; use id_loc in error_at about flexible
+ array member in union; use get_type_quals.
+
+2019-07-09 Martin Sebor <msebor@redhat.com>
+
+ PR c++/61339
+ * cp-tree.h: Change class-key of PODs to struct and others to class.
+ * search.c: Same.
+ * semantics.c (finalize_nrv_r): Same.
+
+2019-07-09 Martin Sebor <msebor@redhat.com>
+
+ PR c++/61339
+ * constexpr.c (cxx_eval_call_expression): Change class-key from class
+ to struct and vice versa to match convention and avoid -Wclass-is-pod
+ and -Wstruct-no-pod.
+ * constraint.cc (get_concept_definition): Same.
+ * cp-tree.h: Same.
+ * cxx-pretty-print.h: Same.
+ * error.c: Same.
+ * logic.cc (term_list::replace): Same.
+ * name-lookup.c (find_local_binding): Same.
+ * pt.c (tsubst_binary_right_fold): Same.
+ * search.c (field_accessor_p): Same.
+ * semantics.c (expand_or_defer_fn): Same.
+
+2019-07-08 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/91110
+ * decl2.c (cp_omp_mappable_type_1): Don't emit any note for
+ error_mark_node type.
+
+2019-07-05 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/67184
+ PR c++/69445
+ * call.c (build_new_method_call_1): Remove set but not used variable
+ binfo.
+
+2019-07-05 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/67184 (again)
+ PR c++/69445
+ * call.c (build_over_call): Devirtualize user-defined operators
+ coming from a base too.
+ (build_new_method_call_1): Do not devirtualize here.
+
+2019-07-04 Marek Polacek <polacek@redhat.com>
+
+ DR 1813
+ PR c++/83374 - __is_standard_layout wrong for a class with repeated
+ bases.
+ * class.c (check_bases): Set CLASSTYPE_NON_STD_LAYOUT for a class if
+ CLASSTYPE_REPEATED_BASE_P is true.
+
+2019-07-04 Andrew Stubbs <ams@codesourcery.com>
+
+ * cp-tree.h (cp_omp_emit_unmappable_type_notes): New prototype.
+ * decl.c (cp_finish_decl): Call cp_omp_emit_unmappable_type_notes.
+ * decl2.c (cp_omp_mappable_type): Move contents to ...
+ (cp_omp_mappable_type_1): ... here and add note output.
+ (cp_omp_emit_unmappable_type_notes): New function.
+ * semantics.c (finish_omp_clauses): Call
+ cp_omp_emit_unmappable_type_notes in four places.
+
+2019-07-03 Martin Liska <mliska@suse.cz>
+
+ * call.c (build_new_op_1): Remove dead assignemts.
+ * typeck.c (cp_build_binary_op): Likewise.
+
+2019-06-27 Jason Merrill <jason@redhat.com>
+
+ PR c++/55442 - memory-hog with highly recursive constexpr.
+ * constexpr.c (push_cx_call_context): Return depth.
+ (cxx_eval_call_expression): Don't cache past constexpr_cache_depth.
+
+2019-06-27 Jan Hubicka <jh@suse.cz>
+
+ * class.c (layout_class_type): Set TYPE_CXX_ODR_P for as-base
+ type copy.
+
+2019-06-27 Martin Liska <mliska@suse.cz>
+
+ * class.c (adjust_clone_args): Remove obviously
+ dead assignments.
+ (dump_class_hierarchy_r): Likewise.
+ * decl.c (check_initializer): Likewise.
+ * parser.c (cp_parser_lambda_expression): Likewise.
+ * pt.c (unify_bound_ttp_args): Likewise.
+ (convert_template_argument): Likewise.
+ * rtti.c (build_headof): Likewise.
+ * typeck.c (convert_for_initialization): Likewise.
+
+2019-06-25 Jason Merrill <jason@redhat.com>
+
+ PR c++/70462 - unnecessary base ctor variant with final.
+ * optimize.c (populate_clone_array): Skip base variant if
+ CLASSTYPE_FINAL.
+ (maybe_clone_body): We don't need an alias if we are only defining
+ one clone.
+
+ * class.c (resolves_to_fixed_type_p): Check CLASSTYPE_FINAL.
+
+2019-06-25 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/90969
+ * constexpr.c (cxx_eval_array_reference): Don't look through VCE from
+ vector type if lval.
+
+2019-06-25 Jozef Lawrynowicz <jozef.l@mittosystems.com>
+
+ * lex.c (init_reswords): Create keyword for "__intN__" type.
+ * cp-tree.h (cp_decl_specifier_seq): New bitfield "int_n_alt".
+ * decl.c (grokdeclarator): Don't pedwarn about "__intN" ISO
+ C incompatibility if alternate "__intN__" form is used.
+ * parser.c (cp_parser_simple_type_specifier): Set
+ decl_specs->int_n_alt if "__intN__" form is used.
+
+2019-06-24 Jan Hubicka <jh@suse.cz>
+
+ * lex.c (cxx_make_type): Set TYPE_CXX_ODR_P.
+
+2019-06-24 Jason Merrill <jason@redhat.com>
+
+ * class.c (layout_class_type): Don't use a separate
+ CLASSTYPE_AS_BASE if it's the same size.
+
+2019-06-23 Marek Polacek <polacek@redhat.com>
+
+ * call.c (convert_default_arg): Use DEFERRED_PARSE instead of
+ DEFAULT_ARG.
+ * cp-objcp-common.c (cp_tree_size): Likewise. Use tree_deferred_parse
+ instead of tree_default_arg.
+ * cp-tree.def: Rename DEFAULT_ARG to DEFERRED_PARSE.
+ * cp-tree.h: Rename DEFARG_TOKENS to DEFPARSE_TOKENS. Rename
+ DEFARG_INSTANTIATIONS to DEFPARSE_INSTANTIATIONS. Rename
+ tree_default_arg to tree_deferred_parse.
+ (UNPARSED_NOEXCEPT_SPEC_P): Use DEFERRED_PARSE instead of DEFAULT_ARG.
+ (cp_tree_node_structure_enum): Rename TS_CP_DEFAULT_ARG to
+ TS_CP_DEFERRED_PARSE.
+ (lang_tree_node): Rename tree_default_arg to tree_deferred_parse.
+ Rename default_arg to deferred_parse. Use TS_CP_DEFERRED_PARSE instead
+ of TS_CP_DEFAULT_ARG.
+ (defarg_location): Remove declaration.
+ (defparse_location): Add declaration.
+ * decl.c (grokfndecl): Use DEFERRED_PARSE instead of DEFAULT_ARG.
+ Call defparse_location instead of defarg_location.
+ (check_default_argument): Use DEFERRED_PARSE instead of DEFAULT_ARG.
+ (cp_tree_node_structure): Likewise. Use TS_CP_DEFERRED_PARSE instead
+ of TS_CP_DEFAULT_ARG.
+ * decl2.c (grokfield): Use DEFERRED_PARSE instead of DEFAULT_ARG.
+ * error.c (dump_expr): Likewise.
+ (location_of): Likewise.
+ * init.c (get_nsdmi): Likewise.
+ * parser.c (cp_parser_save_noexcept): Likewise. Use DEFPARSE_TOKENS
+ instead of DEFARG_TOKENS.
+ (cp_parser_late_noexcept_specifier): Likewise.
+ (cp_parser_late_parse_one_default_arg): Use DEFPARSE_TOKENS instead
+ of DEFARG_TOKENS.
+ (cp_parser_late_parsing_default_args): Use DEFERRED_PARSE instead of
+ DEFAULT_ARG. Use DEFPARSE_INSTANTIATIONS instead of
+ DEFARG_INSTANTIATIONS.
+ (cp_parser_cache_defarg): Use DEFERRED_PARSE instead of DEFAULT_ARG.
+ Use DEFPARSE_TOKENS instead of DEFARG_TOKENS. Use
+ DEFPARSE_INSTANTIATIONS instead of DEFARG_INSTANTIATIONS.
+ (defparse_location): Renamed from defarg_location.
+ * pt.c (tsubst_default_argument): Use DEFERRED_PARSE instead of
+ DEFAULT_ARG.
+ (tsubst_arg_types): Likewise.
+ (dependent_type_p_r): Likewise.
+ * tree.c (cp_tree_equal): Likewise.
+ (cp_walk_subtrees): Likewise.
+ * typeck.c (convert_arguments): Likewise.
+
+2019-06-22 Marek Polacek <polacek@redhat.com>
+
+ PR c++/86476 - noexcept-specifier is a complete-class context.
+ PR c++/52869
+ * cp-tree.def (DEFAULT_ARG): Update commentary.
+ * cp-tree.h (UNPARSED_NOEXCEPT_SPEC_P): New macro.
+ (tree_default_arg): Use tree_base instead of tree_common.
+ (do_push_parm_decls, maybe_check_overriding_exception_spec): Declare.
+ * decl.c (do_push_parm_decls): New function, broken out of...
+ (store_parm_decls): ...here. Call it.
+ * except.c (nothrow_spec_p): Accept DEFAULT_ARG in the assert.
+ * parser.c (cp_parser_noexcept_specification_opt,
+ cp_parser_late_noexcept_specifier, noexcept_override_late_checks):
+ Forward-declare.
+ (unparsed_noexcepts): New macro.
+ (push_unparsed_function_queues): Update initializer.
+ (cp_parser_direct_declarator): Pass FRIEND_P to
+ cp_parser_exception_specification_opt.
+ (inject_parm_decls): New.
+ (pop_injected_parms): New.
+ (cp_parser_class_specifier_1): Implement delayed parsing of
+ noexcept-specifiers.
+ (cp_parser_save_noexcept): New.
+ (cp_parser_late_noexcept_specifier): New.
+ (noexcept_override_late_checks): New.
+ (cp_parser_noexcept_specification_opt): Add FRIEND_P parameter. Call
+ cp_parser_save_noexcept instead of the normal processing if needed.
+ (cp_parser_exception_specification_opt): Add FRIEND_P parameter and
+ pass it to cp_parser_noexcept_specification_opt.
+ (cp_parser_save_member_function_body): Fix comment.
+ (cp_parser_save_default_args): Maybe save the noexcept-specifier to
+ post process.
+ (cp_parser_transaction): Update call to
+ cp_parser_noexcept_specification_opt.
+ (cp_parser_transaction_expression): Likewise.
+ * parser.h (cp_unparsed_functions_entry): Add new field to carry
+ a noexcept-specifier.
+ * pt.c (dependent_type_p_r): Handle unparsed noexcept expression.
+ * search.c (maybe_check_overriding_exception_spec): New function, broken
+ out of...
+ (check_final_overrider): ...here. Call
+ maybe_check_overriding_exception_spec.
+ * tree.c (canonical_eh_spec): Handle UNPARSED_NOEXCEPT_SPEC_P.
+ (cp_tree_equal): Handle DEFAULT_ARG.
+
+ PR c++/90881 - bogus -Wunused-value in unevaluated context.
+ * cvt.c (convert_to_void): Don't emit unused warnings in
+ an unevaluated context.
+
+2019-06-22 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (grokdeclarator): Use id_loc, typespec_loc, and
+ locations[ds_storage_class] in a few additional places.
+
+2019-06-21 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/90909
+ Revert:
+ 2019-05-21 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/67184
+ PR c++/69445
+ * call.c (build_over_call): Devirtualize when the final overrider
+ comes from the base.
+
+2019-06-21 Marek Polacek <polacek@redhat.com>
+
+ PR c++/61490 - qualified-id in friend function definition.
+ * decl.c (grokdeclarator): Diagnose qualified-id in friend function
+ definition. Improve location for diagnostics of friend functions.
+
+ PR c++/60223 - ICE with T{} in non-deduced context.
+ * pt.c (unify): Allow COMPOUND_LITERAL_P in a non-deduced context.
+
+ PR c++/64235 - missing syntax error with invalid alignas.
+ * parser.c (cp_parser_std_attribute_spec): Commit to tentative parse
+ if there's a missing close paren.
+
+ PR c++/90490 - fix decltype issues in noexcept-specifier.
+ * except.c (build_noexcept_spec): Call
+ instantiate_non_dependent_expr_sfinae before
+ build_converted_constant_expr instead of calling
+ instantiate_non_dependent_expr after it. Add
+ processing_template_decl_sentinel.
+
+2019-06-21 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/90950
+ * semantics.c (finish_omp_clauses): Don't reject references to
+ incomplete types if processing_template_decl.
+
+2019-06-19 Marek Polacek <polacek@redhat.com>
+
+ PR c++/60364 - noreturn after first decl not diagnosed.
+ * decl.c (duplicate_decls): Give an error when a function is
+ declared [[noreturn]] after its first declaration.
+ * parser.c (cp_parser_std_attribute): Don't treat C++11 noreturn
+ attribute as equivalent to GNU's.
+ * tree.c (std_attribute_table): Add noreturn.
+
+2019-06-19 Jakub Jelinek <jakub@redhat.com>
+
+ * cp-gimplify.c (cp_genericize_r): Handle OMP_CLAUSE_{IN,EX}CLUSIVE
+ like OMP_CLAUSE_SHARED.
+
+2019-06-18 Jason Merrill <jason@redhat.com>
+
+ * constexpr.c (cxx_eval_store_expression): Delay target evaluation.
+
+2019-06-18 Jason Merrill <jason@redhat.com>
+
+ * constexpr.c (eval_and_check_array_index): Split out from...
+ (cxx_eval_array_reference): ...here.
+ (cxx_eval_store_expression): Use it here, too.
+ (diag_array_subscript): Take location. Strip location wrapper.
+
+2019-06-18 Jason Merrill <jason@redhat.com>
+
+ * constexpr.c (cxx_eval_constant_expression): Handle conversion from
+ and then to the same type.
+
+2019-06-18 Jason Merrill <jason@redhat.com>
+
+ * constexpr.c (unshare_constructor): Add MEM_STAT_DECL.
+
+2019-06-17 Jakub Jelinek <jakub@redhat.com>
+
+ * semantics.c (finish_omp_clauses): For OMP_CLAUSE_REDUCTION_INSCAN
+ set need_copy_assignment.
+
+2019-06-17 Marek Polacek <polacek@redhat.com>
+
+ PR c++/83820 - excessive attribute arguments not detected.
+ * parser.c (cp_parser_std_attribute): Detect excessive arguments.
+
+2019-06-17 Nathan Sidwell <nathan@acm.org>
+
+ PR c++/90754
+ * name-lookup.c (lookup_type_scope_1): Calll qualify_lookup before
+ checking context.
+
+2019-06-14 Marek Polacek <polacek@redhat.com>
+
+ PR c++/90884 - stray note with -Wctor-dtor-privacy.
+ * class.c (maybe_warn_about_overly_private_class): Guard the call to
+ inform.
+
+2019-06-12 Jason Merrill <jason@redhat.com>
+
+ PR c++/85552 - wrong instantiation of dtor for DMI.
+ * typeck2.c (digest_nsdmi_init): Set tf_no_cleanup for direct-init.
+
+2019-06-13 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (grokdeclarator): Use id_loc in five additional places
+ in the last part of the function.
+
+2019-06-13 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (grokdeclarator): Move further up the declaration of
+ id_loc, use it immediately, update its value after the loop
+ over declarator, use it again in the final part of function;
+ improve locations of error messages about multiple data types
+ and conflicting specifiers.
+
+2019-06-13 Richard Biener <rguenther@suse.de>
+
+ PR c++/90801
+ * typeck2.c (split_nonconstant_init_1): Properly count
+ num_split_elts, optimize single constructor elt removal.
+
+2019-06-12 Marek Polacek <polacek@redhat.com>
+
+ PR c++/66999 - 'this' captured by reference.
+ * parser.c (cp_parser_lambda_introducer): Reject `&this'. Use
+ cp_lexer_nth_token_is instead of cp_lexer_peek_nth_token.
+
+ PR c++/90825 - endless recursion when evaluating sizeof.
+ PR c++/90832 - endless recursion when evaluating sizeof.
+ * constexpr.c (cxx_eval_constant_expression): Don't recurse on the
+ result of fold_sizeof_expr if is returns a SIZEOF_EXPR.
+ * typeck.c (cxx_sizeof_expr): Only return a SIZEOF_EXPR if the operand
+ is instantiation-dependent.
+
+ PR c++/90736 - bogus error with alignof.
+ * constexpr.c (adjust_temp_type): Use cv_unqualified type.
+
+2019-06-11 Matthew Beliveau <mbelivea@redhat.com>
+
+ PR c++/90449 - add -Winaccessible-base option.
+ * class.c (warn_about_ambiguous_bases): Changed name to:
+ maybe_warn_about_inaccessible_bases.
+ (maybe_warn_about_inaccessible_bases): Implemented new
+ Winaccessible-base warning option for both direct and virtual
+ base warnings.
+ (layout_class_type): Call to warn_about_ambiguous_bases changed to fit
+ new name.
+
+2019-06-11 Richard Biener <rguenther@suse.de>
+
+ PR c++/90801
+ * typeck2.c (split_nonconstant_init_1): Avoid ordered remove
+ from CONSTRUCTOR by marking to remove elements and doing all
+ of them in a O(n) scan.
+
+2019-06-11 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/90810
+ * init.c (constant_value_1): Handle VECTOR_CST DECL_INITIAL for
+ !DECL_INITIALIZED_BY_CONSTANT_EXPRESSION_P decls like CONSTRUCTOR.
+
+2019-06-11 Martin Liska <mliska@suse.cz>
+
+ PR c++/87847
+ * pt.c (init_template_processing): Disable hash table
+ sanitization for decl_specializations and type_specializations.
+
+2019-06-10 Jason Merrill <jason@redhat.com>
+
+ * constexpr.c (free_constructor): New.
+ (cxx_eval_call_expression): Free parameter value CONSTRUCTORs.
+
+ * constexpr.c (unshare_constructor): Only unshare if T is itself a
+ CONSTRUCTOR.
+ (cxx_eval_call_expression): Don't call it on the result here.
+
+ Reduce constexpr_call memory consumption.
+ * constexpr.c (cxx_bind_parameters_in_call): Use TREE_VEC rather
+ than TREE_LIST.
+ (constexpr_call_hasher::equal, cxx_bind_parameters_in_call)
+ (cxx_eval_call_expression): Adjust.
+
+2019-06-10 Jakub Jelinek <jakub@redhat.com>
+
+ * parser.c (cp_parser_omp_clause_reduction): Don't sorry_at on inscan
+ reductions.
+ (cp_parser_omp_scan_loop_body): New function.
+ (cp_parser_omp_for_loop): Call cp_parser_omp_scan_loop_body if there
+ are inscan reduction clauses.
+ (cp_parser_pragma): Reject PRAGMA_OMP_SCAN.
+ * semantics.c (finish_omp_clauses): Reject mixing inscan with
+ non-inscan reductions on the same construct, or inscan reductions with
+ ordered or schedule clauses, or inscan array reductions.
+ * pt.c (tsubst_omp_clauses): Handle OMP_CLAUSE_{IN,EX}CLUSIVE.
+ (tsubst_expr): Handle OMP_SCAN.
+
+2019-06-07 Jason Merrill <jason@redhat.com>
+
+ * constexpr.c (cxx_eval_constant_expression): Call
+ STRIP_ANY_LOCATION_WRAPPER early.
+ [CONVERT_EXPR]: Don't build anything for conversion to void.
+ [ADDR_EXPR]: ggc_free unused ADDR_EXPR.
+
+2019-06-05 Martin Sebor <msebor@redhat.com>
+
+ PR c/90737
+ * typeck.c (maybe_warn_about_returning_address_of_local): Only
+ consider functions returning pointers as candidates for
+ -Wreturn-local-addr.
+
+2019-06-05 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (smallest_type_location): New.
+ (check_special_function_return_type): Use it.
+ (grokdeclarator): Lkewise.
+
+2019-06-05 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (grokdeclarator): Use locations[ds_friend]
+ in one place.
+
+2019-06-05 Martin Sebor <msebor@redhat.com>
+
+ * call.c (build_conditional_expr_1): Adjust quoting and hyphenation.
+ (convert_like_real): Same.
+ (convert_arg_to_ellipsis): Same.
+ * constexpr.c (diag_array_subscript): Same.
+ * constraint.cc (diagnose_trait_expression): Same.
+ * cvt.c (ocp_convert): Same.
+ * decl.c (start_decl): Same.
+ (check_for_uninitialized_const_var): Same.
+ (grokfndecl): Same.
+ (check_special_function_return_type): Same.
+ (finish_enum_value_list): Same.
+ (start_preparsed_function): Same.
+ * parser.c (cp_parser_decl_specifier_seq): Same.
+ * typeck.c (cp_build_binary_op): Same.
+ (build_static_cast_1): Same.
+
+2019-06-04 Nina Dinka Ranns <dinka.ranns@gmail.com>
+
+ PR c++/63149 - Wrong auto deduction from braced-init-list.
+ * pt.c (listify_autos): use non cv qualified auto_node in
+ std::initializer_list<auto>.
+
+2019-06-04 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (grokdeclarator): Use declarator->id_loc in two
+ additional places.
+
+2019-06-04 Nathan Sidwell <nathan@acm.org>
+
+ * name-lookup.c (lookup_type_scope_1): Reimplement, handle local
+ and namespace scopes separately.
+
+2019-06-04 Harald van Dijk <harald@gigawatt.nl>
+
+ PR c++/60531 - Wrong error about unresolved overloaded function
+ * typeck.c (cp_build_binary_op): See if overload can be resolved.
+ (cp_build_unary_op): Ditto.
+
+2019-06-04 Jason Merrill <jason@redhat.com>
+
+ Reduce accumulated garbage in constexpr evaluation.
+ * constexpr.c (cxx_eval_call_expression): ggc_free any bindings we
+ don't save.
+ (cxx_eval_increment_expression): ggc_free the MODIFY_EXPR after
+ evaluating it.
+
+2019-06-04 Jakub Jelinek <jakub@redhat.com>
+
+ * cp-tree.h (CP_OMP_CLAUSE_INFO): Allow for any clauses up to _condvar_
+ instead of only up to linear.
+
+2019-06-03 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * parser.c (cp_parser_unqualified_id): Use build_min_nt_loc in
+ five places.
+
+2019-06-01 Ville Voutilainen <ville.voutilainen@gmail.com>
+
+ PR c++/85254
+ * class.c (fixup_type_variants): Handle CLASSTYPE_FINAL.
+
+2019-05-31 Nathan Sidwell <nathan@acm.org>
+
+ * cp-tree.h (IDENTIFIER_LAMBDA_P): New.
+ (TYPE_ANON_P): New.
+ (LAMBDA_TYPE_P, TYPE_UNNAMED_P): Likewise.
+ (LAMBDANAME_PREFIX, LAMBDANAME_FORMAT): Delete.
+ (make_lambda_name): Don't declare.
+ * error.c (dump_aggr_type): Check for lambdas before other
+ anonymous names.
+ * lambda.c (begin_lambda_type): Use make_anon_name.
+ * cp-lang.c (cxx_dwarf_name): Lambda names smell anonymous.
+ * mangle.c (write_local_name): Likewise.
+ * name-lookup.c (lambda_cnt, make_lambda_name): Delete.
+
+2019-05-30 Marek Polacek <polacek@redhat.com>
+
+ * cp-tree.h (TYPE_HAS_NONTRIVIAL_DESTRUCTOR): Fix a typo.
+
+2019-05-31 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (grokdeclarator): Use declarator->id_loc in five
+ error_at calls.
+
+2019-05-29 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/90598
+ * tree.c (lvalue_kind): Return clk_none for expressions with
+ with VOID_TYPE_P.
+
+2019-05-29 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/89875
+ * parser.c (cp_parser_sizeof_operand): When the type-id production
+ did not work out commit to the tentative parse.
+
+2019-05-29 Jakub Jelinek <jakub@redhat.com>
+
+ P1091R3 - Extending structured bindings to be more like var decls
+ P1381R1 - Reference capture of structured bindings
+ * decl.c (cp_maybe_mangle_decomp): Handle TREE_STATIC decls even at
+ function scope.
+ (cp_finish_decomp): Copy over various decl properties from decl to
+ v[i] in the tuple case.
+ (grokdeclarator): Allow static, thread_local and __thread for C++2a
+ and use pedwarn instead of error for older standard revisions.
+ Make other structured binding diagnostic messages more i18n friendly.
+
+2019-05-28 Nathan Sidwell <nathan@acm.org>
+
+ * decl.c (duplicate_decls): Assert a template newdecl has no
+ specializations.
+
+2019-05-28 Marek Polacek <polacek@redhat.com>
+
+ PR c++/90548 - ICE with generic lambda and empty pack.
+ * pt.c (tsubst_copy_and_build): Handle pack expansion properly.
+
+2019-05-28 Nathan Sidwell <nathan@acm.org>
+
+ * cp-tree.h (make_anon_name): Drop declaration.
+ (TYPE_UNNAMED_P): Use IDENTIFIER_ANON_P.
+ * cp-lang.c (cxx_dwarf_name): Likewise.
+ * class.c (find_flexarrays): Likewise.
+ * decl.c (name_unnamed_type, xref_tag_1): Likewise.
+ * error.c (dump_aggr_type): Likewise.
+ * pt.c (push_template_decl_real): Likewise.
+ * name-lookup.c (consider_binding_level): Likewise.
+ (anon_cnt, make_anon_name): Delete.
+
+2019-05-25 Marek Polacek <polacek@redhat.com>
+
+ PR c++/90572 - wrong disambiguation in friend declaration.
+ * parser.c (cp_parser_constructor_declarator_p): Don't allow missing
+ typename for friend declarations.
+
+2019-05-23 Jonathan Wakely <jwakely@redhat.com>
+
+ * cp-tree.h (CP_AGGREGATE_TYPE_P): Fix whitespace.
+
+ * init.c (std_placement_new_fn_p): Remove outdated TODO comment that
+ was resolved by r254694.
+
+2019-05-22 Jason Merrill <jason@redhat.com>
+
+ PR c++/20408 - unnecessary code for empty struct.
+ * call.c (build_call_a): Use simple_empty_class_p.
+
+ PR c++/86485 - -Wmaybe-unused with empty class ?:
+ * cp-gimplify.c (simple_empty_class_p): Also true for MODIFY_EXPR.
+
+2019-05-21 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * parser.c (cp_parser_template_declaration_after_parameters): Use
+ DECL_SOURCE_LOCATION in literal operator template errors.
+
+2019-05-21 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/67184
+ PR c++/69445
+ * call.c (build_over_call): Devirtualize when the final overrider
+ comes from the base.
+
+2019-05-21 Nathan Sidwell <nathan@acm.org>
+
+ * name-lookup.c (do_nonmember_using_decl): Drop INSERT_P
+ parameter. Document.
+ (finish_nonmember_using_decl): Adjust do_nonmember_using_decl
+ calls. Remove stray FIXME comment.
+
+ * name-lookup.h (struct cp_binding_level): Drop usings field.
+ (finish_namespace_using_decl, finish_local_using_decl): Replace with ...
+ (finish_nonmember_using_decl): ... this.
+ * name-lookup.c (push_using_decl_1, push_using_decl):
+ (do_nonmember_using_decl): ... here. Add INSERT_P arg. Reimplement.
+ (validate_nonmember_using_decl, finish_namespace_using_decl)
+ (finish_local_using_decl): Replace with ...
+ (finish_nonmember_using_decl): ... this. Drop DECL parm.
+ * parser.c (cp_parser_using_declaration): Don't do lookup here.
+ * pt.c (tsubst_expr): Do not do using decl lookup here.
+
+2019-05-21 Eric Botcazou <ebotcazou@adacore.com>
+
+ * decl2.c (cpp_check) <IS_ASSIGNMENT_OPERATOR>: New case.
+
+2019-05-20 Marek Polacek <polacek@redhat.com>
+
+ CWG 2094 - volatile scalars are trivially copyable.
+ PR c++/85679
+ * tree.c (trivially_copyable_p): Don't check CP_TYPE_VOLATILE_P for
+ scalar types.
+
+2019-05-20 Marek Polacek <polacek@redhat.com>
+
+ * pt.c (convert_template_argument): Add a diagnostic for the
+ [temp.arg]/2 ambiguity case.
+
+ * name-lookup.c (finish_using_directive): Don't issue inform() if the
+ warning didn't trigger. Add quoting. Tweak the inform message.
+
+2019-05-20 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * cp-tree.h: Remove remnants of CONV_NONCONVERTING.
+
+2019-05-20 Nathan Sidwell <nathan@acm.org>
+
+ * name-lookup.c (finish_namespace_using_directive)
+ (finish_local_using_directive): Merge to ...
+ (finish_using_directive): ... here. Handle both contexts.
+ * name-lookup.h (finish_namespace_using_directive)
+ (finish_local_using_directive): Replace with ...
+ (finish_using_directive): ... this.
+ * parser.c (cp_parser_using_directive): Adjust.
+ * pt.c (tsubst_expr): Likewise.
+
+ * cp-tree.h (struct lang_decl_ns): Remove usings field.
+ (DECL_NAMESPACE_USING): Delete.
+ * name-lookup.c (name_lookup::search_usings): Use namespace's
+ binding scope.
+ (name_lookup::queue_namespae): Likewise.
+ (finish_namespace_using_directive, push_namespace): Likewise.
+ (has_using_namespace_std_directive): Just search the entire
+ binding stack.
+
+2019-05-20 Jonathan Wakely <jwakely@redhat.com>
+
+ PR c++/90532 Ensure __is_constructible(T[]) is false
+ * method.c (is_xible_helper): Return error_mark_node for construction
+ of an array of unknown bound.
+
+2019-05-17 Thomas Schwinge <thomas@codesourcery.com>
+
+ PR c++/89433
+ * parser.c (cp_finalize_oacc_routine): Rework checking if already
+ marked with an OpenACC 'routine' directive.
+
+ PR c++/89433
+ * parser.c (cp_parser_oacc_routine)
+ (cp_parser_late_parsing_oacc_routine): Normalize order of clauses.
+ (cp_finalize_oacc_routine): Call oacc_verify_routine_clauses.
+
+ PR c++/89433
+ * parser.c (cp_finalize_oacc_routine): Refer to OpenACC 'routine'
+ clauses from "omp declare target" attribute.
+
+2019-05-16 Martin Sebor <msebor@redhat.com>
+
+ * call.c (print_z_candidate): Wrap diagnostic text in a gettext
+ macro. Adjust.
+ (print_z_candidates): Same.
+ (build_conditional_expr_1): Quote keywords, operators, and types
+ in diagnostics.
+ (build_op_delete_call): Same.
+ (maybe_print_user_conv_context): Wrap diagnostic text in a gettext
+ macro.
+ (convert_like_real): Same.
+ (convert_arg_to_ellipsis): Quote keywords, operators, and types
+ in diagnostics.
+ (build_over_call): Same.
+ (joust): Break up an overlong line. Wrap diagnostic text in a gettext
+ macro.
+ * constexpr.c (cxx_eval_check_shift_p): Spell out >= in English.
+ (cxx_eval_constant_expression): Quote keywords, operators, and types
+ in diagnostics.
+ (potential_constant_expression_1): Same.
+ * cp-gimplify.c (cp_genericize_r): Same.
+ * cvt.c (maybe_warn_nodiscard): Quote keywords, operators, and types
+ in diagnostics.
+ (type_promotes_to): Same.
+ * decl.c (check_previous_goto_1): Same.
+ (check_goto): Same.
+ (start_decl): Same.
+ (cp_finish_decl): Avoid parenthesizing a sentence for consistency.
+ (grok_op_properties): Quote keywords, operators, and types
+ in diagnostics.
+ * decl2.c (grokfield): Same.
+ (coerce_delete_type): Same.
+ * except.c (is_admissible_throw_operand_or_catch_parameter): Same.
+ * friend.c (do_friend): Quote C++ tokens.
+ * init.c (build_new_1): Quote keywords, operators, and types
+ in diagnostics.
+ (build_vec_delete_1): Same.
+ (build_delete): Same.
+ * lex.c (parse_strconst_pragma): Same.
+ (handle_pragma_implementation): Same.
+ (unqualified_fn_lookup_error): Same.
+ * mangle.c (write_type): Same.
+ * method.c (defaulted_late_check): Avoid two consecutive punctuators.
+ * name-lookup.c (cp_binding_level_debug): Remove a trailing newline.
+ (pop_everything): Same.
+ * parser.c (cp_lexer_start_debugging): Quote a macro name.
+ in a diagnostic
+ (cp_lexer_stop_debugging): Same.
+ (cp_parser_userdef_numeric_literal): Quote a C++ header name
+ in a diagnostic.
+ (cp_parser_nested_name_specifier_opt): Quote keywords, operators,
+ and types in diagnostics.
+ (cp_parser_question_colon_clause): Same.
+ (cp_parser_asm_definition): Same.
+ (cp_parser_init_declarator): Same.
+ (cp_parser_template_declaration_after_parameters): Avoid capitalizing
+ a sentence in a diagnostic.
+ (cp_parser_omp_declare_reduction): Quote keywords, operators, and types
+ in diagnostics.
+ (cp_parser_transaction): Same.
+ * pt.c (maybe_process_partial_specialization): Replace second call
+ to permerror with inform for consistency with other uses.
+ (expand_integer_pack): Quote keywords, operators, and types
+ in diagnostics.
+ * rtti.c (get_typeid): Quote keywords, operators, and types
+ in diagnostics.
+ (build_dynamic_cast_1): Same.
+ * semantics.c (finish_asm_stmt): Same.
+ (finish_label_decl): Same.
+ (finish_bases): Same.
+ (finish_offsetof): Same.
+ (cp_check_omp_declare_reduction): Same.
+ (finish_decltype_type): Same.
+ * tree.c (handle_init_priority_attribute): Same. Add detail
+ to diagnostics.
+ (maybe_warn_zero_as_null_pointer_constant): Same.
+ * typeck.c (cp_build_binary_op): Quote keywords, operators, and types
+ in diagnostics.
+ (cp_build_unary_op): Same.
+ (check_for_casting_away_constness): Same.
+ (build_static_cast): Same.
+ (build_const_cast_1): Same.
+ (maybe_warn_about_returning_address_of_local): Same.
+ (check_return_expr): Same.
+ * typeck2.c (abstract_virtuals_error_sfinae): Same.
+ (digest_init_r): Replace a tab with spaces in a diagnostic.
+ (build_functional_cast): Quote keywords, operators, and types
+ in diagnostics.
+
+2019-05-15 Jakub Jelinek <jakub@redhat.com>
+
+ PR debug/90197
+ * cp-gimplify.c (genericize_cp_loop): Emit a DEBUG_BEGIN_STMT
+ before the condition (or if missing or constant non-zero at the end
+ of the loop. Emit a DEBUG_BEGIN_STMT before the increment expression
+ if any. Don't call protected_set_expr_location on incr if it already
+ has a location.
+
+2019-05-15 Marek Polacek <polacek@redhat.com>
+
+ CWG 2096 - constraints on literal unions.
+ * class.c (check_field_decls): Initialize booleans directly. A union
+ is literal if at least one of its non-static data members is of
+ non-volatile literal type.
+
+2019-05-15 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * cp-tree.h (REFERENCE_VLA_OK): Remove.
+ * lambda.c (build_capture_proxy): Remove use of the above.
+
+2019-05-15 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * call.c (perform_overload_resolution, build_new_method_call_1):
+ Use OVL_P; remove redundant TEMPLATE_DECL checks.
+ * decl.c (grokfndecl): Likewise.
+ * mangle.c (write_expression): Likewise.
+ * parser.c (cp_parser_template_id): Likewise.
+ * pt.c (resolve_overloaded_unification, type_dependent_expression_p):
+ Likewise.
+ * search.c (build_baselink): Likewise.
+ * tree.c (is_overloaded_fn, dependent_name, maybe_get_fns): Likewise.
+
+2019-05-14 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR preprocessor/90382
+ * decl.c (grokdeclarator): Fix value assigned to typespec_loc, use
+ min_location.
+
+2019-05-13 Jason Merrill <jason@redhat.com>
+
+ Use releasing_vec more broadly.
+ * cp-tree.h (struct releasing_vec): Replace get_ref method with
+ operator&.
+ (vec_safe_push, vec_safe_reserve, vec_safe_length, vec_safe_splice):
+ Forwarding functions for releasing_vec.
+ (release_tree_vector): Declare but don't define.
+ * call.c (build_op_delete_call, build_temp, call_copy_ctor)
+ (perform_direct_initialization_if_possible): Use releasing_vec.
+ * constexpr.c (cxx_eval_vec_init_1, cxx_eval_store_expression):
+ Likewise.
+ * cp-gimplify.c (cp_fold): Likewise.
+ * cvt.c (force_rvalue, ocp_convert): Likewise.
+ * decl.c (get_tuple_decomp_init): Likewise.
+ * except.c (build_throw): Likewise.
+ * init.c (perform_member_init, expand_default_init): Likewise.
+ * method.c (do_build_copy_assign, locate_fn_flags): Likewise.
+ * parser.c (cp_parser_userdef_char_literal)
+ (cp_parser_userdef_numeric_literal)
+ (cp_parser_userdef_string_literal)
+ (cp_parser_perform_range_for_lookup)
+ (cp_parser_range_for_member_function, cp_parser_omp_for_loop)
+ (cp_parser_omp_for_loop_init): Likewise.
+ * pt.c (tsubst_copy_and_build, do_class_deduction): Likewise.
+ * semantics.c (calculate_direct_bases, calculate_bases)
+ (finish_omp_barrier, finish_omp_flush, finish_omp_taskwait)
+ (finish_omp_taskyield, finish_omp_cancel)
+ (finish_omp_cancellation_point): Likewise.
+ * tree.c (build_vec_init_elt, strip_typedefs, strip_typedefs_expr)
+ (build_min_non_dep_op_overload): Likewise.
+ * typeck.c (build_function_call_vec, cp_build_function_call_nary)
+ (cp_build_modify_expr): Likewise.
+ * typeck2.c (build_functional_cast): Likewise.
+
+2019-05-11 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * typeck.c (cp_build_function_call_vec): When mark_used fails
+ unconditionally return error_mark_node.
+
+2019-05-10 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (grokvardecl): Use an accurate location in error message
+ about main as a global variable.
+
+2019-05-10 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * call.c (build_call_a): Use FUNC_OR_METHOD_TYPE_P.
+ * cp-gimplify.c (cp_fold): Likewise.
+ * cp-objcp-common.c (cp_type_dwarf_attribute): Likewise.
+ * cp-tree.h (TYPE_OBJ_P, TYPE_PTROBV_P): Likewise.
+ * cvt.c (perform_qualification_conversions): Likewise.
+ * decl.c (grokdeclarator): Likewise.
+ * decl2.c (build_memfn_type): Likewise.
+ * mangle.c (canonicalize_for_substitution, write_type): Likewise.
+ * parser.c (cp_parser_omp_declare_reduction): Likewise.
+ * pt.c (check_explicit_specialization, uses_deducible_template_parms,
+ check_cv_quals_for_unify, dependent_type_p_r): Likewise.
+ * rtti.c (ptr_initializer): Likewise.
+ * semantics.c (finish_asm_stmt, finish_offsetof,
+ cp_check_omp_declare_reduction): Likewise.
+ * tree.c (cp_build_qualified_type_real,
+ cp_build_type_attribute_variant, cxx_type_hash_eq,
+ cxx_copy_lang_qualifiers, cp_free_lang_data): Likewise.
+ * typeck.c (structural_comptypes, convert_arguments,
+ cp_build_addr_expr_1, unary_complex_lvalue, cp_build_c_cast,
+ cp_build_modify_expr, comp_ptr_ttypes_real, type_memfn_rqual):
+ Likewise.
+
+2019-05-10 Marek Polacek <polacek@redhat.com>
+
+ PR c++/78010 - bogus -Wsuggest-override warning on final function.
+ * class.c (check_for_override): Don't warn for final functions.
+
+2019-05-10 Jakub Jelinek <jakub@redhat.com>
+
+ PR pch/90326
+ * config-lang.in (gtfiles): Remove c-family/c-lex.c, add
+ c-family/c-cppbuiltin.c.
+
+2019-05-09 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/90382
+ Revert:
+ 2018-04-26 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (grokdeclarator): Fix value assigned to typespec_loc, use
+ min_location.
+
+2019-05-08 Nathan Sidwell <nathan@acm.org>
+
+ Kill DECL_SAVED_FUNCTION_DATA .
+ * cp-tree.h (language_function): Remove x_auto_return_pattern.
+ (current_function_auto_return_pattern): Delete.
+ (lang_decl_fn): Replace saved_language_function with
+ saved_auto_return type.
+ (DECL_SAVED_FUNCTION_DATA): Delete.
+ (DECL_SAVED_AUTO_RETURN_TYPE): New.
+ (FNDECL_USED_AUTO): Correct documentation.
+ * decl.c (duplicate_decls): Adjust AUTO return handling.
+ (start_preparsed_function): Replace
+ current_function_auto_return_pattern with
+ DECL_SAVED_AUTO_RETURN_TYPE. Remove DECL_SAVED_FUNCTION_DATA
+ zapping.
+ (finish_function): Likewise.
+ (save_function_data): Delete.
+ (fndecl_declared_return_type): Reimplement.
+ * mangle.c (write_unqualified_name): Use DECL_SAVED_AUTO_RETURN_TYPE.
+ * method.c (make_thunk, make_alias_for): Likewise.
+ * parser.c (cp_parser_jump_statement): Likewise.
+ * pt.c (do_auto_deduction): Likewise.
+ * typeck.c (check_return_expr): Likewise.
+
+2019-05-06 Jason Merrill <jason@redhat.com>
+
+ PR c++/90171 - reorganize usual_deallocation_fn_p
+ * call.c (struct dealloc_info): New.
+ (usual_deallocation_fn_p): Take a dealloc_info*.
+ (aligned_deallocation_fn_p, sized_deallocation_fn_p): Remove.
+ (build_op_delete_call): Adjust.
+
+2019-05-07 Jason Merrill <jason@redhat.com>
+
+ PR c++/86485 - -Wmaybe-unused with empty class ?:
+ * typeck.c (build_static_cast_1): Use cp_build_addr_expr.
+
+ * pt.c (type_dependent_expression_p): A non-type template parm with
+ a placeholder type is type-dependent.
+
+2019-05-06 Marek Polacek <polacek@redhat.com>
+
+ PR c++/90265 - ICE with generic lambda.
+ * pt.c (tsubst_copy_and_build): Use a dedicated variable for the last
+ element in the vector.
+
+2019-05-03 Martin Liska <mliska@suse.cz>
+
+ * call.c (build_aggr_conv): Use is_empty instead of
+ elements () == 0 (and similar usages).
+ * parser.c (cp_parser_lambda_introducer): Likewise.
+
+2019-05-02 Nathan Sidwell <nathan@acm.org>
+
+ * semantics.c (finish_id_expression_1): Remove unreachable code.
+
+2019-05-01 Nathan Sidwell <nathan@acm.org>
+
+ * name-lookup.h (get_class_binding_direct): Change final arg to
+ bool.
+ (get_class_binding): Likewise.
+ * name-lookup.c (get_class_binding_direct): Replace TYPE_OR_FNS
+ arg with WANT_TYPE bool. Simplify.
+ (get_class_binding): Adjust final arg.
+ * decl.c (reshape_init_class): Adjust get_class_binding calls.
+
+2019-04-30 Nathan Sidwell <nathan@acm.org>
+
+ * cp-objcp-common.c (cp_common_init_ts): Use MARK_TS_EXP for _EXPR
+ nodes. Call c_common_init_ts.
+
+2019-04-29 Nathan Sidwell <nathan@acm.org>
+
+ * decl.c (duplicate_decls): Add whitespace, move comments into
+ conditional blocks.
+ * method.c (explain_implicit_non_constexpr): Refactor.
+ * pt.c (check_explicit_specialization): Fix indentation.
+ * semantics.c (process_outer_var_ref): Reformat.
+ (finish_id_expression_1): Use STRIP_TEMPLATE.
+
+2019-04-26 Jonathan Wakely <jwakely@redhat.com>
+
+ PR c++/90243 - orphaned note in uninstantiated constexpr function
+ * decl.c (check_for_uninitialized_const_var): Suppress notes if no
+ error was shown.
+
+2019-04-26 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/90173
+ * decl.c (grokdeclarator): Set type to error_mark_node
+ upon error about template placeholder type non followed
+ by a simple declarator-id.
+
+2019-04-26 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (grokdeclarator): Fix value assigned to typespec_loc, use
+ min_location.
+
+2019-04-24 Jason Merrill <jason@redhat.com>
+
+ PR c++/90227 - error with template parameter packs.
+ * pt.c (coerce_template_parms): Do add empty pack when
+ require_all_args.
+
+2019-04-24 Richard Biener <rguenther@suse.de>
+
+ * call.c (null_ptr_cst_p): Order checks according to expensiveness.
+ (conversion_null_warnings): Likewise.
+ * typeck.c (same_type_ignoring_top_level_qualifiers_p): Return
+ early if type1 == type2.
+
+2019-04-22 Jason Merrill <jason@redhat.com>
+
+ PR c++/87366 - wrong error with alias template.
+ * typeck.c (structural_comptypes): When comparing_specializations,
+ aliases are unequal.
+ (comptypes): When comparing_specializations, do structural
+ comparison.
+
+2019-04-19 Jason Merrill <jason@redhat.com>
+
+ PR c++/90190 - CTAD with list-constructor.
+ * pt.c (do_class_deduction): Don't try the single element deduction
+ if the single element is also a braced list.
+
+ PR c++/90171 - ICE with destroying delete with size_t parm.
+ * call.c (sized_deallocation_fn_p): New. Use it instead of
+ second_parm_is_size_t in most cases.
+ (second_parm_is_size_t): Don't check for aligned.
+
+2019-04-19 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/89900
+ * pt.c (fn_type_unification): When handling null explicit
+ arguments do not special case non-parameter packs.
+
+2019-04-19 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/90138
+ * pt.c (process_template_parm): Set decl to pushdecl result. If
+ !is_non_type, also set parm to that.
+
+ PR c/89888
+ * decl.c (struct cp_switch): Remove outside_range_p member.
+ (push_switch): Don't clear it.
+ (pop_switch): Adjust c_do_switch_warnings caller.
+ (finish_case_label): Adjust c_add_case_label caller.
+
+ PR c++/90108
+ * decl.c (duplicate_decls): If remove is main variant and
+ DECL_ORIGINAL_TYPE is some other type, remove a DECL_ORIGINAL_TYPE
+ variant that has newdecl as TYPE_NAME if any.
+
+2019-04-18 Jason Merrill <jason@redhat.com>
+
+ PR c++/87554 - ICE with extern template and reference member.
+ * decl.c (cp_finish_decl): Don't set DECL_INITIAL of external vars.
+
+2019-04-17 Jason Merrill <jason@redhat.com>
+
+ PR c++/90047 - ICE with enable_if alias template.
+ * pt.c (tsubst_decl) [TYPE_DECL]: Don't put an erroneous decl in the
+ hash table when we're in SFINAE context.
+
+2019-04-17 Marek Polacek <polacek@redhat.com>
+
+ PR c++/90124 - bogus error with incomplete type in decltype.
+ * typeck.c (build_class_member_access_expr): Check
+ cp_unevaluated_operand.
+
+2019-04-12 Jakub Jelinek <jakub@redhat.com>
+
+ PR c/89933
+ * decl.c (duplicate_decls): When newdecl's type is its main variant,
+ don't try to remove it from the variant list, but instead assert
+ it has no variants.
+
+2019-04-12 Martin Sebor <msebor@redhat.com>
+
+ PR c/88383
+ PR c/89288
+ * parser.c (cp_parser_has_attribute_expression): Handle assignment
+ expressions.
+
+2019-04-12 Jason Merrill <jason@redhat.com>
+
+ * call.c (null_member_pointer_value_p): Handle an empty CONSTRUCTOR
+ of PMF type.
+
+2019-04-12 Marek Polacek <polacek@redhat.com>
+
+ * except.c (build_noexcept_spec): Use build_converted_constant_bool_expr
+ instead of perform_implicit_conversion_flags.
+
+ PR c++/87603 - constexpr functions are no longer noexcept.
+ * constexpr.c (is_sub_constant_expr): Remove unused function.
+ * cp-tree.h (is_sub_constant_expr): Remove declaration.
+ * except.c (check_noexcept_r): Don't consider a call to a constexpr
+ function noexcept.
+
+2019-04-11 Jakub Jelinek <jakub@redhat.com>
+
+ PR translation/90035
+ * parser.h (struct cp_parser): Add
+ type_definition_forbidden_message_arg member.
+ * parser.c (cp_debug_parser): Print it.
+ (cp_parser_check_type_definition): Pass
+ parser->type_definition_forbidden_message_arg as second argument to
+ error.
+ (cp_parser_has_attribute_expression, cp_parser_sizeof_operand): Set
+ parser->type_definition_forbidden_message_arg and use G_() with
+ %qs for parser->type_definition_forbidden_message instead of
+ building untranslatable message using concat.
+
+2019-04-09 Jakub Jelinek <jakub@redhat.com>
+
+ PR translation/90011
+ * typeck2.c (check_narrowing): Remove trailing space from diagnostics.
+
+2019-04-08 Marek Polacek <polacek@redhat.com>
+
+ * typeck2.c (digest_init_r): Don't condition the object slicing warning
+ on flag_checking.
+
+2019-04-08 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/89914
+ * semantics.c (trait_expr_value): Don't use TYPE_NOTHROW_P
+ when maybe_instantiate_noexcept fails.
+ (classtype_has_nothrow_assign_or_copy_p): Likewise.
+ * method.c (implicitly_declare_fn): Avoid passing error_mark_node
+ to build_exception_variant.
+
+2019-04-05 Marek Polacek <polacek@redhat.com>
+
+ PR c++/87145 - bogus error converting class type in template arg list.
+ * pt.c (convert_nontype_argument): Don't call
+ build_converted_constant_expr if it could involve calling a conversion
+ function with a instantiation-dependent constructor as its argument.
+
+2019-04-05 Martin Sebor <msebor@redhat.com>
+
+ PR bootstrap/89980
+ * decl.c (reshape_init_array_1): Avoid treating empty strings
+ as zeros in array initializers.
+ Use trivial_type_p () instead of TYPE_HAS_TRIVIAL_DFLT().
+
+2019-04-04 Jason Merrill <jason@redhat.com>
+
+ PR c++/89948 - ICE with break in statement-expr.
+ * constexpr.c (cxx_eval_statement_list): Jumping out of a
+ statement-expr is non-constant.
+
+2019-04-04 Jason Merrill <jason@redhat.com>
+
+ PR c++/89966 - error with non-type auto tparm.
+ * pt.c (do_auto_deduction): Clear tf_partial.
+
+2019-04-04 Jason Merrill <jason@redhat.com>
+
+ PR c++/86986 - ICE with TTP with parameter pack.
+ * pt.c (coerce_template_parameter_pack): Only look at the type of a
+ non-type parameter pack.
+ (fixed_parameter_pack_p_1): Don't recurse into the type of a
+ non-type parameter pack.
+ (coerce_template_template_parms): Call add_outermost_template_args.
+
+2019-04-04 Martin Sebor <msebor@redhat.com>
+
+ PR c++/89974
+ PR c++/89878
+ PR c++/89833
+ PR c++/47488
+ * decl.c (reshape_init_array_1): Strip trailing zero-initializers
+ from arrays of trivial type and known size.
+ * mangle.c (write_expression): Convert braced initializer lists
+ to STRING_CSTs.
+ (write_expression): Trim trailing zero-initializers from arrays
+ of trivial type.
+ (write_template_arg_literal): Mangle strings the same as braced
+ initializer lists.
+
+2019-04-03 Jason Merrill <jason@redhat.com>
+
+ PR c++/81866 - ICE with member template and default targ.
+ * pt.c (tsubst_template_decl): Handle getting a type from
+ retrieve_specialization.
+
+ PR c++/86586 - -fcompare-debug=-Wsign-compare.
+ * typeck.c (cp_build_binary_op): Don't fold for -Wsign-compare.
+
+ PR c++/89331 - ICE with offsetof in incomplete class.
+ * semantics.c (finish_offsetof): Handle error_mark_node.
+ * typeck.c (build_class_member_access_expr): Call
+ complete_type_or_maybe_complain before converting to base.
+
+ PR c++/89917 - ICE with lambda in variadic mem-init.
+ * pt.c (make_pack_expansion): Change type_pack_expansion_p to false.
+
+2019-04-01 Jason Merrill <jason@redhat.com>
+
+ PR c++/86946 - ICE with function call in template argument.
+ DR 1321
+ * pt.c (iterative_hash_template_arg) [CALL_EXPR]: Use
+ dependent_name.
+
+2019-04-01 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/62207
+ * pt.c (tsubst_copy): Deal with lookup_name not returing a variable.
+
+2019-03-31 Marek Polacek <polacek@redhat.com>
+
+ PR c++/89852 - ICE with C++11 functional cast with { }.
+ * constexpr.c (fold_non_dependent_expr_template): New static function
+ broken out of...
+ (fold_non_dependent_expr): ...here.
+ (fold_non_dependent_init): New function.
+ * cp-tree.h (fold_non_dependent_init): Declare.
+ * typeck2.c (massage_init_elt): Call fold_non_dependent_init instead
+ of fold_non_dependent_expr. Don't call maybe_constant_init.
+
+2019-03-30 Jason Merrill <jason@redhat.com>
+
+ PR c++/89744 - ICE with specialization of member class template.
+ * pt.c (lookup_template_class_1): If the partial instantiation is
+ explicitly specialized, adjust.
+ (maybe_process_partial_specialization): Also adjust
+ CLASSTYPE_TI_ARGS.
+
+2019-03-29 Jakub Jelinek <jakub@redhat.com>
+
+ PR sanitizer/89869
+ * typeck.c: Include gimplify.h.
+ (cp_build_modify_expr) <case COND_EXPR>: Unshare rhs before using it
+ for second time. Formatting fixes.
+
+2019-03-29 Marek Polacek <polacek@redhat.com>
+
+ PR c++/89876 - ICE with deprecated conversion.
+ * call.c (convert_like_real): Only give warnings with tf_warning.
+
+2019-03-28 Marek Polacek <polacek@redhat.com>
+
+ PR c++/89612 - ICE with member friend template with noexcept.
+ * pt.c (maybe_instantiate_noexcept): For function templates, use their
+ template result (function decl). Don't set up local specializations.
+ Temporarily turn on processing_template_decl. Update the template type
+ too.
+
+ PR c++/89836 - bool constant expression and explicit conversions.
+ * call.c (build_converted_constant_expr_internal): New function,
+ renamed from...
+ (build_converted_constant_expr): ...this. New.
+ (build_converted_constant_bool_expr): New.
+ * cp-tree.h (build_converted_constant_bool_expr): Declare.
+ * decl.c (build_explicit_specifier): Call
+ build_converted_constant_bool_expr.
+
+2019-03-28 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/89785
+ * constexpr.c (struct check_for_return_continue_data): New type.
+ (check_for_return_continue): New function.
+ (potential_constant_expression_1) <case SWITCH_STMT>: Walk
+ SWITCH_STMT_BODY to find RETURN_EXPRs or CONTINUE_STMTs not nested
+ in loop bodies and set *jump_target to that if found.
+
+2019-03-27 Jason Merrill <jason@redhat.com>
+
+ PR c++/89831 - error with qualified-id in const member function.
+ * semantics.c (finish_non_static_data_member): Use object cv-quals
+ in scoped case, too.
+
+ PR c++/89421 - ICE with lambda in template parameter list.
+ * parser.c (cp_parser_lambda_expression): Also reject a lambda in a
+ template parameter list before C++20.
+ * pt.c (type_dependent_expression_p): True for LAMBDA_EXPR.
+ * semantics.c (begin_class_definition): Restore error about defining
+ non-lambda class in template parm list.
+
+2019-03-26 Jason Merrill <jason@redhat.com>
+
+ PR c++/86932 - missed SFINAE with empty pack.
+ * pt.c (coerce_template_parms): Don't add an empty pack if
+ tf_partial.
+ (fn_type_unification): Pass tf_partial to coerce_template_parms.
+
+ PR c++/86429 - constexpr variable in lambda.
+ PR c++/82643
+ PR c++/87327
+ * constexpr.c (cxx_eval_constant_expression): In a lambda function,
+ try evaluating the captured variable directly.
+
+2019-03-26 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/89796
+ * semantics.c (finish_omp_atomic): Add warning_sentinel for
+ -Wunused-value around finish_expr_stmt call.
+
+2019-03-25 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/84661
+ PR c++/85013
+ * parser.c (cp_parser_binary_expression): Don't call cp_fully_fold
+ to undo the disabling of warnings.
+
+2019-03-25 Jason Merrill <jason@redhat.com>
+
+ PR c++/87748 - substitution failure error with decltype.
+ * pt.c (most_specialized_partial_spec): Clear
+ processing_template_decl.
+
+2019-03-25 Marek Polacek <polacek@redhat.com>
+
+ PR c++/89214 - ICE when initializing aggregates with bases.
+ * typeck2.c (digest_init_r): Warn about object slicing instead of
+ crashing.
+
+ PR c++/89705 - ICE with reference binding with conversion function.
+ * call.c (reference_binding): If the result of the conversion function
+ is a prvalue of non-class type, use the cv-unqualified type.
+
+2019-03-25 Nathan Sidwell <nathan@acm.org>
+
+ * lambda.c (maybe_add_lambda_conv_op): Don't add to comdat group.
+
+2019-03-22 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/60702
+ * cp-tree.h (get_tls_wrapper_fn): Remove declaration.
+ (maybe_get_tls_wrapper_call): Declare.
+ * decl2.c (get_tls_wrapper_fn): Make static.
+ (maybe_get_tls_wrapper_call): New function.
+ * typeck.c (build_class_member_access_expr): Handle accesses to TLS
+ variables.
+ * semantics.c (finish_qualified_id_expr): Likewise.
+ (finish_id_expression_1): Use maybe_get_tls_wrapper_call.
+ * pt.c (tsubst_copy_and_build): Likewise.
+
+ PR c++/87481
+ * constexpr.c (struct constexpr_ctx): Add constexpr_ops_count member.
+ (cxx_eval_constant_expression): When not skipping, not constant class
+ or location wrapper, increment *ctx->constexpr_ops_count and if it is
+ above constexpr_loop_nest_limit, diagnose failure.
+ (cxx_eval_outermost_constant_expr): Add constexpr_ops_count and
+ initialize ctx.constexpr_ops_count to its address.
+ (is_sub_constant_expr): Likewise.
+
+2019-03-21 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/71446
+ * call.c (filed_in_pset): Change pset from hash_set<tree> * to
+ hash_set<tree, true> &, adjust uses accordingly.
+ (build_aggr_conv): Change pset from hash_set<tree> *
+ to hash_set<tree, true>. Replace goto fail; with return NULL;,
+ adjust pset uses.
+
+ PR c++/89767
+ * parser.c (cp_parser_lambda_introducer): Add ids and first_capture_id
+ variables, check for duplicates in this function.
+ * lambda.c (add_capture): Don't check for duplicates nor use
+ IDENTIFIER_MARKED.
+ (register_capture_members): Don't clear IDENTIFIER_MARKED here.
+
+2019-03-21 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/89571
+ * method.c (after_nsdmi_defaulted_late_checks): Avoid passing
+ error_mark_node to comp_except_specs.
+
+2019-03-20 Jason Merrill <jason@redhat.com>
+
+ PR c++/87480 - decltype of member access in default template arg
+ * pt.c (type_unification_real): Accept a dependent result in
+ template context.
+
+2019-03-19 Martin Sebor <msebor@redhat.com>
+
+ PR tree-optimization/89688
+ * typeck2.c (store_init_value): Call braced_lists_to_string for more
+ kinds of initializers.
+
+2019-03-18 Jason Merrill <jason@redhat.com>
+
+ PR c++/89630 - ICE with dependent using-decl as template arg.
+ * tree.c (cp_tree_equal): Always return false for USING_DECL.
+
+ PR c++/89761 - ICE with sizeof... in pack expansion.
+ * pt.c (argument_pack_element_is_expansion_p): Handle
+ ARGUMENT_PACK_SELECT.
+
+ PR c++/89640 - GNU attributes on lambda.
+ * parser.c (cp_parser_lambda_declarator_opt): Allow GNU attributes.
+
+ PR c++/89682 - wrong access error in default argument.
+ * pt.c (tsubst_default_argument): Don't defer access checks.
+
+2019-03-18 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/85014
+ * semantics.c (finish_non_static_data_member): Check return value
+ of context_for_name_lookup and immediately return error_mark_node
+ if isn't a type.
+
+2019-03-17 Jason Merrill <jason@redhat.com>
+
+ PR c++/89571 - ICE with ill-formed noexcept on constructor.
+ * pt.c (maybe_instantiate_noexcept): Only return false if defaulted.
+ (regenerate_decl_from_template): Use it for noexcept-specs.
+
+2019-03-14 Jason Merrill <jason@redhat.com>
+
+ * parser.c (cp_parser_decl_specifier_seq): Support C++20
+ concept-definition syntax without 'bool'.
+
+2019-03-14 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/89512
+ * semantics.c (finish_qualified_id_expr): Reject variable templates.
+
+ PR c++/89652
+ * constexpr.c (struct constexpr_ctx): Change save_exprs type from
+ hash_set<tree> to vec<tree>.
+ (cxx_eval_call_expression): Adjust for save_exprs being a vec instead
+ of hash_set.
+ (cxx_eval_loop_expr): Likewise. Truncate the vector after each
+ removal of SAVE_EXPRs from values.
+ (cxx_eval_constant_expression) <case SAVE_EXPR>: Call safe_push
+ method on save_exprs instead of add.
+
+2019-03-13 Jason Merrill <jason@redhat.com>
+
+ PR c++/86521 - C++17 copy elision in initialization by constructor.
+ * call.c (joust_maybe_elide_copy): New.
+ (joust): Call it.
+
+2019-03-13 Marek Polacek <polacek@redhat.com>
+
+ PR c++/88979 - further P0634 fix for constructors.
+ * parser.c (cp_parser_decl_specifier_seq): Pass flags to
+ cp_parser_constructor_declarator_p.
+ (cp_parser_direct_declarator): Allow missing typename for constructor
+ parameters.
+ (cp_parser_constructor_declarator_p): Add FLAGS parameter. Pass it to
+ cp_parser_type_specifier.
+
+ PR c++/89686 - mixing init-capture and simple-capture in lambda.
+ * parser.c (cp_parser_lambda_introducer): Give error when combining
+ init-capture and simple-capture.
+
+ PR c++/89660 - bogus error with -Wredundant-move.
+ * typeck.c (maybe_warn_pessimizing_move): Only accept (T &) &arg
+ as the std::move's argument. Don't call convert_for_initialization
+ when warn_redundant_move isn't on.
+
+2019-03-11 Jason Merrill <jason@redhat.com>
+
+ PR c++/86521 - wrong overload resolution with ref-qualifiers.
+ * call.c (build_user_type_conversion_1): Don't use a conversion to a
+ reference of the wrong rvalueness for direct binding.
+
+2019-03-11 Martin Liska <mliska@suse.cz>
+
+ * cvt.c (build_expr_type_conversion): Wrap apostrophes
+ in gcc internal format with %'.
+ * decl.c (check_no_redeclaration_friend_default_args): Likewise.
+ (grokfndecl): Likewise.
+ * name-lookup.c (do_pushtag): Likewise.
+ * pt.c (unify_parameter_deduction_failure): Likewise.
+ (unify_template_deduction_failure): Likewise.
+
+2019-03-11 Martin Liska <mliska@suse.cz>
+
+ * call.c (convert_arg_to_ellipsis): Wrap an option name
+ in a string format message and fix GNU coding style.
+ (build_over_call): Likewise.
+ * class.c (check_field_decl): Likewise.
+ (layout_nonempty_base_or_field): Likewise.
+ * constexpr.c (cxx_eval_loop_expr): Likewise.
+ * cvt.c (type_promotes_to): Likewise.
+ * decl.c (cxx_init_decl_processing): Likewise.
+ (mark_inline_variable): Likewise.
+ (grokdeclarator): Likewise.
+ * decl2.c (record_mangling): Likewise.
+ * error.c (maybe_warn_cpp0x): Likewise.
+ * except.c (doing_eh): Likewise.
+ * mangle.c (maybe_check_abi_tags): Likewise.
+ * parser.c (cp_parser_diagnose_invalid_type_name): Likewise.
+ (cp_parser_userdef_numeric_literal): Likewise.
+ (cp_parser_primary_expression): Likewise.
+ (cp_parser_unqualified_id): Likewise.
+ (cp_parser_pseudo_destructor_name): Likewise.
+ (cp_parser_builtin_offsetof): Likewise.
+ (cp_parser_lambda_expression): Likewise.
+ (cp_parser_lambda_introducer): Likewise.
+ (cp_parser_lambda_declarator_opt): Likewise.
+ (cp_parser_selection_statement): Likewise.
+ (cp_parser_init_statement): Likewise.
+ (cp_parser_decomposition_declaration): Likewise.
+ (cp_parser_function_specifier_opt): Likewise.
+ (cp_parser_static_assert): Likewise.
+ (cp_parser_simple_type_specifier): Likewise.
+ (cp_parser_namespace_definition): Likewise.
+ (cp_parser_using_declaration): Likewise.
+ (cp_parser_ctor_initializer_opt_and_function_body): Likewise.
+ (cp_parser_initializer_list): Likewise.
+ (cp_parser_type_parameter_key): Likewise.
+ (cp_parser_member_declaration): Likewise.
+ (cp_parser_try_block): Likewise.
+ (cp_parser_std_attribute_spec): Likewise.
+ (cp_parser_requires_clause_opt): Likewise.
+ * pt.c (check_template_variable): Likewise.
+ (check_default_tmpl_args): Likewise.
+ (push_tinst_level_loc): Likewise.
+ (instantiate_pending_templates): Likewise.
+ (invalid_nontype_parm_type_p): Likewise.
+ * repo.c (get_base_filename): Likewise.
+ * rtti.c (typeid_ok_p): Likewise.
+ (build_dynamic_cast_1): Likewise.
+ * tree.c (maybe_warn_parm_abi): Likewise.
+
+2019-03-08 Jakub Jelinek <jakub@redhat.com>
+
+ PR other/80058
+ * parser.c (cp_parser_template_declaration_after_parameters): Avoid
+ one space before " at the end of line and another after " on another
+ line in a string literal.
+
+ PR tree-optimization/89550
+ * semantics.c (maybe_convert_cond): Only set TREE_NO_WARNING if
+ warning_at returned true.
+ * decl2.c (c_parse_final_cleanups): Likewise.
+ * typeck.c (convert_for_assignment): Likewise.
+ * decl.c (finish_function): Likewise.
+
+ PR c++/89585
+ * parser.c (cp_parser_asm_definition): Just warn instead of error
+ on volatile qualifier outside of function body.
+
+ PR c++/89599
+ * constexpr.c (potential_constant_expression_1): Reject
+ REINTERPRET_CAST_P NOP_EXPRs.
+
+ PR c++/89622
+ * call.c (joust): Call print_z_candidate only if pedwarn returned
+ true.
+
+2019-03-07 Jason Merrill <jason@redhat.com>
+
+ PR c++/88123 - lambda and using-directive.
+ * name-lookup.c (op_unqualified_lookup)
+ (maybe_save_operator_binding, discard_operator_bindings)
+ (push_operator_bindings): New.
+ * typeck.c (build_x_binary_op, build_x_unary_op): Call
+ maybe_save_operator_binding.
+ * decl.c (start_preparsed_function): Call push_operator_bindings.
+ * tree.c (cp_free_lang_data): Call discard_operator_bindings.
+
+ PR c++/88820 - ICE with CTAD and member template used in DMI.
+ * pt.c (do_class_deduction): Handle parm used as its own arg.
+
+2019-03-07 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/89585
+ * parser.c (cp_parser_asm_definition): Parse asm qualifiers even
+ at toplevel, but diagnose them.
+
+2019-03-06 Jason Merrill <jason@redhat.com>
+
+ PR c++/89381 - implicit copy and using-declaration.
+ * class.c (classtype_has_move_assign_or_move_ctor_p): Don't consider
+ op= brought in by a using-declaration.
+
+2019-03-06 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/87148
+ * init.c (build_value_init_noctor): Ignore flexible array members.
+
+2019-03-06 Jason Merrill <jason@redhat.com>
+
+ PR c++/89576 - if constexpr of lambda capture.
+ * semantics.c (maybe_convert_cond): Do convert a non-dependent
+ condition in a template.
+ * typeck.c (condition_conversion): Handle being called in a
+ template.
+
+2019-03-06 Marek Polacek <polacek@redhat.com>
+
+ PR c++/87378 - bogus -Wredundant-move warning.
+ * typeck.c (maybe_warn_pessimizing_move): See if the maybe-rvalue
+ overload resolution would actually succeed.
+
+2019-03-05 Jason Merrill <jason@redhat.com>
+
+ * class.c (is_really_empty_class): Add ignore_vptr parm.
+ (trivial_default_constructor_is_constexpr): Pass it.
+ * call.c (build_over_call): Pass it.
+ * constexpr.c (cxx_eval_constant_expression): Pass it instead of
+ checking TYPE_POLYMORPHIC_P.
+ (cxx_eval_component_reference, potential_constant_expression_1):
+ Pass it.
+ * cp-gimplify.c (simple_empty_class_p): Pass it.
+ * init.c (expand_aggr_init_1): Pass it.
+
+2019-03-04 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/84605
+ * parser.c (cp_parser_class_head): Reject TYPE_BEING_DEFINED too.
+
+2019-03-04 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/71446
+ * call.c (field_in_pset): New function.
+ (build_aggr_conv): Handle CONSTRUCTOR_IS_DESIGNATED_INIT correctly.
+
+2019-03-02 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/71446
+ * cp-tree.h (CONSTRUCTOR_IS_DESIGNATED_INIT): Define.
+ * parser.c (cp_parser_braced_list): Adjust cp_parser_initializer_list
+ caller, set CONSTRUCTOR_IS_DESIGNATED_INIT.
+ (cp_parser_initializer_list): Add designated parameter, set *designated
+ to a bool whether any designators were parsed.
+ * decl.c (reshape_init): Copy over CONSTRUCTOR_IS_DESIGNATED_INIT if
+ needed.
+ * pt.c (tsubst_copy_and_build): Likewise.
+ * call.c (implicit_conversion): If CONSTRUCTOR_IS_DESIGNATED_INIT,
+ don't call build_list_conv, nor build_complex_conv, nor attempt to
+ convert a single element initializer to scalar.
+
+2019-03-01 Marek Polacek <polacek@redhat.com>
+
+ PR c++/89537 - missing location for error with non-static member fn.
+ * call.c (resolve_args): Use EXPR_LOCATION.
+ * typeck.c (build_class_member_access_expr): Use input_location.
+
+ PR c++/89532 - ICE with incomplete type in decltype.
+ * semantics.c (finish_compound_literal): Return error_mark_node
+ if digest_init_flags returns error_mark_node.
+
+2019-03-01 Jakub Jelinek <jakub@redhat.com>
+
+ Implement P1002R1, Try-catch blocks in constexpr functions
+ PR c++/89513
+ * parser.c (cp_parser_ctor_initializer_opt_and_function_body):
+ Diagnose constexpr ctor or function with function-try-block with
+ pedwarn for c++17 and earlier. Formatting fix.
+ (cp_parser_try_block): Use pedwarn instead of error and only for
+ c++17 and earlier when try block appears in constexpr function.
+ * constexpr.c (build_constexpr_constructor_member_initializers):
+ Handle TRY_BLOCK here instead of erroring on it.
+
+2019-02-28 Jason Merrill <jason@redhat.com>
+
+ PR c++/88183 - ICE with .* fold-expression.
+ * pt.c (fold_expression) [DOTSTAR_EXPR]: Remove special handling.
+
+ PR c++/86969 - ICE with constexpr if and recursive generic lambdas.
+ * class.c, lambda.c, pt.c: Revert earlier change.
+ * lambda.c (add_capture): Don't special-case capture of dependent
+ VLA.
+
+ * name-lookup.c (print_binding_level): Print this_entity.
+
+2019-02-27 Marek Polacek <polacek@redhat.com>
+
+ PR c++/88857 - ICE with value-initialization of argument in template.
+ * call.c (convert_like_real): Don't call build_value_init in template.
+
+2019-02-27 Jason Merrill <jason@redhat.com>
+
+ PR c++/86969 - ICE with constexpr if and recursive generic lambdas.
+ * semantics.c (process_outer_var_ref): Do capture dependent vars.
+ * class.c (finish_struct): Only add TAG_DEFN if T is in
+ current_function_decl.
+ * lambda.c (vla_capture_type): Force the capture type out into the
+ lambda's enclosing function.
+ (add_capture): Pass in the lambda.
+ * pt.c (tsubst_lambda_expr): complete_type a VLA capture type.
+
+2019-02-27 Marek Polacek <polacek@redhat.com>
+
+ PR c++/89511 - ICE with using-declaration and unscoped enumerator.
+ * parser.c (cp_parser_using_declaration): For an unscoped enum
+ only use its context if it's not a function declaration.
+
+2019-02-27 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/89488
+ * method.c (process_subob_fn): When maybe_instantiate_noexcept
+ returns false don't call merge_exception_specifiers.
+
+2019-02-27 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/88987
+ * parser.c (cp_parser_noexcept_specification_opt): Return NULL_TREE
+ for a non-constant parsed expression.
+
+2019-02-26 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/89481
+ * constexpr.c (cxx_eval_store_expression): When changing active union
+ member, set no_zero_init.
+
+2019-02-23 Marek Polacek <polacek@redhat.com>
+
+ PR c++/88294 - ICE with non-constant noexcept-specifier.
+ * pt.c (maybe_instantiate_noexcept): Set up the list of local
+ specializations. Set current_class_{ptr,ref}.
+
+2019-02-22 David Malcolm <dmalcolm@redhat.com>
+
+ PR c++/89390
+ * parser.c (cp_parser_unqualified_id): Capture and use locations
+ for destructors.
+
+2019-02-22 Marek Polacek <polacek@redhat.com>
+
+ PR c++/89420 - ICE with CAST_EXPR in explicit-specifier.
+ * decl.c (build_explicit_specifier): Don't check
+ processing_template_decl. Call instantiation_dependent_expression_p
+ instead of value_dependent_expression_p. Call
+ instantiate_non_dependent_expr_sfinae before
+ build_converted_constant_expr instead of calling
+ instantiate_non_dependent_expr after it. Add
+ processing_template_decl_sentinel.
+
+2019-02-22 Thomas Schwinge <thomas@codesourcery.com>
+
+ * parser.c (cp_parser_oacc_simple_clause): Remove parser formal
+ parameter, move loc formal parameter to the front. Adjust all
+ users.
+ (cp_parser_oacc_shape_clause): Add loc formal parameter. Adjust
+ all users.
+
+2019-02-21 Jason Merrill <jason@redhat.com>
+
+ PR c++/87685 - generic lambda 'this' capture error.
+ * lambda.c (lambda_expr_this_capture): Change add_capture_p to int.
+ (maybe_generic_this_capture): Pass -1.
+
+ PR c++/88394 - ICE with VLA init-capture.
+ * lambda.c (is_normal_capture_proxy): Check DECL_CAPTURED_VARIABLE.
+
+ PR c++/88869 - C++17 ICE with CTAD and explicit specialization.
+ * pt.c (do_class_deduction): Don't include explicit specialization
+ args in outer_args.
+
+ PR c++/89422 - ICE with -g and lambda in default arg in template.
+ * pt.c (tsubst_function_decl): SET_DECL_FRIEND_CONTEXT sooner.
+
+2019-02-21 Jason Merrill <jason@redhat.com>
+
+ PR c++/88419 - C++17 ICE with class template arg deduction.
+ * pt.c (make_template_placeholder): Set TYPE_CANONICAL after
+ CLASS_PLACEHOLDER_TEMPLATE.
+
+2019-02-21 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/89285
+ * constexpr.c (struct constexpr_fundef): Add parms and result members.
+ (retrieve_constexpr_fundef): Adjust for the above change.
+ (register_constexpr_fundef): Save constexpr body with copy_fn,
+ temporarily set DECL_CONTEXT on DECL_RESULT before that.
+ (get_fundef_copy): Change FUN argument to FUNDEF with
+ constexpr_fundef * type, grab body and parms/result out of
+ constexpr_fundef struct and temporarily change it for copy_fn calls
+ too.
+ (cxx_eval_builtin_function_call): For __builtin_FUNCTION temporarily
+ adjust current_function_decl from ctx->call context. Test
+ !potential_constant_expression instead of !is_constant_expression.
+ (cxx_bind_parameters_in_call): Grab parameters from new_call. Undo
+ convert_for_arg_passing changes for TREE_ADDRESSABLE type passing.
+ (cxx_eval_call_expression): Adjust get_fundef_copy caller.
+ (cxx_eval_conditional_expression): For IF_STMT, allow then or else
+ operands to be NULL.
+ (label_matches): Handle BREAK_STMT and CONTINUE_STMT.
+ (cxx_eval_loop_expr): Add support for FOR_STMT, WHILE_STMT and DO_STMT.
+ (cxx_eval_switch_expr): Add support for SWITCH_STMT.
+ (cxx_eval_constant_expression): Handle IF_STMT, FOR_STMT, WHILE_STMT,
+ DO_STMT, CONTINUE_STMT, SWITCH_STMT, BREAK_STMT and CONTINUE_STMT.
+ For SIZEOF_EXPR, recurse on the result of fold_sizeof_expr. Ignore
+ DECL_EXPR with USING_DECL operand.
+ * lambda.c (maybe_add_lambda_conv_op): Build thisarg using
+ build_int_cst to make it a valid constant expression.
+
+2019-02-20 Jason Merrill <jason@redhat.com>
+
+ PR c++/88690 - C++17 ICE with empty base in aggregate.
+ * typeck2.c (process_init_constructor_record): Skip trivial
+ initialization of an empty base.
+
+2019-02-21 Richard Biener <rguenther@suse.de>
+
+ PR middle-end/89392
+ * vtable-class-hierarchy.c (vtv_generate_init_routine): Do not
+ make symtab process new functions here.
+
+2019-02-20 Jason Merrill <jason@redhat.com>
+
+ PR c++/87921 - wrong error with inline static data member.
+ * decl2.c (finish_static_data_member_decl): Don't set DECL_IN_AGGR_P
+ for a non-template inline variable. Do nothing for an
+ already-instantiated variable.
+ (c_parse_final_cleanups): Check DECL_IN_AGGR_P without
+ DECL_INLINE_VAR_P.
+ * decl.c (check_initializer): Likewise.
+ (make_rtl_for_nonlocal_decl): Likewise.
+ * pt.c (instantiate_decl): Likewise.
+ * typeck2.c (store_init_value): Likewise.
+
+2019-02-20 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/89403
+ * decl2.c (c_parse_final_cleanups): Move TREE_ASM_WRITTEN setting
+ for flag_syntax_only from here...
+ * semantics.c (expand_or_defer_fn_1): ... here.
+
+ PR c++/89405
+ * decl.c (maybe_commonize_var): When clearing TREE_PUBLIC and
+ DECL_COMMON, set DECL_INTERFACE_KNOWN.
+
+ PR c++/89336
+ * constexpr.c (cxx_eval_store_expression): Diagnose changing of active
+ union member for -std=c++17 and earlier.
+
+2019-02-19 Jason Merrill <jason@redhat.com>
+
+ PR c++/87513 - 'sorry' mangling PMF template-id.
+ * mangle.c (write_expression): Handle SCOPE_REF to BASELINK.
+
+2019-02-19 Jason Merrill <jason@redhat.com>
+
+ PR c++/88380 - wrong-code with flexible array and NSDMI.
+ * typeck2.c (process_init_constructor_record): Skip flexarrays.
+
+2019-02-20 will wray <wjwray@gmail.com>
+
+ PR c++/88572 - wrong handling of braces on scalar init.
+ * decl.c (reshape_init_r): Allow braces around scalar initializer
+ within aggregate init. Reject double braced-init of scalar
+ variable.
+
+2019-02-20 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/84536
+ * pt.c (tsubst_init): Diagnose an initializer expanding to an
+ empty list of expressions; tweak wrt dependent types.
+ (regenerate_decl_from_template): For VAR_DECLs call tsubst_init
+ instead of tsubst_expr.
+
+2019-02-19 Jason Merrill <jason@redhat.com>
+
+ PR c++/88368 - wrong 'use of deleted function'
+ * method.c (walk_field_subobs): Remember errors from get_nsdmi.
+ (get_defaulted_eh_spec): Call push_tinst_level.
+ * pt.c (maybe_instantiate_noexcept): Keep error_mark_node.
+ * typeck2.c (merge_exception_specifiers): Handle error_mark_node.
+
+2019-02-19 Chung-Lin Tang <cltang@codesourcery.com>
+
+ PR c/87924
+ * parser.c (cp_parser_oacc_clause_wait): Add representation of wait
+ clause without argument as 'wait (GOMP_ASYNC_NOVAL)', adjust comments.
+
+2019-02-19 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/89387
+ * lambda.c (maybe_generic_this_capture): Don't check
+ DECL_NONSTATIC_MEMBER_FUNCTION_P on USING_DECLs.
+
+ PR c++/89391
+ * typeck.c (build_reinterpret_cast_1): Don't handle void to
+ && conversion go through build_target_expr_with_type.
+
+ PR c++/89390
+ * error.c (qualified_name_lookup_error): Only call
+ suggest_alternative_in_scoped_enum if name is IDENTIFIER_NODE.
+
+2019-02-19 Tom Honermann <tom@honermann.net>
+
+ * name-lookup.c (get_std_name_hint): Added u8string as a name hint.
+
+2019-02-18 Jason Merrill <jason@redhat.com>
+
+ PR c++/89336 - multiple stores in constexpr stmt.
+ * constexpr.c (cxx_eval_store_expression): Preevaluate scalar or
+ assigned value.
+
+ * pt.c (check_explicit_specialization): If the declarator is a
+ template-id, only check whether the arguments are dependent.
+
+ Improve duplicate [[likely]] diagnostic.
+ * parser.c (cp_parser_statement): Make attrs_loc a range. Pass it
+ to process_stmt_hotness_attribute.
+ * cp-gimplify.c (process_stmt_hotness_attribute): Take attrs_loc.
+ (genericize_if_stmt): Use likely/unlikely instead of predictor_name.
+
+2019-02-17 Marek Polacek <polacek@redhat.com>
+
+ PR c++/89217 - ICE with list-initialization in range-based for loop.
+ * constexpr.c (unshare_constructor): No longer static.
+ * cp-tree.h (unshare_constructor): Declare.
+ * semantics.c (finish_compound_literal): When dealing with a
+ non-dependent expression in a template, return the original
+ expression. Pass LOOKUP_NO_NARROWING to digest_init_flags.
+
+2019-02-13 Marek Polacek <polacek@redhat.com>
+
+ PR c++/89297 - ICE with OVERLOAD in template.
+ * semantics.c (finish_compound_literal): Call
+ instantiate_non_dependent_expr_sfinae.
+
+2019-02-13 Alexandre Oliva <aoliva@redhat.com>
+
+ PR c++/86379
+ * cp-tree.h (USING_DECL_SCOPE): Use result rather than type.
+ * name-lookup.c (strip_using_decl): Use USING_DECL_SCOPE.
+ * search.c (protected_accessible_p): Follow USING_DECL_DECLS.
+ (shared_member_p): Likewise.
+ (lookup_member): Likewise.
+ * decl.c (grok_special_member_properties): Skip USING_DECLs.
+ * semantics.c (finish_omp_declare_simd_methods): Likewise.
+ (finish_qualified_id_expr): Do not call shared_member_p with
+ a dependent expr.
+
+ PR c++/87322
+ * pt.c (tsubst_lambda_expr): Avoid duplicate tsubsting.
+ Move cp_evaluated resetting before signature tsubsting.
+ (gen_elem_of_pack_expansion_instantiation): Separate local
+ specializations per index.
+
+2019-02-13 David Malcolm <dmalcolm@redhat.com>
+
+ PR c++/89036
+ * class.c (add_method): Drop destructor assertion.
+
+2019-02-13 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/88986
+ * decl.c (make_typename_type): Allow for TYPE_PACK_EXPANSION as
+ context (the first argument).
+ * pt.c (tsubst, case TYPENAME_TYPE): Handle TYPE_PACK_EXPANSION
+ as context.
+
+2019-02-12 Jason Merrill <jason@redhat.com>
+
+ PR c++/89144 - link error with constexpr initializer_list.
+ * call.c (convert_like_real) [ck_list]: Don't allocate a temporary
+ array for an empty list.
+ * typeck2.c (store_init_value): Don't use cxx_constant_init in a
+ template.
+
+2019-02-11 Jason Merrill <jason@redhat.com>
+
+ PR c++/89241 - ICE with __func__ in lambda in template.
+ * pt.c (enclosing_instantiation_of): Also check
+ instantiated_lambda_fn_p for the template context.
+
+2019-02-11 Marek Polacek <polacek@redhat.com>
+
+ PR c++/89212 - ICE converting nullptr to pointer-to-member-function.
+ * pt.c (tsubst_copy_and_build) <case CONSTRUCTOR>: Return early for
+ null member pointer value.
+
+2019-02-11 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/88977
+ * pt.c (convert_nontype_argument): Pass true as manifestly_const_eval
+ to maybe_constant_value calls.
+
+2019-02-11 Marek Polacek <polacek@redhat.com>
+
+ * typeck2.c (digest_init_r): Remove commented code.
+
+2019-02-11 Martin Sebor <msebor@redhat.com>
+
+ PR c++/87996
+ * decl.c (compute_array_index_type_loc): Preserve signed sizes
+ for diagnostics. Call valid_array_size_p instead of error.
+ * init.c (build_new_1): Compute size for diagnostic. Call
+ invalid_array_size_error
+ (build_new): Call valid_array_size_p instead of error.
+
+2019-02-07 Alexandre Oliva <aoliva@redhat.com>
+
+ PR c++/86218
+ * call.c (compare_ics): Deal with ck_aggr in either cs.
+
+2019-02-06 David Malcolm <dmalcolm@redhat.com>
+
+ PR c++/71302
+ * call.c (get_location_for_expr_unwinding_for_system_header): New
+ function.
+ (conversion_null_warnings): Use it when getting locations for
+ EXPR, effectively adding a call to
+ get_location_for_expr_unwinding_for_system_header for
+ -Wconversion-null and making use of EXPR_LOCATION for
+ -Wzero-as-null-pointer-constant.
+
+2019-02-05 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/89187
+ * optimize.c (maybe_thunk_body): Clear TREE_ADDRESSABLE on
+ PARM_DECLs of the thunk.
+ * lambda.c (maybe_add_lambda_conv_op): Likewise.
+
+2019-02-05 Marek Polacek <polacek@redhat.com>
+
+ PR c++/89158 - by-value capture of constexpr variable broken.
+ * call.c (convert_like_real) <case ck_user>: Call mark_exp_read
+ instead of mark_rvalue_use.
+
+2019-02-05 Alexandre Oliva <aoliva@redhat.com>
+
+ PR c++/87770
+ * pt.c (instantiates_primary_template_p): New.
+ (type_dependent_expression_p): Use it.
+
+2019-02-01 Jason Merrill <jason@redhat.com>
+
+ PR c++/88761 - ICE with reference capture of constant.
+ * lambda.c (mark_const_cap_r): Do walk subtrees of DECL_EXPR for
+ non-proxy decls.
+
+2019-02-01 Marek Polacek <polacek@redhat.com>
+
+ PR c++/88325 - ICE with invalid out-of-line template member definition.
+ * parser.c (cp_parser_class_name): Don't call make_typename_type
+ for overloads.
+
+2019-02-01 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/87175
+ * parser.c (cp_parser_gnu_attributes_opt): Set ok to false
+ if require_open failed.
+
+2019-01-31 Marek Polacek <polacek@redhat.com>
+
+ PR c++/89083, c++/80864 - ICE with list initialization in template.
+ * constexpr.c (adjust_temp_type): Use copy_node and change the type
+ instead of using build_constructor.
+ * decl.c (reshape_init_r): Don't reshape a digested initializer.
+ Return the initializer for COMPOUND_LITERAL_P.
+
+ PR c++/88983 - ICE with switch in constexpr function.
+ * constexpr.c (cxx_eval_switch_expr): Use SWITCH_COND and SWITCH_BODY.
+ (cxx_eval_constant_expression) <case COND_EXPR>: Don't look for the
+ label in the else branch if we found it in the then branch.
+
+2019-01-30 Jason Merrill <jason@redhat.com>
+
+ PR c++/88752 - ICE with lambda and constexpr if.
+ * cp-tree.h (LAMBDA_EXPR_INSTANTIATED): New.
+ * pt.c (tsubst_lambda_expr): Set it.
+ (instantiated_lambda_fn_p): Check it.
+ (enclosing_instantiation_of): Use it.
+
+2019-01-31 Jakub Jelinek <jakub@redhat.com>
+
+ PR libstdc++/88170
+ * cxx-pretty-print.c (pp_cxx_enumeration_constant): Print always as
+ a C cast in pp_c_flag_gnu_v3 mode.
+
+2019-01-30 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/88988
+ * lambda.c (is_capture_proxy): Don't return true for
+ DECL_OMP_PRIVATIZED_MEMBER artificial vars.
+
+2019-01-30 Marek Polacek <polacek@redhat.com>
+
+ PR c++/89119 - ICE with value-initialization in template.
+ * pt.c (tsubst_copy_and_build): Handle RANGE_EXPR.
+
+2019-01-29 Jason Merrill <jason@redhat.com>
+
+ PR c++/86943 - wrong code converting lambda to function pointer.
+ * lambda.c (maybe_add_lambda_conv_op): Use a template-id in the
+ call. Only forward parms for decltype.
+ * pt.c (tsubst_copy_and_build) [CALL_EXPR]: Handle CALL_FROM_THUNK_P
+ specially.
+ * typeck.c (check_return_expr): Don't mess with a thunk call.
+
+2019-01-28 Jason Merrill <jason@redhat.com>
+
+ PR c++/89089 - ICE with [[no_unique_address]].
+ PR c++/88865 - wrong layout with [[no_unique_address]].
+ * class.c (check_field_decls): A potentially-overlapping field makes
+ the class non-layout-POD, but not non-empty.
+ (end_of_class): Always consider empty data members.
+ (layout_class_type): Set DECL_SIZE for empty fields.
+
+2019-01-28 Marek Polacek <polacek@redhat.com>
+
+ PR c++/88358 - name wrongly treated as type.
+ * parser.c (cp_parser_direct_declarator): Don't assume a qualified-id
+ in parameter-list is a type if the function's declarator-id is not
+ qualified.
+
+2019-01-27 Marek Polacek <polacek@redhat.com>
+
+ PR c++/88815 - narrowing conversion lost in decltype.
+ PR c++/78244 - narrowing conversion in template not detected.
+ * cp-tree.h (CONSTRUCTOR_IS_DEPENDENT): New.
+ * pt.c (instantiation_dependent_r): Consider a CONSTRUCTOR with
+ CONSTRUCTOR_IS_DEPENDENT instantiation-dependent.
+ * semantics.c (finish_compound_literal): When the compound literal
+ isn't instantiation-dependent and the type isn't type-dependent,
+ fall back to the normal processing. Set CONSTRUCTOR_IS_DEPENDENT.
+
+ PR c++/89024 - ICE with incomplete enum type.
+ * call.c (standard_conversion): When converting an
+ ARITHMETIC_TYPE_P to an incomplete type, return NULL.
+
+2019-01-25 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/88969
+ * call.c (build_op_delete_call): Implement 7.6.2.5/(10.1).
+ * decl2.c (coerce_delete_type): Use build_pointer_type instead
+ of TYPE_POINTER_TO.
+
+2019-01-24 Jason Merrill <jason@redhat.com>
+
+ PR c++/89001 - mangling of reference temporaries
+ * cp-tree.h (struct saved_scope): Add ref_temp_count.
+ (current_ref_temp_count): New macro.
+ * mangle.c (mangle_ref_init_variable): Use it.
+ * typeck2.c (store_init_value): Clear it.
+ * call.c (make_temporary_var_for_ref_to_temp): Copy public and
+ comdat.
+
+2019-01-24 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/88976
+ * semantics.c (finish_omp_cancel): Diagnose more than one if
+ on #pragma omp cancel with different modifiers. Use
+ maybe_convert_cond when not in template or build_x_binary_op
+ otherwise.
+
+2019-01-23 Marek Polacek <polacek@redhat.com>
+
+ PR c++/88757 - qualified name treated wrongly as type.
+ * parser.c (cp_parser_direct_declarator): Don't treat qualified-ids
+ in parameter-list as types if name lookup for declarator-id didn't
+ find one or more function templates.
+
+2019-01-23 Jakub Jelinek <jakub@redhat.com>
+
+ PR c/44715
+ * cp-gimplify.c (genericize_cp_loop): Call begin_bc_block only
+ after genericizing cond and incr expressions.
+
+ PR c++/88984
+ * cp-gimplify.c (genericize_switch_stmt): Move cond genericization
+ before the begin_bc_block call.
+
+2019-01-21 Jason Merrill <jason@redhat.com>
+
+ PR c++/87893 - constexpr ctor ICE on ARM.
+ PR c++/88293 - ICE with comma expression.
+ * constexpr.c (initialized_type): Don't shortcut non-void type.
+ Handle COMPOUND_EXPR.
+ (cxx_eval_outermost_constant_expr): Return early for void type.
+
+2019-01-21 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/88949
+ * optimize.c (cxx_copy_decl): New function.
+ (clone_body): Use it instead of copy_decl_no_change.
+
+ PR sanitizer/88901
+ * typeck.c (cp_build_binary_op): Don't instrument
+ SANITIZE_POINTER_COMPARE if processing_template_decl.
+ (pointer_diff): Similarly for SANITIZE_POINTER_SUBTRACT.
+
+2019-01-18 Jason Merrill <jason@redhat.com>
+
+ PR c++/88875 - error with explicit list constructor.
+ * call.c (reference_binding): Don't modify EXPR. Set
+ need_temporary_p on the ck_user conversion for a temporary.
+ (convert_like_real): Check it.
+
+2019-01-18 H.J. Lu <hongjiu.lu@intel.com>
+
+ PR c/51628
+ PR c/88664
+ * call.c (convert_for_arg_passing): Upate the
+ warn_for_address_or_pointer_of_packed_member call.
+ * typeck.c (convert_for_assignment): Likewise.
+
+2019-01-17 Jason Merrill <jason@redhat.com>
+
+ PR c++/86205 - ICE with ?: of throw and template-id.
+ * pt.c (resolve_nondeduced_context_or_error): Split out from...
+ * typeck.c (decay_conversion): ...here.
+ * call.c (build_conditional_expr_1): Use it.
+
+ PR c++/86740, ICE with constexpr if and nested generic lambdas.
+ * tree.c (cp_walk_subtrees): Handle LAMBDA_EXPR.
+
+2019-01-17 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (grokdeclarator): Use typespec_loc in error messages
+ about 'auto' and trailing return type.
+
+2019-01-17 David Malcolm <dmalcolm@redhat.com>
+
+ PR c++/88699
+ * class.c (add_method): Don't use DECL_DESTRUCTOR_P on
+ USING_DECLs.
+
+2019-01-17 Nathan Sidwell <nathan@acm.org>
+
+ PR c++/86610
+ * semantics.c (process_outer_var_ref): Only skip dependent types
+ in templates.
+
+2019-01-17 Alexandre Oliva <aoliva@redhat.com>
+
+ PR c++/87768
+ * cp-tree.h (saved_scope): Add suppress_location_wrappers.
+ * name-lookup.c (do_push_to_top_level): Save and reset it.
+ (do_pop_from_top_level): Restore it.
+
+ PR c++/86648
+ * pt.c (make_template_placeholder): Use auto_identifier.
+ (is_auto): Drop CLASS_PLACEHOLDER_TEMPLATE test.
+ * error.c (dump_type): Handle template placeholders.
+ * cxx-pretty-print.c (pp_cx_unqualified_id): Likewise.
+
+ PR c++/88146
+ * cvt.c (convert_to_void): Handle all cdtor calls as if
+ returning void.
+
+2019-01-16 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (grokdeclarator): Use locations[ds_storage_class] in
+ error messages about ill-formed uses of mutable.
+
+2019-01-16 Marek Polacek <polacek@redhat.com>
+
+ PR c++/78244 - narrowing conversion in template not detected.
+ * call.c (perform_implicit_conversion_flags): Set
+ IMPLICIT_CONV_EXPR_BRACED_INIT.
+ * cp-tree.h (IMPLICIT_CONV_EXPR_BRACED_INIT): New.
+ * pt.c (tsubst_copy_and_build): Use it.
+
+2019-01-15 David Malcolm <dmalcolm@redhat.com>
+
+ PR c++/88795
+ * pt.c (build_deduction_guide): Bail out if tsubst_arg_types
+ fails.
+
+2019-01-15 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (start_decl): Improve error location.
+ * decl2.c (grokfield): Likewise.
+
+2019-01-15 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (grokdeclarator): Move further up the location_t loc
+ declaration and use the location when building a TYPE_DECL for
+ a typedef name.
+ * decl2.c (grokbitfield): Use DECL_SOURCE_LOCATION in the error
+ about an ill-formed bit-field as typedef.
+
+2019-01-14 Marek Polacek <polacek@redhat.com>
+
+ PR c++/88830 - ICE with abstract class.
+ * decl2.c (maybe_emit_vtables): Check CLASSTYPE_LAZY_DESTRUCTOR.
+ Fix formatting.
+
+ PR c++/88825 - ICE with bogus function return type deduction.
+ * typeck.c (can_do_nrvo_p): Check error_mark_node.
+
+2019-01-14 Tom Honermann <tom@honermann.net>
+
+ Implement P0482R5, char8_t: A type for UTF-8 characters and strings
+ * cvt.c (type_promotes_to): Handle char8_t promotion.
+ * decl.c (grokdeclarator): Handle invalid type specifier
+ combinations involving char8_t.
+ * lex.c (init_reswords): Add char8_t as a reserved word.
+ * mangle.c (write_builtin_type): Add name mangling for char8_t (Du).
+ * parser.c (cp_keyword_starts_decl_specifier_p)
+ (cp_parser_simple_type_specifier): Recognize char8_t as a simple
+ type specifier.
+ (cp_parser_string_literal): Use char8_array_type_node for the type
+ of CPP_UTF8STRING.
+ (cp_parser_set_decl_spec_type): Tolerate char8_t typedefs in system
+ headers.
+ * rtti.c (emit_support_tinfos): type_info support for char8_t.
+ * tree.c (char_type_p): Recognize char8_t as a character type.
+ * typeck.c (string_conv_p): Handle conversions of u8 string
+ literals of char8_t type.
+ (check_literal_operator_args): Handle UDLs with u8 string literals
+ of char8_t type.
+ * typeck2.c (ordinary_char_type_p): New.
+ (digest_init_r): Disallow initializing a char array with a u8 string
+ literal.
+
+2019-01-14 Martin Liska <mliska@suse.cz>
+
+ PR gcov-profile/88263
+ * decl2.c (get_tls_wrapper_fn): Use DECL_SOURCE_LOCATION
+ as location of the TLS wrapper.
+
+2019-01-12 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (cp_finish_decl): Improve error location.
+ * decl2.c (grokfield): Likewise, improve two locations.
+
+2019-01-11 Marek Polacek <polacek@redhat.com>
+
+ PR c++/88692, c++/87882 - -Wredundant-move false positive with *this.
+ * typeck.c (maybe_warn_pessimizing_move): Return if ARG isn't
+ ADDR_EXPR.
+
+2019-01-11 Jason Merrill <jason@redhat.com>
+
+ PR c++/88312 - pack expansion of decltype.
+ * pt.c (instantiation_dependent_r): A template non-type parameter
+ pack is instantiation-dependent.
+
+2019-01-11 Jason Merrill <jason@redhat.com>
+
+ PR c++/88613 - ICE with use of const var in lambda.
+ * expr.c (mark_use): Fix location wrapper handling.
+ * cp-gimplify.c (cp_fold_maybe_rvalue): Call mark_rvalue_use.
+
+2019-01-11 Tobias Burnus <burnus@net-b.de>
+
+ PR C++/88114
+ * decl2.c (maybe_emit_vtables): If needed, generate code for
+ the destructor of an abstract class.
+ (mark_used): Update comment for older function-name change.
+
+2019-01-11 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (start_decl): Improve error location.
+ (grokdeclarator): Likewise, improve two locations.
+
+2019-01-09 Sandra Loosemore <sandra@codesourcery.com>
+
+ PR other/16615
+
+ * cp-tree.h: Mechanically replace "can not" with "cannot".
+ * parser.c: Likewise.
+ * pt.c: Likewise.
+
+2019-01-08 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (grok_reference_init): Improve error location.
+ (grokdeclarator): Likewise, improve two locations.
+
+2019-01-08 Marek Polacek <polacek@redhat.com>
+
+ PR c++/88538 - braced-init-list in template-argument-list.
+ * parser.c (cp_parser_template_argument): Handle braced-init-list when
+ in C++20.
+
+ PR c++/88548 - this accepted in static member functions.
+ * parser.c (cp_debug_parser): Adjust printing of
+ local_variables_forbidden_p.
+ (cp_parser_new): Set local_variables_forbidden_p to 0 rather than false.
+ (cp_parser_primary_expression): When checking
+ local_variables_forbidden_p, use THIS_FORBIDDEN or
+ LOCAL_VARS_FORBIDDEN.
+ (cp_parser_lambda_body): Update the type of
+ local_variables_forbidden_p. Set it to 0 rather than false.
+ (cp_parser_condition): Adjust call to cp_parser_declarator.
+ (cp_parser_explicit_instantiation): Likewise.
+ (cp_parser_init_declarator): Likewise.
+ (cp_parser_declarator): New parameter. Use it.
+ (cp_parser_direct_declarator): New parameter. Use it to set
+ local_variables_forbidden_p. Adjust call to cp_parser_declarator.
+ (cp_parser_type_id_1): Adjust call to cp_parser_declarator.
+ (cp_parser_parameter_declaration): Likewise.
+ (cp_parser_default_argument): Update the type of
+ local_variables_forbidden_p. Set it to LOCAL_VARS_AND_THIS_FORBIDDEN
+ rather than true.
+ (cp_parser_member_declaration): Tell cp_parser_declarator if we saw
+ 'static' or 'friend'.
+ (cp_parser_exception_declaration): Adjust call to cp_parser_declarator.
+ (cp_parser_late_parsing_default_args): Update the type of
+ local_variables_forbidden_p. Set it to LOCAL_VARS_AND_THIS_FORBIDDEN
+ rather than true.
+ (cp_parser_cache_defarg): Adjust call to cp_parser_declarator.
+ (cp_parser_objc_class_ivars): Likewise.
+ (cp_parser_objc_struct_declaration): Likewise.
+ (cp_parser_omp_for_loop_init): Likewise.
+ * parser.h (cp_parser): Change the type of local_variables_forbidden_p
+ to unsigned char.
+ (LOCAL_VARS_FORBIDDEN, LOCAL_VARS_AND_THIS_FORBIDDEN, THIS_FORBIDDEN):
+ Define.
+
+2019-01-08 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (start_decl): Improve permerror location.
+
+2019-01-08 Jonathan Wakely <jwakely@redhat.com>
+ Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/88554
+ * decl.c (finish_function): For -Wreturn-type don't add a return *this;
+ fixit hint if current_class_ref is NULL. Use a single if instead of
+ two nested ones.
+
+2019-01-07 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (start_decl): Improve two error_at locations.
+ (expand_static_init): Likewise.
+
+2019-01-07 Marek Polacek <polacek@redhat.com>
+
+ PR c++/88741 - wrong error with initializer-string.
+ * decl.c (cp_complete_array_type): Strip any location wrappers.
+
+2019-01-07 Bernd Edlinger <bernd.edlinger@hotmail.de>
+
+ PR c++/88261
+ PR c++/69338
+ PR c++/69696
+ PR c++/69697
+ * cp-tree.h (LOOKUP_ALLOW_FLEXARRAY_INIT): New flag value.
+ * typeck2.c (digest_init_r): Raise an error for non-static
+ initialization of a flexible array member.
+ (process_init_constructor, massage_init_elt,
+ process_init_constructor_array, process_init_constructor_record,
+ process_init_constructor_union, process_init_constructor): Add the
+ flags parameter and pass it thru.
+ (store_init_value): Pass LOOKUP_ALLOW_FLEXARRAY_INIT parameter to
+ digest_init_flags for static decls.
+
+2019-01-07 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/85052
+ * cp-tree.h (cp_build_vec_convert): Declare.
+ * parser.c (cp_parser_postfix_expression): Parse
+ __builtin_convertvector.
+ * constexpr.c: Include fold-const-call.h.
+ (cxx_eval_internal_function): Handle IFN_VEC_CONVERT.
+ (potential_constant_expression_1): Likewise.
+ * semantics.c (cp_build_vec_convert): New function.
+ * pt.c (tsubst_copy_and_build): Handle CALL_EXPR to
+ IFN_VEC_CONVERT.
+
+2019-01-03 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/88636
+ * decl.c (builtin_function_1): Return result of pushdecl_top_level
+ or pushdecl rather than decl.
+
+2019-01-03 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * tree.c (handle_nodiscard_attribute): Improve warning location.
+
+2019-01-02 Marek Polacek <polacek@redhat.com>
+
+ PR c++/88612 - ICE with -Waddress-of-packed-member.
+ * call.c (convert_for_arg_passing): Only give warnings with tf_warning.
+ * typeck.c (convert_for_assignment): Likewise.
+
+ PR c++/88631 - CTAD failing for value-initialization.
+ * typeck2.c (build_functional_cast): Try deducing the template
+ arguments even if there are no arguments to deduce from.
+
+2019-01-01 Jakub Jelinek <jakub@redhat.com>
+
+ Update copyright years.
+
+Copyright (C) 2019-2020 Free Software Foundation, Inc.
+
+Copying and distribution of this file, with or without modification,
+are permitted in any medium without royalty provided the copyright
+notice and this notice are preserved.