summaryrefslogtreecommitdiff
path: root/gcc/cp
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/cp')
-rw-r--r--gcc/cp/ChangeLog4041
-rw-r--r--gcc/cp/ChangeLog-20144041
-rw-r--r--gcc/cp/Make-lang.in2
-rw-r--r--gcc/cp/NEWS2
-rw-r--r--gcc/cp/call.c2
-rw-r--r--gcc/cp/cfns.gperf2
-rw-r--r--gcc/cp/cfns.h2
-rw-r--r--gcc/cp/class.c2
-rw-r--r--gcc/cp/config-lang.in2
-rw-r--r--gcc/cp/constexpr.c2
-rw-r--r--gcc/cp/cp-array-notation.c2
-rw-r--r--gcc/cp/cp-cilkplus.c2
-rw-r--r--gcc/cp/cp-gimplify.c2
-rw-r--r--gcc/cp/cp-lang.c2
-rw-r--r--gcc/cp/cp-objcp-common.c2
-rw-r--r--gcc/cp/cp-objcp-common.h2
-rw-r--r--gcc/cp/cp-tree.def2
-rw-r--r--gcc/cp/cp-tree.h2
-rw-r--r--gcc/cp/cvt.c2
-rw-r--r--gcc/cp/cxx-pretty-print.c2
-rw-r--r--gcc/cp/cxx-pretty-print.h2
-rw-r--r--gcc/cp/decl.c2
-rw-r--r--gcc/cp/decl.h2
-rw-r--r--gcc/cp/decl2.c2
-rw-r--r--gcc/cp/dump.c2
-rw-r--r--gcc/cp/error.c2
-rw-r--r--gcc/cp/except.c2
-rw-r--r--gcc/cp/expr.c2
-rw-r--r--gcc/cp/friend.c2
-rw-r--r--gcc/cp/g++spec.c2
-rw-r--r--gcc/cp/init.c2
-rw-r--r--gcc/cp/lambda.c2
-rw-r--r--gcc/cp/lang-specs.h2
-rw-r--r--gcc/cp/lex.c2
-rw-r--r--gcc/cp/mangle.c2
-rw-r--r--gcc/cp/method.c2
-rw-r--r--gcc/cp/name-lookup.c2
-rw-r--r--gcc/cp/name-lookup.h2
-rw-r--r--gcc/cp/operators.def2
-rw-r--r--gcc/cp/optimize.c2
-rw-r--r--gcc/cp/parser.c2
-rw-r--r--gcc/cp/parser.h2
-rw-r--r--gcc/cp/pt.c2
-rw-r--r--gcc/cp/ptree.c2
-rw-r--r--gcc/cp/repo.c2
-rw-r--r--gcc/cp/rtti.c2
-rw-r--r--gcc/cp/search.c2
-rw-r--r--gcc/cp/semantics.c2
-rw-r--r--gcc/cp/tree.c2
-rw-r--r--gcc/cp/type-utils.h2
-rw-r--r--gcc/cp/typeck.c2
-rw-r--r--gcc/cp/typeck2.c2
-rw-r--r--gcc/cp/vtable-class-hierarchy.c2
53 files changed, 4097 insertions, 4087 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index de34ef92cf6..f7891db65f7 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,4046 +1,15 @@
+2015-01-05 Jakub Jelinek <jakub@redhat.com>
+
+ Update copyright years.
+
2015-01-05 Marek Polacek <polacek@redhat.com>
PR c/64423
* typeck.c (cp_build_array_ref): Pass loc down to
warn_array_subscript_with_type_char.
-2014-12-31 Iain Sandoe <iain@codesourcery.com>
-
- * parser.c (cp_parser_primary_expression): If parsing an
- objective-c++ message expression fails, see if a lambda is present.
- (cp_parser_objc_message_receiver): Don't assume that, if a message
- receiver expression fails, it is a hard error.
-
-2014-12-25 Jason Merrill <jason@redhat.com>
-
- * pt.c (check_default_tmpl_args): Uses the parameter source
- location in the diagnostic.
- (convert_template_argument): Just return if parm is error_mark_node.
-
- PR c++/63522
- * parser.c (cp_parser_type_parameter): Call
- check_for_bare_parameter_packs on default argument.
-
-2014-12-24 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/63985
- * parser.c (cp_parser_init_declarator): Add location_t* parameter.
- (cp_parser_simple_declaration): Provide proper diagnostic for
- multiple declarations and initializers in range-based for loops.
- (cp_parser_single_declaration): Adjust call.
-
-2014-12-20 Jason Merrill <jason@redhat.com>
-
- PR c++/64359
- * pt.c (iterative_hash_template_arg): Hash alias specializations
- differently from their TYPE_CANONICAL.
- (alias_template_specialization_p): Optimize.
- (template_args_equal): Optimize alias handling.
- (dependent_alias_template_spec_p): Only check innermost args.
-
-2014-12-19 Kai Tietz <ktietz@redhat.com>
-
- PR c++/61198
- * pt.c (most_general_template): Don't break for template-alias.
-
-2014-12-18 Jason Merrill <jason@redhat.com>
-
- PR c++/64105
- * parser.c (cp_parser_simple_type_specifier): Make auto parameter
- before -std=c++14 an error.
-
- PR c++/64352
- * pt.c (tsubst_copy_and_build): Pass complain to mark_used.
-
- PR c++/64251
- * decl2.c (mark_used): Don't mark if in_template_function.
-
-2014-12-18 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/60955
- * pt.c (struct warning_sentinel): Move it...
- * cp-tree.h: ... here.
- * semantics.c (force_paren_expr): Use it.
-
-2014-12-17 Jason Merrill <jason@redhat.com>
-
- PR c++/64333
- * constexpr.c (cxx_bind_parameters_in_call): non_constant_args parm.
- (cxx_eval_call_expression): Don't cache calls with non-constant args.
- (cxx_eval_constant_expression) [COMPOUND_EXPR]: Pass true for lval.
- (cxx_eval_unary_expression, cxx_eval_binary_expression)
- (cxx_eval_conditional_expression): Pass false for lval.
-
- * constexpr.c: Change "addr" parm names to "lval".
-
- * constexpr.c: Tweak comments and formatting.
-
-2014-12-16 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/58650
- * parser.c (cp_parser_member_declaration): Fix error recovery for
- initialized non-static data member declared friend.
-
-2014-12-15 Jan Hubicka <hubicka@ucw.cz>
-
- * decl2.c (decl_needed_p): When not optimizing, do not consider external
- decls as needed.
-
-2014-12-15 Jason Merrill <jason@redhat.com>
-
- PR c++/64297
- * typeck.c (apply_memfn_quals): Correct wrong TYPE_CANONICAL.
-
- N3778: Sized Deallocation
- * call.c (non_placement_deallocation_fn_p): A global sized
- operator delete is not a usual deallocation function until C++14.
- (build_op_delete_call): Choose the global sized op delete if we
- know the size.
- * cp-tree.h: Declare non_placement_deallocation_fn_p.
- (enum cp_tree_index): Remove CPTI_GLOBAL_DELETE_FNDECL.
- (global_delete_fndecl): Remove.
- * decl.c (cxx_init_decl_processing): Also declare sized op deletes.
- (grok_op_properties): Warn about sized dealloc without the flag.
- * init.c (build_builtin_delete_call): Remove.
- (build_vec_delete_1, build_delete): Don't call it.
- * decl2.c (maybe_warn_sized_delete): New.
- (cp_write_global_declarations): Call it.
-
-2014-12-15 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/58882
- * decl.c (check_array_designated_initializer): Diagnose gracefully
- C99 designators which aren't integral constant-expressions; allow
- constexpr user-defined type conversion operators.
-
-2014-12-12 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/59628
- * semantics.c (finish_omp_reduction_clause): Early return true
- if DECL_SAVED_TREE (id) is NULL_TREE.
-
-2014-12-12 Jason Merrill <jason@redhat.com>
-
- N3922
- * pt.c (do_auto_deduction): In direct-init context, { x } deduces
- from x.
-
- * cp-tree.h (NAMESPACE_ABI_TAG): New.
- * name-lookup.c (handle_namespace_attrs): Set it.
- * class.c (check_tag): Split out from find_abi_tags_r.
- (find_abi_tags_r): Also check namespace tags.
- (mark_type_abi_tags): Also mark namespace tags.
-
-2014-12-12 Kai Tietz <ktietz@redhat.com>
-
- PR c++/63996
- * constexpr.c (cxx_eval_loop_expr): Don't loop
- endless on none-constant expression.
-
-2014-12-12 Jason Merrill <jason@redhat.com>
-
- PR c++/61402
- * lambda.c (add_capture): Don't pass a dependent type to
- variably_modified_type_p.
-
-2014-12-11 Jason Merrill <jason@redhat.com>
-
- Remove N3639 "array of runtime length" from -std=c++14.
- * decl.c (compute_array_index_type): VLAs are not part of C++14.
- (create_array_type_for_decl, grokdeclarator): Likewise.
- * lambda.c (add_capture): Likewise.
- * pt.c (tsubst): Likewise.
- * rtti.c (get_tinfo_decl): Likewise.
- * semantics.c (finish_decltype_type): Likewise.
- * typeck.c (cxx_sizeof_or_alignof_type): Likewise.
- (cp_build_addr_expr_1): Likewise.
- * init.c (build_vec_init): Don't throw bad_array_length.
-
- PR c++/64248
- Revert:
- * parser.c (cp_parser_unqualified_id): Handle __func__ here.
- (cp_parser_primary_expression): Not here.
-
- PR c++/57510
- * typeck2.c (split_nonconstant_init_1): Handle arrays here.
- (store_init_value): Not here.
- (split_nonconstant_init): Look through TARGET_EXPR. No longer static.
- * cp-tree.h: Declare split_nonconstant_init.
- * call.c (set_up_extended_ref_temp): Use split_nonconstant_init.
-
-2014-12-11 Paolo Carlini <paolo.carlini@oracle.com>
-
- * typeck.c (maybe_warn_about_useless_cast): Remove unnecessary
- conditional.
-
-2014-12-10 Kai Tietz <ktietz@redhat.com>
-
- PR c++/64127
- * parser.c (cp_parser_diagnose_invalid_type_name): Check id
- for being an identifier before accessing it.
-
- PR c++/64100
- * typeck.c (lookup_destructor): Handle incomplete type.
-
-2014-12-09 Jason Merrill <jason@redhat.com>
-
- PR c++/64129
- * decl.c (grokdeclarator): Recover from variable template
- specialization declared as function.
-
- PR c++/64222
- * parser.c (cp_parser_unqualified_id): Don't declare fname while
- parsing function parms.
-
-2014-12-03 Jason Merrill <jason@redhat.com>
-
- PR c++/64029
- * decl.c (grok_reference_init): Complete array type.
-
- PR c++/64080
- * constexpr.c (cxx_eval_store_expression): Handle non-decl store
- targets.
-
-2014-12-03 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/63558
- * decl.c (identify_goto): Return a bool if diagnostic is emitted.
- (check_previous_goto_1): Consistently emit permerror + inform.
- (check_goto): Likewise.
-
-2014-12-03 Richard Biener <rguenther@suse.de>
-
- * constexpr.c (cxx_eval_builtin_function_call): Use
- fold_build_call_array_loc.
-
-2014-12-02 Marek Polacek <polacek@redhat.com>
-
- * constexpr.c (cxx_eval_check_shift_p): New function.
- (cxx_eval_binary_expression): Call it. Set NON_CONSTANT_P if it
- returns true.
-
-2014-12-01 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/60859
- * decl.c (reshape_init_r): Do not reject value-initialization of
- scalar array element.
-
-2014-12-01 Marek Polacek <polacek@redhat.com>
-
- PR sanitizer/63956
- * constexpr.c: Include ubsan.h.
- (cxx_eval_call_expression): Bail out for IFN_UBSAN_{NULL,BOUNDS}
- internal functions and for ubsan builtins.
- * error.c: Include internal-fn.h.
- (dump_expr): Add printing of internal functions.
-
-2014-12-01 Marek Polacek <polacek@redhat.com>
-
- * constexpr.c (literal_type_p): Return true for void type in C++14.
-
-2014-12-01 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/60845
- * typeck.c (finish_class_member_access_expr): Use %q#T instead of
- %qD in error message.
-
-2014-11-29 Jakub Jelinek <jakub@redhat.com>
-
- * cp-gimplify.c (cxx_omp_clause_apply_fn): Remove NULL last argument
- from create_tmp_var calls.
-
-2014-11-28 Marek Polacek <polacek@redhat.com>
-
- PR c/63862
- * typeck.c (cp_build_binary_op) <RSHIFT_EXPR, LSHIFT_EXPR>: Don't
- convert the right operand to integer type.
-
-2014-11-27 Kai Tietz <ktietz@redhat.com>
-
- PR c++/63904
- * constexpr.c (cxx_eval_vec_init_1): Avoid
- type-overflow issue.
-
-2014-11-26 Jason Merrill <jason@redhat.com>
-
- Allow partial specialization of variable templates.
- * cp-tree.h (TINFO_USED_TEMPLATE_ID): New.
- * decl.c (duplicate_decls): Copy it.
- * error.c (dump_decl) [TEMPLATE_ID_EXPR]: Handle variables.
- * parser.c (cp_parser_decltype_expr): Do call finish_id_expression
- on template-ids.
- * pt.c (register_specialization): Remember variable template insts.
- (instantiate_template_1): Find the matching partial specialization.
- (check_explicit_specialization): Allow variable partial specialization.
- (process_partial_specialization): Likewise.
- (push_template_decl_real): Likewise.
- (more_specialized_partial_spec): Rename from more_specialized_class.
- (most_specialized_partial_spec): Rename from most_specialized_class.
- (get_partial_spec_bindings): Rename from get_class_bindings.
-
-2014-11-26 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/63757
- * call.c (standard_conversion): Do not require expr to be non-null
- when NULLPTR_TYPE_P (from) is true.
-
-2014-11-26 Jason Merrill <jason@redhat.com>
-
- * constexpr.c (cxx_eval_constant_expression) [SAVE_EXPR]: Avoid
- multiple evaluation.
-
- * constexpr.c (cxx_eval_call_expression): Don't talk about
- flowing off the end if we're already non-constant.
-
-2014-11-26 Ville Voutilainen <ville.voutilainen@gmail.com>
-
- Diagnose string constant conversion to char* in c++11 and above
- as forbidden, not deprecated.
- * typeck.c (string_conv_p): Do a pedwarn in c++11 and above,
- change the diagnostic for the Wwrite-strings case for c++11 and above.
-
-2014-11-24 Jason Merrill <jason@redhat.com>
-
- * pt.c (lookup_template_variable): Always unknown_type_node.
-
-2014-11-25 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/63786
- * parser.c (cp_parser_label_for_labeled_statement): Check the case
- with check_for_bare_parameter_packs.
-
-2014-11-24 Jonathan Wakely <jwakely@redhat.com>
- Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/63203
- * decl.c (initialize_local_var): Add -Winit-self warning for
- references initialized with themselves.
-
-2014-11-24 Jason Merrill <jason@redhat.com>
-
- PR c++/63942
- * mangle.c (mangle_decl): If we aren't going to create a symbol
- alias, don't build the alias DECL either.
-
-2014-11-24 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/63905
- * cp-tree.h (lang_decl_fn): Remove constructor_attr, destructor_attr.
-
-2014-11-21 Jason Merrill <jason@redhat.com>
-
- PR c++/63657
- PR c++/38958
- * call.c (set_up_extended_ref_temp): Set TREE_USED on the reference
- if the temporary has a non-trivial destructor.
- * decl.c (poplevel): Don't look through references.
-
- PR c++/63942
- * name-lookup.c (supplement_binding_1): Override a mangling alias.
- * mangle.c (maybe_remove_implicit_alias): New.
- (mangle_decl): Always avoid creating conflicting alias.
- * cp-tree.h: Adjust.
-
- PR c++/63849
- * mangle.c (decl_mangling_context): Use template_type_parameter_p.
-
- PR c++/63588
- * pt.c (uses_template_parms): Handle null argument.
-
-2014-11-21 Jakub Jelinek <jakub@redhat.com>
-
- PR target/63764
- * typeck.c (cp_build_array_ref): Adjust
- convert_vector_to_pointer_for_subscript caller. If it returns true,
- call non_lvalue_loc on the result.
-
-2014-11-20 Jason Merrill <jason@redhat.com>
-
- PR c++/63658
- * pt.c (convert_nontype_argument): Call convert_from_reference.
- (check_instantiated_arg): Don't be confused by reference refs.
- (unify): Look through reference refs on the arg, too.
- * mangle.c (write_template_arg): Look through reference refs.
-
- * error.c (dump_expr): Avoid printing (*&i) for references.
-
-2014-11-20 Ville Voutilainen <ville.voutilainen@gmail.com>
-
- PR c++/63959
- * tree.c (trivially_copyable_p): Check for CP_TYPE_VOLATILE_P.
-
-2014-11-20 Trevor Saunders <tsaunders@mozilla.com>
-
- * cp-objcp-common.c: Use hash_table instead of htab.
-
-2014-11-19 Jason Merrill <jason@redhat.com>
-
- PR c++/56041
- * cp-tree.h (struct processing_template_decl_sentinel): New.
- * pt.c (instantiate_non_dependent_expr_internal): Split out from...
- (instantiate_non_dependent_expr_sfinae): Here.
- (convert_nontype_argument): Use them.
- * constexpr.c (fold_non_dependent_expr): Use them.
-
- PR c++/63885
- * constexpr.c (cxx_eval_constant_expression) [PARM_DECL]: Don't
- complain yet about a reference.
- [TARGET_EXPR]: Handle TARGET_EXPR with addr == true.
- [ADDR_EXPR]: Make sure we don't take the address of a CONSTRUCTOR.
- (cxx_bind_parameters_in_call): In the new scheme addr is always false.
- * typeck.c (build_address): Don't take the address of a CONSTRUCTOR.
-
- PR c++/57979
- * init.c (decl_really_constant_value): Rename from
- integral_constant_value.
- (scalar_constant_value): Similar but limited to scalar results.
- (decl_constant_value_safe): Remove.
- (constant_value_1): Respect return_aggregate_cst_ok_p.
- * typeck.c (decay_conversion): Use scalar_constant_value.
- * call.c (convert_like_real): Likewise.
- * cvt.c (ocp_convert): No need to check CLASS_TYPE_P.
- * typeck.c (decay_conversion): Or ARRAY_TYPE.
- * constexpr.c (struct constexpr_ctx): Add strict field.
- (cxx_eval_constant_expression) [VAR_DECL]: Use it to select between
- decl_constant_value and decl_really_constant_value.
- (cxx_eval_outermost_constant_expr): Add strict parm.
- (maybe_constant_init): Not strict.
- (potential_constant_expression_1): Add strict parm.
- Shorten most internal calls with RECUR macro.
- * cp-tree.h, pt.c, semantics.c: Adjust.
-
-2014-11-19 Jason Merrill <jason@redhat.com>
-
- PR c++/63928
- * constexpr.c (cxx_eval_store_expression): Return init, not *valp.
-
-2014-11-19 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/55425
- * constexpr.c (constexpr_fn_retval): Accept __func__, __FUNCTION__,
- and __PRETTY_FUNCTION__.
-
-2014-11-18 Jason Merrill <jason@redhat.com>
-
- PR c++/63924
- * constexpr.c (cxx_eval_constant_expression) [PARM_DECL]: A load
- from a variable of empty class type is constant.
-
- * constexpr.c (cxx_eval_statement_list): Handle statement-expressions.
- (potential_constant_expression_1): Handle STMT_EXPR.
-
- * constexpr.c (cxx_eval_constant_expression): Give jump_target a
- default argument.
- (lots): Omit NULL jump_target arguments.
-
- * constexpr.c (struct constexpr_ctx): Add quiet field.
- (cxx_eval_outermost_constant_expr, is_sub_constant_expr): Set it.
- (lots): Replace allow_non_constant parameter with ctx->quiet.
-
- PR c++/63940
- * constexpr.c (cxx_eval_binary_expression): Don't assume the
- expression was already folded.
- (cxx_eval_unary_expression): Likewise.
-
-2014-11-18 Marc Glisse <marc.glisse@inria.fr>
-
- PR libstdc++/43622
- * rtti.c (emit_support_tinfos): Handle __float128.
-
-2014-11-18 Jason Merrill <jason@redhat.com>
-
- PR c++/63925
- * constexpr.c (cxx_eval_increment_expression): Use POINTER_PLUS_EXPR.
-
- PR c++/63934
- * constexpr.c (cxx_eval_call_expression): Check DECL_CONSTRUCTOR_P
- rather than VOID_TYPE_P.
-
- * pt.c (instantiate_template_1): Use tsubst_aggr_type for context.
-
- PR c++/58102
- * typeck2.c (store_init_value): Set it.
- * cp-tree.h (CONSTRUCTOR_MUTABLE_POISON): New.
- * constexpr.c (cxx_eval_outermost_constant_expr): Check it.
-
-2014-11-17 Jason Merrill <jason@redhat.com>
-
- PR c++/33911
- * call.c (build_call_a): Don't warn_deprecated_use here.
- (build_over_call): Or here.
- * decl2.c (mark_used): Do it here.
- (is_late_template_attribute): Attribute deprecated is not deferred.
- (cplus_decl_attributes): Propagate TREE_DEPRECATED out to the template.
- * parser.c (cp_parser_template_name): Warn about deprecated template.
- (cp_parser_template_argument): Likewise.
-
- PR c++/50473
- * decl.c (cp_finish_decl): Don't try to process a non-dependent
- constant initializer for a reference.
- * pt.c (value_dependent_expression_p): A reference is always
- dependent.
- * call.c (extend_ref_init_temps_1): Also clear TREE_SIDE_EFFECTS
- on any NOP_EXPRs.
-
- Handle C++14 constexpr flow control.
- * constexpr.c (cxx_eval_loop_expr, cxx_eval_switch_expr): New.
- (cxx_eval_statement_list): New.
- (cxx_eval_constant_expression): Handle LABEL_EXPR,
- CASE_LABEL_EXPR, GOTO_EXPR, LOOP_EXPR, SWITCH_EXPR. Handle jump
- semantics of RETURN_EXPR.
- (many functions): Add jump_target parameter.
- (returns, breaks, continues, switches, label_matches): New.
- * cp-tree.h (LABEL_DECL_BREAK, LABEL_DECL_CONTINUE): New.
- * cp-gimplify.c (begin_bc_block): Set them.
-
- * cp-gimplify.c (genericize_cp_loop): Use LOOP_EXPR.
- (genericize_for_stmt): Handle null statement-list.
-
- * constexpr.c (use_new_call): Always use new call handling.
-
- C++14 constexpr support (minus loops and multiple returns)
- * constexpr.c (use_new_call): New macro.
- (build_data_member_initialization): Ignore non-mem-inits.
- (check_constexpr_bind_expr_vars): Remove C++14 checks.
- (constexpr_fn_retval): Likewise.
- (check_constexpr_ctor_body): Do nothing in C++14.
- (massage_constexpr_body): In C++14 only collect mem-inits.
- (get_function_named_in_call): Handle null CALL_EXPR_FN.
- (cxx_bind_parameters_in_call): Build bindings in same order as
- parameters. Don't treat iniviref parms specially in new call mode.
- (cxx_eval_call_expression): If use_new_call, do constexpr expansion
- based on DECL_SAVED_TREE rather than the massaged constexpr body.
- Set up ctx->object from AGGR_INIT_EXPR_SLOT if we don't have one.
- (is_sub_constant_expr): Don't mess with ctx.ctor here.
- (cxx_eval_component_reference): A null element means we're mid-
- initialization.
- (cxx_eval_store_expression, cxx_eval_increment_expression): New.
- (cxx_eval_constant_expression): Handle RESULT_DECL, DECL_EXPR,
- MODIFY_EXPR, STATEMENT_LIST, BIND_EXPR, USING_STMT,
- PREINCREMENT_EXPR, POSTINCREMENT_EXPR, PREDECREMENT_EXPR,
- POSTDECREMENT_EXPR. Don't look into DECL_INITIAL of variables in
- constexpr functions. In new-call mode find parms in the values table.
- (potential_constant_expression_1): Handle null CALL_EXPR_FN.
- Handle STATEMENT_LIST, MODIFY_EXPR, MODOP_EXPR, IF_STMT,
- PREINCREMENT_EXPR, POSTINCREMENT_EXPR, PREDECREMENT_EXPR,
- POSTDECREMENT_EXPR, BIND_EXPR, WITH_CLEANUP_EXPR,
- CLEANUP_POINT_EXPR, MUST_NOT_THROW_EXPR, TRY_CATCH_EXPR,
- EH_SPEC_BLOCK, EXPR_STMT, DECL_EXPR, CASE_LABEL_EXPR, BREAK_STMT,
- CONTINUE_STMT, USING_STMT, IF_STMT, DO_STMT, FOR_STMT, WHILE_STMT,
- SWITCH_STMT, ASM_EXPR.
- (cxx_eval_vec_init_1): Call build_aggr_init_expr.
- (cxx_eval_indirect_ref): Don't return a CONSTRUCTOR when the
- caller wants an lvalue.
- (cxx_eval_outermost_constant_expr): Pull object out of AGGR_INIT_EXPR.
- (maybe_constant_init): Look through INIT_EXPR.
- (ensure_literal_type_for_constexpr_object): Set
- cp_function_chain->invalid_constexpr.
- * cp-tree.h (struct language_function): Add invalid_constexpr bitfield.
- * decl.c (start_decl): Set cp_function_chain->invalid_constexpr.
- (check_for_uninitialized_const_var): Likewise.
- (maybe_save_function_definition): Check it.
- * parser.c (cp_parser_jump_statement): Set
- cp_function_chain->invalid_constexpr.
- (cp_parser_asm_definition): Likewise.
-
- PR c++/52282
- * decl.c (build_ptrmemfunc_type): Don't build a different
- RECORD_TYPE for a qualified PMF.
- * cp-tree.h (TYPE_PTRMEMFUNC_FN_TYPE): Merge cv-quals.
- (TYPE_PTRMEMFUNC_FN_TYPE_RAW): New.
- * decl2.c (cplus_decl_attributes): Use TYPE_PTRMEMFUNC_FN_TYPE_RAW.
- * tree.c (cp_walk_subtrees): Likewise.
- (cp_build_qualified_type_real): Remove special PMF handling.
-
-2014-11-15 Jason Merrill <jason@redhat.com>
-
- * parser.c (cp_parser_omp_declare_reduction_exprs): A block is not
- an expression.
-
- * constexpr.c (cxx_eval_builtin_function_call): Use
- fold_builtin_call_array.
-
- * constexpr.c (cx_check_missing_mem_inits): Clarify error message.
-
-2014-11-14 Paolo Carlini <paolo.carlini@oracle.com>
-
- * semantics.c (end_maybe_infinite_loop): Use fold_non_dependent_expr.
- * parser.c (cp_parser_omp_clause_collapse): Likewise.
- (cp_parser_enumerator_definition): Don't call
- instantiate_non_dependent_expr...
- * decl.c (build_enumerator): ... call fold_non_dependent_expr here.
- * typeck2.c (massage_init_elt): Use fold_non_dependent_expr.
- * constexpr.c (maybe_constant_value): Allow VIEW_CONVERT_EXPR in
- the final gcc_assert.
-
- * constexpr.c (fold_non_dependent_expr): Add.
- * cp-tree.h (fold_non_dependent_expr): Declare it.
- * call.c (null_ptr_cst_p): Use it.
- * pt.c (tsubst_copy_and_build, build_non_dependent_expr): Likewise.
- * semantics.c (begin_maybe_infinite_loop): Likewise.
- * typeck.c (cp_build_binary_op): Likewise.
- * typeck2.c (check_narrowing): Likewise.
-
- * pt.c (fold_non_dependent_expr): Rename to
- instantiate_non_dependent_expr.
- (fold_non_dependent_expr_sfinae): Rename to
- instantiate_non_dependent_expr_sfinae.
- (convert_nontype_argument, build_non_dependent_expr): Adjust.
- * decl.c (compute_array_index_type): Likewise.
- * parser.c (cp_parser_parenthesized_expression_list,
- cp_parser_enumerator_definition, cp_parser_omp_clause_collapse):
- Likewise.
- * semantics.c (end_maybe_infinite_loop, finish_static_assert):
- Likewise.
- * typeck.c (cxx_alignas_expr): Likewise.
- * typeck2.c (store_init_value, massage_init_elt): Likewise.
- * call.c: Adjust comments.
- * class.c: Likewise.
- * constexpr.c: Likewise.
- * decl2.c: Likewise.
- * tree.c: Likewise.
-
-2014-11-14 Jonathan Wakely <jwakely@redhat.com>
-
- * mangle.c (find_substitution): Look for abi_tag on class templates.
-
-2014-11-13 Bernd Schmidt <bernds@codesourcery.com>
- Thomas Schwinge <thomas@codesourcery.com>
- Ilya Verbin <ilya.verbin@intel.com>
- Andrey Turetskiy <andrey.turetskiy@intel.com>
-
- * Make-lang.in (c++.install-common): Do not install for the offload
- compiler.
-
-2014-11-13 Kai Tietz <ktietz@redhat.com>
-
- * cp-tree.h (cp_build_function_call): Remove prototype.
- (cp_build_addr_expr_strict): Likewise.
- (build_typed_address): Likewise.
- * typeck.c (build_typed_address): Removed.
- (cp_build_addr_expr_strict): Make static.
- (cp_build_function_call): Likewise.
-
-2014-11-12 Paolo Carlini <paolo.carlini@oracle.com>
-
- DR 1510
- PR c++/60420
- * cp-tree.h (struct cp_decl_specifier_seq): Add decltype_p bool field.
- * decl.c (grokdeclarator): Use it.
- * parser.c (cp_parser_simple_type_specifier): Likewise.
- * pt.c (tsubst, case DECLTYPE_TYPE): Use tf_ignore_bad_quals.
-
-2014-11-11 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/63265
- * pt.c (tsubst_copy_and_build, case COND_EXPR): Maybe fold to
- constant the condition.
-
-2014-11-10 Andi Kleen <ak@linux.intel.com>
-
- * semantics.c (finish_goto_stmt): Call check_no_cilk.
- (finish_while_stmt_cond): Dito.
- (finish_do_stmt): Dito.
- (finish_for_cond): Dito.
- (finish_switch_cond): Dito.
-
-2014-11-10 Paolo Carlini <paolo.carlini@oracle.com>
-
- * typeck.c (cp_build_binary_op): Use OPT_Wshift_count_negative and
- OPT_Wshift_count_overflow in the warnings.
-
-2014-11-09 Jason Merrill <jason@redhat.com>
-
- DR 799
- * typeck.c (build_reinterpret_cast_1): reinterpret_cast to the
- same scalar type is an rvalue.
-
- DR 2007
- * call.c (build_new_op_1): Don't do non-class lookup for =, -> or [].
-
-2014-11-07 Jason Merrill <jason@redhat.com>
-
- DR 1558
- * pt.c (dependent_alias_template_spec_p): New.
- (dependent_type_p_r): Handle dependent alias template specialization.
- (template_args_equal): A dependent alias template specializations
- is not equal to its underlying type as a template argument.
- * tree.c (strip_typedefs): Don't strip a dependent alias
- template-id.
-
- * parser.c (cp_parser_unqualified_id): Handle __func__ here.
- (cp_parser_primary_expression): Not here.
-
-2014-11-07 Thomas Preud'homme <thomas.preudhomme@arm.com>
-
- PR c++/63366
- * decl.c (grokdeclarator): Fix __complex meaning __complex double.
-
-2014-10-29 Richard Sandiford <richard.sandiford@arm.com>
-
- * constexpr.c: Remove redundant enum from machine_mode.
-
-2014-10-28 Jason Merrill <jason@redhat.com>
-
- * constexpr.c (cxx_eval_outermost_constant_expr): Tweak.
-
-2014-10-28 Andrew MacLeod <amacleod@redhat.com>
-
- * call.c: Adjust include files.
- * class.c: Ditto.
- * decl2.c: Ditto.
- * decl.c: Ditto.
- * lambda.c: Ditto.
- * mangle.c: Ditto.
- * method.c: Ditto.
- * optimize.c: Ditto.
- * parser.c: Ditto.
- * semantics.c: Ditto.
- * tree.c: Ditto.
- * vtable-class-hierarchy.c: Ditto.
-
-2014-10-24 Jason Merrill <jason@redhat.com>
-
- Implement N3653 (Member initializers and aggregates) and fix
- references to 'this' in constexpr constructors.
- * class.c (check_field_decls): In C++14 an NSDMI does not make the
- class non-aggregate.
- * constexpr.c (struct constexpr_ctx): New.
- (cxx_bind_parameters_in_call): Handle 'this'.
- (cxx_eval_call_expression): Create new constexpr_ctx.
- (cxx_eval_component_reference): Check CONSTRUCTOR_NO_IMPLICIT_ZERO.
- (initialized_type, init_subob_ctx, verify_ctor_sanity): New.
- (cxx_eval_bare_aggregate): Use them. Build CONSTRUCTOR early.
- (cxx_eval_vec_init_1): Likewise.
- (cxx_eval_constant_expression) [PARM_DECL]: Allow 'this'.
- [TARGET_EXPR]: Build new constexpr_ctx.
- [PLACEHOLDER_EXPR]: New.
- (cxx_eval_outermost_constant_expr): Build new constexpr_ctx. Add
- object parameter.
- (is_sub_constant_expr): Build new constexpr_ctx.
- (potential_constant_expression_1): Handle PLACEHOLDER_EXPR.
- Allow 'this'.
- * cp-gimplify.c (cp_gimplify_init_expr): Call replace_placeholders.
- * cp-tree.h (CONSTRUCTOR_NO_IMPLICIT_ZERO): New.
- * error.c (dump_expr): Handle PLACEHOLDER_EXPR.
- * init.c (get_nsdmi): Generate PLACEHOLDER_EXPR.
- * tree.c (lvalue_kind): Handle PLACEHOLDER_EXPR.
- (build_ctor_subob_ref, replace_placeholders): New.
- * typeck2.c (store_init_value): Use replace_placeholders.
- (process_init_constructor_record): Make zero-init before NSDMI
- explicit.
-
-2014-10-27 Andrew MacLeod <amacleod@redhat.com>
-
- * cp-gimplify.c: Adjust include files.
-
-2014-10-26 Manuel López-Ibáñez <manu@gcc.gnu.org>
-
- PR c++/53061
- * cp-objcp-common.c: Do not include new.
- (cxx_initialize_diagnostics): Move from here to ...
- * error.c (cxx_initialize_diagnostics): : ... here. Move
- diagnostics initialization here from init_error.
- (cxx_pp): Use a real pointer not a macro.
- (init_error): Just initialize cxx_pp.
- * cxx-pretty-print.c (cxx_pretty_printer::cxx_pretty_printer): Do
- not set maximum line length.
-
-2014-10-23 Jonathan Wakely <jwakely@redhat.com>
-
- PR c++/63619
- * decl2.c (delete_sanity): Use OPT_Wdelete_incomplete in warning.
-
-2014-10-21 Paolo Carlini <paolo.carlini@oracle.com>
-
- * parser.c (cp_parser_unary_expression): Add default arguments.
- (cp_parser_cast_expression, cp_parser_sizeof_operand,
- cp_parser_omp_atomic): Adjust.
-
-2014-10-20 Jason Merrill <jason@redhat.com>
-
- PR c++/63601
- * lambda.c (current_nonlambda_function): New.
- * semantics.c (finish_this_expr): Use it.
- * cp-tree.h: Declare it.
-
-2014-10-17 Alan Modra <amodra@gmail.com>
-
- PR middle-end/61848
- * decl.c (merge_decls): Don't merge section name, comdat group or
- tls model to newdecl symtab node, instead merge to olddecl.
- Override existing olddecl section name. Set tls_model for all
- thread-local vars, not just OMP thread-private ones. Remove
- incorrect comment.
-
-2014-10-16 Andrew MacLeod <amacleod@redhat.com>
-
- * cp-tree.h: Adjust include files.
-
-2014-10-15 Jason Merrill <jason@redhat.com>
-
- PR c++/63528
- * pt.c (lookup_template_variable): Call coerce_template_parms.
-
-2014-10-15 Paolo Carlini <paolo.carlini@oracle.com>
-
- * semantics.c (is_instantiation_of_constexpr, literal_type_p,
- ensure_literal_type_for_constexpr_object,
- constexpr_fundef_hasher::equal, constexpr_fundef_hasher::hash,
- retrieve_constexpr_fundef, is_valid_constexpr_fn,
- build_anon_member_initialization, build_data_member_initialization,
- check_constexpr_bind_expr_vars, check_constexpr_ctor_body_1,
- check_constexpr_ctor_body, sort_constexpr_mem_initializers,
- build_constexpr_constructor_member_initializers, constexpr_fn_retval,
- massage_constexpr_body, cx_check_missing_mem_inits,
- register_constexpr_fundef, explain_invalid_constexpr_fn,
- constexpr_call_hasher::hash, constexpr_call_hasher::equal,
- maybe_initialize_constexpr_call_table, get_function_named_in_call,
- get_nth_callarg, lookup_parameter_binding,
- cxx_eval_builtin_function_call, adjust_temp_type,
- cxx_bind_parameters_in_call, push_cx_call_context,
- pop_cx_call_context, cx_error_context, cxx_eval_call_expression,
- reduced_constant_expression_p, verify_constant,
- cxx_eval_unary_expression, cxx_eval_binary_expression,
- cxx_eval_conditional_expression, cxx_eval_array_reference,
- cxx_eval_component_reference, cxx_eval_bit_field_ref,
- cxx_eval_logical_expression, base_field_constructor_elt,
- cxx_eval_bare_aggregate, cxx_eval_vec_init_1, cxx_eval_vec_init,
- cxx_fold_indirect_ref, cxx_eval_indirect_ref, non_const_var_error,
- cxx_eval_trinary_expression, var_in_constexpr_fn,
- cxx_eval_constant_expression, cxx_eval_outermost_constant_expr,
- is_sub_constant_expr, cxx_constant_value, maybe_constant_value,
- maybe_constant_init, potential_constant_expression_1,
- potential_constant_expression, potential_rvalue_constant_expression,
- require_potential_constant_expression,
- require_potential_rvalue_constant_expression): Moved definitions...
- * constexpr.c: ... here, new file.
- * Make-lang.in: Update.
- * config-lang.in: Likewise.
-
-2014-10-14 Jason Merrill <jason@redhat.com>
-
- PR c++/63455
- * parser.c (struct saved_token_sentinel): New.
- (cp_parser_statement): Use it.
- (cp_parser_start_tentative_firewall): New.
- (cp_parser_end_tentative_firewall): New.
- (cp_parser_lambda_expression): Use them.
- (cp_parser_statement_expr): New.
- (cp_parser_primary_expression): Use it.
-
-2014-10-14 DJ Delorie <dj@redhat.com>
-
- * typeck.c (cp_common_type): Check for all __intN types, not just
- __int128.
- * decl.c (grokdeclarator): Likewise.
- * rtti.c (emit_support_tinfos): Check for all __intN types, not just
- __int128.
- * parser.c (cp_lexer_next_token_is_decl_specifier_keyword): Check
- for all __intN types, not just __int128.
- (cp_parser_simple_type_specifier): Likewise.
- * mangle.c (integer_type_codes): Remove int128-specific codes.
- * cp-tree.h (cp_decl_specifier_seq): Add int_n_idx to store which
- __intN was specified.
- * lex.c (init_reswords): Reserve all __intN keywords.
-
-2014-10-14 Marc Glisse <marc.glisse@inria.fr>
-
- * typeck.c (cp_build_unary_op) [TRUTH_NOT_EXPR]: Accept float vectors.
-
-2014-10-13 H.J. Lu <hongjiu.lu@intel.com>
-
- * mangle.c (mangle_conv_op_name_for_type): Cast elements to
- unsigned long.
- (print_template_statistics): Cast size and elements to long.
-
-2014-10-12 Trevor Saunders <tsaunders@mozilla.com>
-
- * cp-gimplify.c, cp-tree.h, decl.c, mangle.c, name-lookup.c,
- pt.c, semantics.c, tree.c, typeck2.c: Use hash_table instead of
- hashtab.
-
-2014-10-10 Jason Merrill <jason@redhat.com>
-
- PR c++/62115
- * class.c (build_base_path): Preserve rvalueness.
- * call.c (convert_like_real) [ck_base]: Let convert_to_base handle &/*.
- * rtti.c (build_dynamic_cast_1): Call convert_to_reference later.
-
- PR c++/63194
- * method.c (defaulted_late_check): Call maybe_instantiate_noexcept.
-
- * method.c (implicitly_declare_fn): Handle deleted lambda default
- ctor and copy assop here.
- * class.c (check_bases_and_members): Not here.
- (add_implicitly_declared_members): And don't set
- CLASSTYPE_LAZY_MOVE_ASSIGN.
-
- * semantics.c (finish_id_expression): Check for error_mark_node.
-
-2014-10-09 Jason Merrill <jason@redhat.com>
-
- PR c++/63207
- * semantics.c (outer_var_p): Non-static.
- (process_outer_var_ref): Split out from finish_id_expression.
- * pt.c (tsubst_copy_and_build): Call them.
- * cp-tree.h: Declare them.
-
-2014-10-09 Paolo Carlini <paolo.carlini@oracle.com>
-
- * semantics.c (check_constexpr_ctor_body_1): New.
- (check_constexpr_ctor_body): Use it; add bool parameter.
- (build_data_member_initialization): Handle BIND_EXPR and
- USING_STMT in the main conditional.
- (build_constexpr_constructor_member_initializers): Do not
- handle BIND_EXPR here.
- (constexpr_fn_retval): Handle BIND_EXPR in the switch.
- (massage_constexpr_body): Don't do it here.
- * parser.c (cp_parser_ctor_initializer_opt_and_function_body):
- Adjust check_constexpr_ctor_body call.
- (cp_parser_compound_statement): Do not pedwarn for compound-statement
- in constexpr function in C++14 mode.
- * cp-tree.h (check_constexpr_ctor_body): Update declaration.
-
-2014-10-09 Jason Merrill <jason@redhat.com>
-
- PR c++/63309
- * parser.c (cp_parser_class_head): push_template_decl for members
- of templates, too.
-
- PR c++/63415
- * pt.c (value_dependent_expression_p) [CONSTRUCTOR]: Check the type.
- (iterative_hash_template_arg): Likewise.
-
- PR c++/63437
- * cp-tree.h (REF_PARENTHESIZED_P): Also allow INDIRECT_REF.
- * semantics.c (force_paren_expr): And set it.
- * typeck.c (check_return_expr): And handle it.
-
-2014-10-09 Marc Glisse <marc.glisse@inria.fr>
-
- * decl.c (grokdeclarator): constexpr only implies const in C++11.
-
-2014-10-08 Jason Merrill <jason@redhat.com>
-
- PR c++/63405
- * pt.c (tsubst_pack_expansion): Limit simple expansion to type packs.
-
- PR c++/63485
- * tree.c (build_cplus_array_type): Look for a type with no
- typedef-name or attributes.
-
- * call.c (call_copy_ctor): New.
- (build_over_call): Use it to avoid infinite recursion on invalid code.
-
-2014-10-07 Jason Merrill <jason@redhat.com>
-
- * tree.c (cp_tree_equal) [TRAIT_EXPR]: Use cp_tree_equal for type2.
-
-2014-10-06 Edward Smith-Rowland <3dw4rd@verizon.net>
-
- * cp/parser.c: Allow [[deprecated]] for C++11. Issue a pedwarn.
-
-2014-10-06 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/55250
- * semantics.c (check_constexpr_bind_expr_vars): New.
- (check_constexpr_ctor_body, massage_constexpr_body): Use it.
- (build_constexpr_constructor_member_initializers): Handle
- BIND_EXPR in the main conditional.
-
-2014-10-02 Mark Wielaard <mjw@redhat.com>
-
- PR debug/63239
- * cp-objcp-common.h (LANG_HOOKS_FUNCTION_DECL_DELETED_P): Define.
- (cp_function_decl_deleted_p): New prototype.
- * cp-objcp-common.c (cp_function_deleted_p): New function.
-
-2014-10-03 Marc Glisse <marc.glisse@inria.fr>
-
- PR c++/54427
- PR c++/57198
- PR c++/58845
- * typeck.c (cp_build_binary_op): save_expr after convert to save
- redundant operations.
- [TRUTH_ANDIF_EXPR, TRUTH_ORIF_EXPR]: Handle vectors.
- (cp_build_unary_op) [TRUTH_NOT_EXPR]: Likewise.
-
-2014-10-03 Jason Merrill <jason@redhat.com>
-
- * decl.c (start_decl): Complain about static/thread_local vars
- in constexpr function.
- (check_for_uninitialized_const_var): Also uninitialized vars.
- * parser.c (cp_parser_jump_statement): And gotos.
- (cp_parser_asm_operand_list): And asm.
- (cp_parser_try_block): And try.
- * semantics.c (ensure_literal_type_for_constexpr_object): And
- non-literal.
-
- * semantics.c (constexpr_fn_retval): Ignore declarations in C++14.
- (var_in_constexpr_fn): New.
- (cxx_eval_constant_expression): Look into DECL_INITIAL.
- (potential_constant_expression_1): Allow constexpr-local vars.
-
- PR c++/63362
- * tree.c (strip_typedefs): Handle TREE_LIST.
-
-2014-10-03 Paolo Carlini <paolo.carlini@oracle.com>
-
- * parser.c (cp_parser_assignment_expression,
- cp_parser_constant_expression): Add default arguments.
- (cp_parser_primary_expression,
- cp_parser_postfix_open_square_expression,
- cp_parser_parenthesized_expression_list,
- cp_parser_question_colon_clause,
- cp_parser_expression, cp_parser_constant_expression,
- cp_parser_label_for_labeled_statement, cp_parser_static_assert,
- cp_parser_template_argument, cp_parser_enumerator_definition,
- cp_parser_member_declaration, cp_parser_constant_initializer,
- cp_parser_noexcept_specification_opt, cp_parser_throw_expression,
- cp_parser_std_attribute_spec, cp_parser_objc_message_args,
- cp_parser_objc_class_ivars, cp_parser_omp_clause_collapse,
- cp_parser_omp_clause_aligned, cp_parser_omp_clause_safelen,
- cp_parser_omp_clause_simdlen, cp_parser_omp_clause_dist_schedule,
- cp_parser_omp_for_incr, cp_parser_omp_for_loop_init,
- cp_parser_cilk_simd_vectorlength, cp_parser_cilk_simd_linear): Adjust.
-
-2014-10-02 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/53025
- * cp-tree.h (struct saved_scope): Add noexcept_operand.
- (cp_noexcept_operand): Define.
- * call.c (build_over_call): Use it.
- * parser.c (cp_parser_unary_expression, [RID_NOEXCEPT]): Likewise.
- * pt.c (tsubst_copy_and_build, [NOEXCEPT_EXPR]): Likewise.
-
-2014-10-01 Jason Merrill <jason@redhat.com>
-
- PR c++/63362
- * method.c (constructible_expr): Handle value-init of non-class.
- * parser.c (cp_parser_trait_expr): Allow pack expansion.
- * pt.c (tsubst_copy_and_build): Handle pack expansion.
-
- PR c++/63362
- * class.c (type_has_non_user_provided_default_constructor): Rename
- from type_has_user_provided_default_constructor, reverse sense.
- (default_init_uninitialized_part, explain_non_literal_class): Adjust.
- (check_bases_and_members): Set TYPE_HAS_COMPLEX_DFLT.
- * call.c (build_new_method_call_1): Adjust.
- * cp-tree.h: Adjust.
- * decl.c (grok_special_member_properties): Don't set
- TYPE_HAS_COMPLEX_DFLT.
- * init.c (build_value_init_noctor): Don't use
- type_has_user_provided_default_constructor.
-
-2014-09-30 Jason Merrill <jason@redhat.com>
-
- * cp-tree.h (cp_trait_kind): Add CPTK_IS_TRIVIALLY_ASSIGNABLE and
- CPTK_IS_TRIVIALLY_CONSTRUCTIBLE.
- * cxx-pretty-print.c (pp_cxx_trait_expression): Likewise.
- * parser.c (cp_parser_primary_expression): Likewise.
- (cp_parser_trait_expr): Likewise. Handle variadic trait.
- * semantics.c (trait_expr_value): Likewise.
- (finish_trait_expr): Likewise.
- (check_trait_type): Handle variadic trait. Return bool.
- * method.c (build_stub_object): Add rvalue reference here.
- (locate_fn_flags): Not here.
- (check_nontriv, assignable_expr, constructible_expr): New.
- (is_trivially_xible): New.
-
- * cp-tree.h (cp_trait_kind): Add CPTK_IS_TRIVIALLY_COPYABLE.
- * cxx-pretty-print.c (pp_cxx_trait_expression): Likewise.
- * parser.c (cp_parser_primary_expression): Likewise.
- (cp_parser_trait_expr): Likewise.
- * semantics.c (trait_expr_value): Likewise.
- (finish_trait_expr): Likewise.
-
- * method.c (build_stub_object): Use CONVERT_EXPR.
- * tree.c (build_dummy_object): Likewise.
- (is_dummy_object): Adjust.
-
- * cp-tree.h (cp_trait_kind): Remove CPTK_IS_CONVERTIBLE_TO.
- * cxx-pretty-print.c (pp_cxx_trait_expression): Likewise.
- * semantics.c (trait_expr_value): Likewise.
- (finish_trait_expr): Likewise.
- * parser.c (cp_parser_primary_expression): Likewise.
- (cp_parser_trait_expr): Likewise. Remove redundant grokdeclarator.
-
-2014-09-30 Manuel López-Ibáñez <manu@gcc.gnu.org>
-
- PR c++/16564
- * error.c (print_instantiation_context): Delete.
- * typeck2.c (build_x_arrow): Record location when pushing
- template instantiation.
- * pt.c (push_tinst_level): Make it a wrapper around ...
- (push_tinst_level_loc): ... this. New function. Make excessive
- template instantiation depth a fatal error. Record location. Use
- bool as return type.
- (instantiate_pending_templates): Make excessive
- template instantiation depth a fatal error.
- (problematic_instantiation_changed): Use bool as return type.
- * cp-tree.h (print_instantiation_context): Delete.
- (push_tinst_level): Update declaration.
- (problematic_instantiation_changed): Likewise.
- (push_tinst_level_loc): New.
-
-2014-09-29 Richard Biener <rguenther@suse.de>
-
- * typeck.c (enum_cast_to_int): Use CONVERT_EXPR_P to check
- for conversions.
-
-2014-09-26 Jason Merrill <jason@redhat.com>
-
- * mangle.c (find_substitution): Use write_abi_tags.
-
-2014-09-25 Marek Polacek <polacek@redhat.com>
-
- PR c++/61945
- * class.c (warn_hidden): Check for FUNCTION_DECL.
-
-2014-09-25 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/63249
- * semantics.c (handle_omp_array_sections_1): Call mark_rvalue_use
- on low_bound and length.
-
-2014-09-24 Aldy Hernandez <aldyh@redhat.com>
-
- * class.c, decl.c, optimize.c: Rename all instances of
- DECL_ABSTRACT to DECL_ABSTRACT_P.
-
-2014-09-24 Marek Polacek <polacek@redhat.com>
-
- PR c/61405
- PR c/53874
- * semantics.c (finish_switch_cond): Call unlowered_expr_type.
- * tree.c (bot_manip): Add default case.
- * parser.c (cp_parser_primary_expression): Cast the controlling
- expression of a switch to an int.
- (cp_parser_unqualified_id): Likewise.
-
-2014-09-23 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/61857
- * parser.c (cp_parser_skip_to_closing_square_bracket,
- cp_parser_array_designator_p): New.
- (cp_parser_initializer_list): Use the latter.
-
-2014-09-22 Jason Merrill <jason@redhat.com>
-
- * semantics.c (finish_non_static_data_member): In diagnostic, give
- error at point of use and note at point of declaration.
-
- PR c++/63320
- PR c++/60463
- PR c++/60755
- * lambda.c (maybe_resolve_dummy, lambda_expr_this_capture): Handle
- not finding 'this'.
-
-2014-09-22 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/62219
- * pt.c (check_default_tmpl_args): Check LAMBDA_FUNCTION_P.
-
-2014-09-22 Jason Merrill <jason@redhat.com>
-
- * decl.c (poplevel): Don't warn about unused vars in template scope.
- * error.c (dump_decl): Handle variable templates.
-
-2014-09-20 Jason Merrill <jason@redhat.com>
-
- PR c++/62017
- * decl.c (begin_destructor_body): Only clobber the as-base part of
- *this.
-
-2014-09-19 Jason Merrill <jason@redhat.com>
-
- PR c++/61392
- * mangle.c (write_expression): Use unresolved-name mangling for
- DR850 case.
-
- PR c++/61465
- * call.c (convert_like_real) [ck_identity]: Call mark_rvalue_use
- after pulling out an element from a CONSTRUCTOR.
-
-2014-09-18 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/63248
- * semantics.c (finish_omp_clauses): Don't call cp_omp_mappable_type
- on type of type dependent expressions, and don't call it if
- handle_omp_array_sections has kept TREE_LIST because something
- was type dependent.
- * pt.c (tsubst_expr) <case OMP_TARGET, case OMP_TARGET_DATA>:
- Use keep_next_level, begin_omp_structured_block and
- finish_omp_structured_block instead of push_stmt_list and
- pop_stmt_list.
-
-2014-09-18 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/62232
- * class.c (finish_struct_1): Do not -Wnon-virtual-dtor warn
- for final class types.
-
-2014-09-15 Jason Merrill <jason@redhat.com>
-
- * pt.c (lookup_template_class_1): Splice out abi_tag attribute if
- necessary. Call inherit_targ_abi_tags here.
- * class.c (check_bases_and_members): Not here.
- (inherit_targ_abi_tags): Check CLASS_TYPE_P.
- * cp-tree.h: Declare inherit_targ_abi_tags.
-
-2014-09-15 Ville Voutilainen <ville.voutilainen@gmail.com>
-
- Do not diagnose lambda default arguments in c++14 modes.
- * parser.c (cp_parser_lambda_declarator_opt): Make the pedwarn
- conditional.
-
-2014-09-15 Jakub Jelinek <jakub@redhat.com>
-
- * Make-lang.in (check_g++_parallelize): Change to just an upper bound
- number.
-
-2014-09-13 Marek Polacek <polacek@redhat.com>
-
- PR c++/60862
- * parser.c (cp_parser_postfix_expression) <case CPP_OPEN_PAREN>: Set
- location of a call expression.
-
-2014-09-11 Jason Merrill <jason@redhat.com>
-
- PR c++/63201
- * decl.c (start_decl): Handle specialization of member variable
- template.
- * pt.c (check_explicit_specialization): Adjust error.
-
-2014-09-11 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/61489
- * typeck2.c (process_init_constructor_record): Do not warn about
- missing field initializer if EMPTY_CONSTRUCTOR_P (init).
-
-2014-09-11 Jason Merrill <jason@redhat.com>
-
- PR c++/63139
- * pt.c (tsubst_pack_expansion): Simplify substitution into T....
- (tsubst): Don't throw away PACK_EXPANSION_EXTRA_ARGS.
-
-2014-09-10 Jason Merrill <jason@redhat.com>
-
- PR c++/61659
- * decl.c (grokfndecl): Don't set DECL_COMDAT on static inlines.
- (duplicate_decls, start_decl): Likewise.
- * pt.c (check_explicit_specialization): Likewise.
- (push_template_decl_real): Or static templates.
-
-2014-09-08 Jason Merrill <jason@redhat.com>
-
- * typeck.c (build_class_member_access_expr): Move
- -Winvalid-offsetof code...
- * semantics.c (finish_offsetof): ...here.
- * parser.c (cp_parser_builtin_offsetof): Remember the location of
- the type argument.
- * pt.c (tsubst_copy_and_build) [OFFSETOF_EXPR]: Preserve it.
-
- PR c++/62255
- * pt.c (instantiate_decl): Handle recursive instantiation of
- static data member.
-
-2014-09-05 Jason Merrill <jason@redhat.com>
-
- PR c++/62659
- * semantics.c (potential_constant_expression_1): Handle un-folded
- pointer to member constants.
-
-2014-09-04 Markus Trippelsdorf <markus@trippelsdorf.de>
-
- PR ipa/61659
- * decl.c (duplicate_decls): Check DECL_DECLARED_INLINE_P on
- newdecl, not olddecl.
-
-2014-09-02 Paolo Carlini <paolo.carlini@oracle.com>
-
- DR 1453
- * class.c (check_field_decls): A class of literal type cannot have
- volatile non-static data members and base classes.
- (explain_non_literal_class): Update.
-
-2014-09-02 Jakub Jelinek <jakub@redhat.com>
- Balaji V. Iyer <balaji.v.iyer@intel.com>
- Igor Zamyatin <igor.zamyatin@intel.com>
-
- * cp-cilkplus.c (cpp_validate_cilk_plus_loop_aux): Loc definition
- simplified.
- * parser.c (cp_parser_cilk_for): New function.
- (cp_parser_cilk_grainsize): Likewise.
- (cp_parser_statement): Added RID_CILK_FOR case.
- (cp_parser_omp_for_cond): Added CILK_FOR check.
- (cp_parser_omp_for_loop_init): Change function argument to accept
- tree_code instead just a bool flag; change the check to use that
- tree_code; check for initialization declaration in case of Cilk_for.
- (cp_parser_omp_for_loop): Added checks for CILK_FOR and RID_CILK_FOR;
- changed call to cp_parser_omp_for_loop_init according new arguments'
- list.
- (cp_parser_pragma): Added PRAGMA_CILK_GRAINSIZE case.
- * pt.c (tsubst_expr): Added CILK_FOR case.
- * semantics.c: Include convert.h.
- (finish_omp_clauses): Properly handle OMP_CLAUSE_SCHEDULE_CILKFOR
- case; added OMP_CLAUSE__CILK_FOR_COUNT_.
- (handle_omp_for_class_iterator): New argument lastp and its usage;
- added NE_EXPR case.
- (finish_omp_for): Changed call to handle_omp_for_class_iterator
- according new arguments' list; in case of Cilk_for save very first
- decl and create empty stmt_list block; use block to build correct
- statement tree.
-
-2014-08-31 Jason Merrill <jason@redhat.com>
-
- PR c++/62302
- * optimize.c (cdtor_comdat_group): Just look at the
- DECL_ASSEMBLER_NAME of the 'tors.
-
-2014-08-27 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/52892
- * semantics.c (cxx_eval_call_expression): Use STRIP_NOPS on the
- result of cxx_eval_constant_expression.
-
-2014-08-26 Jason Merrill <jason@redhat.com>
-
- PR c++/58624
- * pt.c (tsubst_decl) [VAR_DECL]: Copy TLS model.
- (tsubst_copy_and_build) [VAR_DECL]: Use TLS wrapper.
- * semantics.c (finish_id_expression): Don't call TLS wrapper in a
- template.
-
-2014-08-25 Jason Merrill <jason@redhat.com>
-
- * pt.c (check_explicit_specialization): Don't complain about
- non-template variable.
- (template_for_substitution): Allow variable templates.
- (check_template_variable): Fix logic for member var template.
- * decl.c (start_decl): Don't complain about extra template header
- here.
-
- * decl.c (start_decl): Look through member variable template.
- * pt.c (tsubst_decl) [VAR_DECL]: Handle member variable templates.
- * decl2.c (grokfield): Set DECL_CONTEXT earlier on
- variables.
-
-2014-08-25 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/34938
- * cp-tree.h (TFF_POINTER): Add.
- * cxx-pretty-print.h (pp_cxx_cv_qualifiers): Forward the third
- argument too.
- * error.c (dump_type_suffix): Actually print the const and noreturn
- attribute when appropriate.
-
-2014-08-23 Edward Smith-Rowland <3dw4rd@verizon.net>
-
- * decl.c (compute_array_index_type, grokdeclarator,
- undeduced_auto_decl): Change from cxx1y to cxx14.
- *lambda.c(add_capture()): Change error message from C++1y to C++14.
- * parser.c (cp_parser_unqualified_id, cp_parser_pseudo_destructor_name,
- cp_parser_lambda_introducer, cp_parser_lambda_declarator_opt,
- cp_parser_decltype, cp_parser_conversion_type_id,
- cp_parser_simple_type_specifier, cp_parser_type_id_1,
- cp_parser_template_type_arg, cp_parser_std_attribute,
- cp_parser_template_declaration_after_export): Ditto.
- * pt.c (tsubst): Ditto.
- * semantics.c (force_paren_expr, finish_decltype_type): Ditto.
- * tree.c: Change comment.
- * typeck.c (comp_template_parms_position, cxx_sizeof_or_alignof_type,
- cp_build_addr_expr_1, maybe_warn_about_useless_cast): Ditto.
-
-2014-08-23 Jason Merrill <jason@redhat.com>
-
- Allow non-constexpr variable templates.
- * decl2.c (note_variable_template_instantiation): New.
- * cp-tree.h: Declare it.
- * pt.c (instantiate_decl): Call it.
- (push_template_decl_real): Allow non-constexpr variable templates.
- * semantics.c (finish_id_expression): Mark the variable template
- instantiation as used.
- * mangle.c (write_mangled_name): Variable template instantiations
- are mangled.
- * parser.c (cp_parser_init_declarator): Complain about
- non-function implicit templates.
-
-2014-08-22 Marek Polacek <polacek@redhat.com>
-
- PR c++/62199
- * parser.c (cp_parser_binary_expression): Check each LHS if it's
- preceded with logical not. Adjust call to
- warn_logical_not_parentheses.
-
-2014-08-22 Manuel López-Ibáñez <manu@gcc.gnu.org>
-
- PR c++/57709
- * name-lookup.c (pushdecl_maybe_friend_1): Do not warn if a
- declaration shadows a function declaration, unless the former
- declares a function, pointer to function or pointer to member
- function, because this is a common and valid case in real-world
- code.
- * cp-tree.h (TYPE_PTRFN_P,TYPE_REFFN_P,TYPE_PTRMEMFUNC_P):
- Improve description.
-
-2014-08-22 Jason Merrill <jason@redhat.com>
-
- PR c++/62129
- * class.c (outermost_open_class): Fix logic.
- * decl.c (complete_vars): Fix logic.
-
-2014-08-22 Jason Merrill <jason@redhat.com>
-
- PR c++/62129
- * class.c (outermost_open_class): New.
- * cp-tree.h: Declare it.
- * decl.c (maybe_register_incomplete_var): Use it.
- (complete_vars): Handle any constant variable.
- * expr.c (cplus_expand_constant): Handle CONSTRUCTOR.
-
-2014-08-22 Igor Zamyatin <igor.zamyatin@intel.com>
-
- PR other/62008
- * cp-array-notation.c (build_array_notation_ref): Added correct
- handling of case with incorrect array.
-
-2014-08-21 Manuel López-Ibáñez <manu@gcc.gnu.org>
-
- PR fortran/44054
- * error.c (cp_diagnostic_finalizer): Delete.
- (init_error): Do not set diagnostic_finalizer here.
-
-2014-08-19 Marek Polacek <polacek@redhat.com>
-
- PR c++/62153
- * call.c (build_new_op_1): Remember the type of arguments for
- a comparison. If either operand of a comparison is a boolean
- expression, call maybe_warn_bool_compare.
-
-2014-08-19 Jason Merrill <jason@redhat.com>
-
- PR tree-optimization/62091
- * decl2.c (decl_needed_p): Return true for virtual functions when
- devirtualizing.
-
- PR lto/53808
- PR c++/61659
- * decl.c (maybe_commonize_var): Don't use DECL_COMDAT to trigger
- comdat_linkage.
-
-2014-08-19 Gerald Pfeifer <gerald@pfeifer.com>
-
- * class.c (contains_empty_class_p): Remove.
-
-2014-08-18 Paolo Carlini <paolo.carlini@oracle.com>
-
- * parser.c (cp_parser_expression): Add default arguments.
- (cp_parser_primary_expression, cp_parser_postfix_expression,
- cp_parser_array_notation, cp_parser_postfix_open_square_expression,
- cp_parser_unary_expression, cp_parser_direct_new_declarator,
- cp_parser_question_colon_clause, cp_parser_assignment_operator_opt,
- cp_parser_lambda_body, cp_parser_expression_statement,
- cp_parser_condition, cp_parser_c_for, cp_parser_range_for,
- cp_parser_iteration_statement, cp_parser_jump_statement,
- cp_parser_decltype_expr, cp_parser_noexcept_specification_opt,
- cp_parser_asm_operand_list, cp_parser_objc_message_receiver,
- cp_parser_objc_synchronized_statement, cp_parser_objc_throw_statement,
- cp_parser_omp_var_list_no_open, cp_parser_omp_clause_num_threads,
- cp_parser_omp_clause_num_teams, cp_parser_omp_clause_thread_limit,
- cp_parser_omp_clause_linear, cp_parser_omp_clause_device,
- cp_parser_omp_atomic, cp_parser_omp_for_loop_init,
- cp_parser_omp_for_loop, cp_parser_omp_declare_reduction_exprs,
- cp_parser_transaction_expression): Adjust.
-
-2014-08-15 Jason Merrill <jason@redhat.com>
-
- PR c++/61566
- * pt.c (lookup_template_class_1): Revert recent change.
- * mangle.c (CLASSTYPE_TEMPLATE_ID_P): Revert recent change.
-
- PR c++/61566
- * pt.c (instantiate_class_template_1): Ignore lambda on
- CLASSTYPE_DECL_LIST.
- (push_template_decl_real): A lambda is not primary.
- (lookup_template_class_1): Don't look for a lambda partial
- instantiation.
- * lambda.c (maybe_add_lambda_conv_op): Distinguish between being
- currently in a function and the lambda living in a function.
- * mangle.c (CLASSTYPE_TEMPLATE_ID_P): False for lambda.
-
-2014-08-15 Richard Biener <rguenther@suse.de>
- Jason Merrill <jason@redhat.com>
-
- PR bootstrap/62077
- * tree.c (build_min_array_type, set_array_type_canon): Split out...
- (build_cplus_array_type): ...from here. Only call build_array_type
- for main variants.
-
-2014-08-15 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/62072
- Revert:
- 2014-07-09 Paolo Carlini <paolo.carlini@oracle.com>
-
- DR 1584
- PR c++/57466
- * pt.c (check_cv_quals_for_unify): Implement resolution, disregard
- cv-qualifiers of function types.
-
-2014-08-15 Manuel Lopez-Ibanez <manu@gcc.gnu.org>
-
- * call.c (build_conditional_expr_1): Use OPT_Wextra in warning.
-
-2014-08-14 Paolo Carlini <paolo.carlini@oracle.com>
-
- * typeck.c (composite_pointer_type, cxx_sizeof_or_alignof_type,
- cp_build_array_ref, cp_build_function_call_vec): When a
- pedwarn is suppressed under SFINAE, return error_mark_node.
-
- * typeck.c (cxx_sizeof_or_alignof_type): Fix complain &
- tf_warning_or_error, where complain is a bool, glitch.
-
-2014-08-14 Ville Voutilainen <ville.voutilainen@gmail.com>
-
- PR c++/62101
- * decl.c (grokdeclarator): Move the check for friend initializers..
- * decl2.c (grokfield) ..here. Postpone early return for friends
- until after the initializer check.
-
-2014-08-14 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/54377
- * pt.c (coerce_template_parms): Improve error message vs default
- arguments.
-
-2014-08-14 Paolo Carlini <paolo.carlini@oracle.com>
-
- * parser.c (cp_parser_init_declarator): Remove redundant check of
- decl_specifiers->type.
-
-2014-08-13 Jason Merrill <jason@redhat.com>
-
- * call.c (build_x_va_arg): Support passing non-POD through ....
- (convert_arg_to_ellipsis): Likewise.
-
-2014-08-13 Andrew Sutton <andrew.n.sutton@gmail.com>
-
- * pt.c (lookup_template_variable): Make dependent variable templates
- have unknown type.
-
-2014-08-13 Paolo Carlini <paolo.carlini@oracle.com>
-
- * parser.c (cp_parser_elaborated_type_specifier): Handle
- specially cp_parser_template_id returning a BASELINK.
-
-2014-08-13 Paolo Carlini <paolo.carlini@oracle.com>
-
- * parser.c (cp_parser_diagnose_invalid_type_name,
- cp_parser_make_typename_type): Remove scope parameter.
- (cp_parser_parse_and_diagnose_invalid_type_name,
- cp_parser_elaborated_type_specifier): Adjust calls.
-
-2014-08-12 Ville Voutilainen <ville.voutilainen@gmail.com>
-
- Reject virt-specifiers on friends and member templates
- * friend.c (do_friend): Diagnose virt-specifiers.
- * pt.c (push_template_decl_real): Diagnose virt-specifiers.
-
-2014-08-09 Paolo Carlini <paolo.carlini@oracle.com>
-
- * typeck2.c (check_narrowing): Add tsubst_flags_t parameter, change
- return type to bool; in C++11 for constants give errors, not pedwarns.
- * cp-tree.h (check_narrowing): Adjust declaration.
- * call.c (convert_like_real): Update calls.
- * semantics.c (finish_compound_literal): Likewise.
-
-2014-08-08 Jason Merrill <jason@redhat.com>
-
- * pt.c (lookup_template_class_1): Copy abi_tag.
-
-2014-08-08 Kai Tietz <ktietz@redhat.com>
-
- * semantics.c (expand_or_defer_fn_1): Check for keep-inline-dllexport
- that we operate on a true inline.
-
-2014-08-07 Trevor Saunders <tsaunders@mozilla.com>
-
- * class.c, cp-gimplify.c, decl.c, decl2.c, error.c, method.c,
- optimize.c, pt.c, semantics.c: Remove includes of pointer-set.h.
-
-2014-08-07 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51312
- * decl.c (build_enumerator): Handle class types with conversion
- operators via perform_implicit_conversion_flags and
- build_expr_type_conversion.
-
- * cvt.c (build_expr_type_conversion): Replace pair of errors
- with error + inform.
-
-2014-08-07 Jason Merrill <jason@redhat.com>
-
- PR c++/62043
- * parser.c (c_parse_file): Change sorry to fatal_error.
-
- PR c++/61959
- * semantics.c (cxx_eval_bare_aggregate): Handle POINTER_PLUS_EXPR.
-
-2014-08-07 Trevor Saunders <tsaunders@mozilla.com>
-
- * cp-tree.h, pt.c: Use hash_map instead of pointer_map.
-
-2014-08-06 Jason Merrill <jason@redhat.com>
-
- * init.c (build_vec_init): Fix constant initialization of
- trailing elements.
- (build_value_init_noctor): Call maybe_constant_init.
- * semantics.c (maybe_constant_init): See through EXPR_STMT and
- conversion to void.
-
- PR c++/60417
- * init.c (build_vec_init): Reorganize earlier change a bit.
-
- PR c++/61994
- * init.c (build_vec_init): Leave atype an ARRAY_TYPE
- if we're just returning an INIT_EXPR.
-
-2014-08-06 Jason Merrill <jason@redhat.com>
- Braden Obrzut <admin@maniacsvault.net>
-
- * pt.c (check_explicit_specialization): Don't test
- DECL_DECLARED_INLINE_P for a variable template.
-
-2014-08-06 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/43906
- * typeck.c (cp_build_binary_op): Extend to more cases the
- -Waddress warning.
-
-2014-08-01 Braden Obrzut <admin@maniacsvault.net>
-
- Implement constexpr variable templates
- * decl.c (grokvardecl): Handle specializations of variable templates.
- (grokdeclarator): Handle variable template id expressions and NULL_TREE
- return from grokvardecl.
- * decl2.c (check_member_template): Allow declaration of template member
- variables.
- * parser.c (cp_parser_template_id): Build a TEMPLATE_ID_EXPR for
- variable templates.
- * pt.c (check_template_variable): Accept variable temploids at
- non-class scope.
- (push_template_decl_real): The current instantiation of a template
- can be a VAR_DECL.
- (determine_specialization): Accept variable templates.
- (check_explicit_specialization): Handle and check for malformed
- variable template specializations.
- (lookup_template_variable): New.
- (tsubst_decl): Handle variable template specializations.
- (do_decl_instantiation): Handle template variables.
- (instantiate_decl): Handle template variables.
- * semantics.c (finish_template_variable): New.
- (finish_id_expression): Instantiate variable templates.
- * cp-tree.h (variable_template_p): New.
-
-2014-08-02 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/15339
- * decl.c (check_redeclaration_no_default_args): New.
- (duplicate_decls): Use it, handle default arguments
- in redeclarations of function templates.
-
-2014-08-02 Trevor Saunders <tsaunders@mozilla.com>
-
- * optimize.c, semantics.c: Use hash_map instead of pointer_map.
-
-2014-08-02 Trevor Saunders <tsaunders@mozilla.com>
-
- * class.c, cp-gimplify.c, cp-tree.h, decl.c, decl2.c, error.c,
- method.c, name-lookup.c, pt.c, semantics.c, tree.c: Use hash_set
- instead of pointer_set.
-
-2014-08-01 Jason Merrill <jason@redhat.com>
-
- PR c++/60417
- * init.c (build_vec_init): Set CONSTRUCTOR_IS_DIRECT_INIT on
- init-list for trailing elements.
- * typeck2.c (process_init_constructor_array): Likewise.
-
-2014-08-01 Paolo Carlini <paolo.carlini@oracle.com>
-
- DR 217 again
- * decl.c (duplicate_decls): Handle static member functions too.
-
-2014-08-01 Igor Zamyatin <igor.zamyatin@intel.com>
-
- * cp-array-notation.c (expand_an_in_modify_expr): Fix the misprint
- in error output.
-
-2014-08-01 Igor Zamyatin <igor.zamyatin@intel.com>
-
- PR other/61963
- * parser.c (cp_parser_array_notation): Added check for array_type.
-
-2014-08-01 Igor Zamyatin <igor.zamyatin@intel.com>
-
- PR middle-end/61455
- * cp-array-notation.c (expand_array_notation_exprs): Handling of
- DECL_EXPR improved. Changed handling for INIT_EXPR.
-
-2014-08-01 Paolo Carlini <paolo.carlini@oracle.com>
-
- * pt.c (lookup_template_class_1): Use DECL_TYPE_TEMPLATE_P.
-
-2014-08-01 Jakub Jelinek <jakub@redhat.com>
-
- * cp-gimplify.c (cp_genericize_r): For -fsanitize=null and/or
- -fsanitize=alignment call ubsan_maybe_instrument_reference
- for casts to REFERENCE_TYPE and ubsan_maybe_instrument_member_call
- for calls to member functions.
-
-2014-07-31 Marc Glisse <marc.glisse@inria.fr>
-
- PR c++/60517
- * typeck.c (maybe_warn_about_returning_address_of_local): Return
- whether it is returning the address of a local variable.
- (check_return_expr): Return 0 instead of the address of a local
- variable.
-
-2014-07-30 Jason Merrill <jason@redhat.com>
-
- PR lto/53808
- PR c++/61659
- * pt.c (push_template_decl_real): Don't set DECL_COMDAT on friends.
-
-2014-07-30 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/57397
- * pt.c (unify_arity): Add boolean parameter.
- (unify_too_few_arguments): Likewise.
- (type_unification_real): Diagnose correctly insufficient
- arguments in the presence of trailing variadic parameters;
- deducing multiple trailing packs as empty is fine.
-
-2014-07-30 Jason Merrill <jason@redhat.com>
-
- PR c++/61659
- PR c++/61687
- Revert:
- * decl2.c (mark_all_virtuals): New variable.
- (maybe_emit_vtables): Check it instead of flag_devirtualize.
- (cp_write_global_declarations): Set it and give helpful diagnostic
- if it introduces errors.
- * class.c (finish_struct_1): Check it.
-
- PR lto/53808
- PR c++/61659
- * pt.c (push_template_decl_real): Set DECL_COMDAT on templates.
- (check_explicit_specialization): Clear it on specializations.
- * decl.c (duplicate_decls, start_decl): Likewise.
- (grokmethod, grokfndecl): Set DECL_COMDAT on inlines.
- * method.c (implicitly_declare_fn): Set DECL_COMDAT. Determine
- linkage after setting the appropriate flags.
- * tree.c (decl_linkage): Don't check DECL_COMDAT.
- * decl2.c (mark_needed): Mark clones.
- (import_export_decl): Not here.
-
-2014-07-25 Edward Smith-Rowland <3dw4rd@verizon.net>
-
- Implement N4051 - Allow typename in a template template parameter
- * parser.c (cp_parser_type_parameter_key): New funtion;
- (cp_parser_token_is_type_parameter_key): Ditto;
- (cp_parser_type_parameter): Look for type-parameter-key for all versions
- but pedwarn for less than cxx1z.
-
-2014-07-17 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50961
- * call.c (standard_conversion): Use resolve_nondeduced_context
- for type_unknown_p (EXPR) && TREE_CODE (TO) == BOOLEAN_TYPE.
-
-2014-07-17 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/61804
- * parser.c (cp_parser_tokens_start_cast_expression): Return -1
- for '++' and '--'.
-
-2014-07-15 Jason Merrill <jason@redhat.com>
-
- PR c++/61811
- * decl2.c (maybe_emit_vtables): Return true for -fuse-all-virtuals.
-
- PR c++/60848
- PR c++/61723
- * call.c (is_std_init_list): Don't check CLASSTYPE_TEMPLATE_INFO.
- * class.c (finish_struct): Reject invalid definition of
- std::initializer_list.
-
-2014-07-15 Paolo Carlini <paolo.carlini@oracle.com>
-
- * call.c (convert_like_real): Call print_z_candidate and inform only
- if permerror returns true.
-
-2014-07-14 Jan Hubicka <hubicka@ucw.cz>
-
- * class.c (build_clone): Do not clear assembler names of
- templates.
- * decl.c (cp_tree_node_structure): Add TEMPLATE_DECL.
- * cp-objcp-common.c (cp_tree_size): Add TEMPLATE_DECL
- as a special case return sizeof (struct tree_decl_non_common)
- for other decls.
- (cp_common_init_ts): Do not initialize NAMESPACE_DECL;
- initialize TEMPLATE_DECL as MARK_TS_DECL_COMMON.
- * cp/cp-tree.h (tree_template_decl): New structure.
- (cp_tree_node_structure_enum): Add TS_CP_TEMPLATE_DECL.
- (union cp_lang_tree_node): Add template_decl.
- (DECL_TEMPLATE_PARMS, DECL_TEMPLATE_RESULT): Update.
-
-2014-07-14 Jason Merrill <jason@redhat.com>
-
- PR c++/61445
- PR c++/56947
- * pt.c (instantiate_decl): Don't check defer_ok for local class
- members.
-
-2014-07-14 Jakub Jelinek <jakub@redhat.com>
-
- PR middle-end/61294
- * cp-tree.h (LITERAL_ZERO_P): Define.
- * parser.c (cp_parser_parenthesized_expression_list): Add
- want_literal_zero_p argument, if true, for literal zeros
- insert INTEGER_CSTs with LITERAL_ZERO_P flag set.
- (cp_parser_postfix_expression): Adjust
- cp_parser_parenthesized_expression_list caller, handle
- -Wmemset-transposed-args.
- (literal_zeros): New variable.
-
-2014-07-13 Jason Merrill <jason@redhat.com>
-
- PR c++/58511
- * semantics.c (is_instantiation_of_constexpr): Return true for
- defaulted functions, too.
- (explain_invalid_constexpr_fn): Only use
- explain_implicit_non_constexpr if !DECL_DECLARED_CONSTEXPR_P.
- * method.c (explain_implicit_non_constexpr): Pass
- DECL_INHERITED_CTOR_BASE to explain_implicit_non_constexpr.
-
- PR c++/58611
- * decl.c (check_initializer): Don't finish_compound_literal
- on erroneous constexpr init.
-
- PR c++/58612
- * tree.c (bot_replace): Only replace a dummy 'this' parm.
-
- PR c++/60628
- * decl.c (create_array_type_for_decl): Only check for auto once.
-
- PR c++/58636
- * call.c (build_list_conv): Don't try to build a list of references.
-
-2014-07-13 Edward Smith-Rowland <3dw4rd@verizon.net>
-
- PR C++/60209 - Declaration of user-defined literal operator cause error
- * parser.c (cp_parser_operator): Fold treatment of strings
- and user-defined string literals. Use the full string parser.
- (cp_parser_string_literal): Add flag to not look for literal operator.
-
-2014-07-11 Jason Merrill <jason@redhat.com>
-
- PR c++/22434
- PR c++/61288
- * call.c (build_conditional_expr_1): Avoid reading freed memory.
-
-2014-07-11 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/53159
- * call.c (build_user_type_conversion_1): Copy LOOKUP_NO_NARROWING
- into convflags.
- * decl.c (check_initializer): Don't call check_narrowing here,
- set LOOKUP_NO_NARROWING.
- * typeck2.c (digest_init_r): Likewise.
-
-2014-07-10 Jason Merrill <jason@redhat.com>
-
- PR c++/61661
- * semantics.c (reduced_constant_expression_p): Handle CONSTRUCTOR.
-
- PR c++/61659
- PR c++/61687
- * decl2.c (mark_all_virtuals): New variable.
- (maybe_emit_vtables): Check it instead of flag_devirtualize.
- (cp_write_global_declarations): Set it and give helpful diagnostic
- if it introduces errors.
- * class.c (finish_struct_1): Check it.
- * decl.c (grokdeclarator): Clear virtualp after 'virtual auto' error.
-
-2014-07-09 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/60686
- * decl.c (grokdeclarator): Adjust error messages about 'explicit'
- outside class declaration, in friend declaration, and neither on
- constructor nor conversion operator.
-
-2014-07-09 Paolo Carlini <paolo.carlini@oracle.com>
-
- DR 1584
- PR c++/57466
- * pt.c (check_cv_quals_for_unify): Implement resolution, disregard
- cv-qualifiers of function types.
-
-2014-07-09 Andrew Sutton <andrew.n.sutton@gmail.com>
- Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/59361
- * parser.c (cp_parser_tokens_start_cast_expression): Return 0 for
- CPP_ELLIPSIS too.
-
-2014-07-07 Paolo Carlini <paolo.carlini@oracle.com>
-
- * class.c (check_for_override): Wrap the 'final' and 'override'
- keywords in %< and %>.
-
-2014-07-06 Marek Polacek <polacek@redhat.com>
-
- PR c/6940
- * cp-tree.h (DECL_ARRAY_PARAMETER_P): Define.
- * decl.c (grokdeclarator): Set DECL_ARRAY_PARAMETER_P.
- * typeck.c (cxx_sizeof_expr): Warn when using sizeof on an array
- function parameter.
-
-2014-07-02 Paolo Carlini <paolo.carlini@oracle.com>
-
- * pt.c (convert_template_argument): Use inform instead of error in
- three places.
-
-2014-06-30 Edward Smith-Rowland <3dw4rd@verizon.net>
-
- PR c++/58781
- PR c++/60249
- PR c++/59867
- * parser.c (cp_parser_userdef_string_literal): Take a tree
- not a cp_token*.
- (cp_parser_string_literal): Don't hack the token stream.
-
-2014-06-30 Jason Merrill <jason@redhat.com>
-
- PR c++/61659
- PR lto/53808
- * decl2.c (maybe_emit_vtables): Mark all vtable entries if
- devirtualizing.
- * init.c (build_vtbl_address): Don't mark destructor.
- * class.c (finish_struct_1): Add all classes to keyed_classes
- if devirtualizing.
-
- PR c++/61647
- * pt.c (type_dependent_expression_p): Check BASELINK_OPTYPE.
-
- PR c++/61566
- * mangle.c (decl_mangling_context): Look through a TEMPLATE_DECL.
-
- * decl.c (build_ptrmemfunc_type): Don't give a PMF RECORD_TYPE
- TYPE_BINFO or TYPE_LANG_SPECIFIC.
- * cp-tree.h (TYPE_PTRMEMFUNC_FLAG): Use TYPE_LANG_FLAG_2.
- (TYPE_PTRMEMFUNC_P): Don't expect TYPE_LANG_SPECIFIC.
- * typeck.c (build_ptrmemfunc_access_expr): Don't use lookup_member.
- * pt.c (unify): Also check whether the argument is a PMF.
-
-2014-06-30 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/54891
- * parser.c (cp_parser_tokens_start_cast_expression): In C++11
- a '[' can also start a primary-expression.
- (cp_parser_cast_expression): Parse a cast-expression only tentatively
- when cp_parser_tokens_start_cast_expression returns -1.
-
-2014-06-30 Jason Merrill <jason@redhat.com>
-
- PR c++/61539
- * pt.c (unify_one_argument): Type/expression mismatch just causes
- deduction failure.
-
- * semantics.c (simplify_aggr_init_expr): Remove remnants of
- 2014-04-11 change.
-
-2014-06-30 Marek Polacek <polacek@redhat.com>
-
- * cp-gimplify.c (cp_genericize): Don't instrument returns if the
- function has no_sanitize_undefined attribute.
- * decl.c (compute_array_index_type): Don't instrument VLAs if the
- function has no_sanitize_undefined attribute.
-
-2014-06-30 Igor Zamyatin <igor.zamyatin@intel.com>
-
- PR middle-end/57541
- * cp-array-notation.c (expand_sec_reduce_builtin):
- Check that bultin argument is correct.
- * call.c (build_cxx_call): Check for 0 arguments in builtin call.
-
-2014-06-28 Jonathan Wakely <jwakely@redhat.com>
-
- DR 1579
- PR c++/58051
- * typeck.c (check_return_expr): Lookup as an rvalue even when the
- types aren't the same.
-
-2014-06-27 Jason Merrill <jason@redhat.com>
-
- PR c++/61433
- * error.c (dump_template_bindings): Don't tsubst in a clone.
-
-2014-06-27 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/61614
- * semantics.c (finish_compound_literal): Revert r204228.
-
-2014-06-27 Paolo Carlini <paolo.carlini@oracle.com>
-
- * parser.c (cp_parser_compound_literal_p): New.
- (cp_parser_postfix_expression, cp_parser_sizeof_operand): Use it.
-
-2014-06-26 Jason Merrill <jason@redhat.com>
-
- * parser.c (cp_parser_for_init_statement): Change range-for error
- to pedwarn.
-
- N3994 Ranged-based for-loops: The Next Generation
- * parser.c (cp_lexer_nth_token_is): New.
- (cp_parser_for_init_statement): Allow "for (id : init)".
-
-2014-06-26 Teresa Johnson <tejohnson@google.com>
-
- * class.c (dump_class_hierarchy): Use saved dump files.
- (dump_vtable): Ditto.
- (dump_vtt): Ditto.
-
-2014-06-26 Adam Butcher <adam@jessamine.co.uk>
-
- PR c++/61537
- * parser.c (cp_parser_elaborated_type_specifier): Only consider template
- parameter lists outside of function parameter scope.
-
-2014-06-25 Paolo Carlini <paolo.carlini@oracle.com>
-
- DR 178
- PR c++/49132
- * typeck2.c (process_init_constructor_record): Do not complain about
- uninitialized const members, because within aggregate-initialization,
- members without explicit initializers are value-initialized.
-
-2014-06-25 Jakub Jelinek <jakub@redhat.com>
-
- * semantics.c (finish_omp_clauses): Make sure
- OMP_CLAUSE_LINEAR_STEP has correct type.
-
-2014-06-24 Jan Hubicka <hubicka@ucw.cz>
-
- * class.c (check_methods, create_vtable_ptr, determine_key_method,
- add_vcall_offset_vtbl_entries_1): Guard VINDEX checks by
- FUNCTION_DECL check.
- * cp-tree.h (lang_decl_ns): Add ns_using and ns_users.
- (DECL_NAMESPACE_USING, DECL_NAMESPACE_USERS): Use lang_decl_ns.
- (DECL_NAMESPACE_ASSOCIATIONS): Use DECL_INITIAL.
- (DECL_TEMPLATE_INSTANTIATIONS): Use DECL_SIZE_UNIT.
-
-2014-06-24 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/33972
- * decl.c (grokdeclarator): Do not early check for operator-function-id
- as non-function.
-
-2014-06-24 Trevor Saunders <tsaunders@mozilla.com>
-
- * class.c, semantics.c, tree.c, vtable-class-hierarchy.c:
- Adjust.
-
-2014-06-24 Jakub Jelinek <jakub@redhat.com>
-
- * parser.c (cp_parser_omp_for_loop): For
- #pragma omp parallel for simd move lastprivate clause from parallel
- to for rather than simd.
-
-2014-06-23 Paolo Carlini <paolo.carlini@oracle.com>
-
- DR 577
- PR c++/33101
- * decl.c (grokparms): Accept a single parameter of type 'void'.
-
-2014-06-20 Jason Merrill <jason@redhat.com>
-
- PR c++/59296
- * call.c (add_function_candidate): Avoid special 'this' handling
- if we have a ref-qualifier.
-
- PR c++/61556
- * call.c (build_over_call): Call build_this in template path.
-
-2014-06-19 Jason Merrill <jason@redhat.com>
-
- PR c++/59296
- * call.c (add_function_candidate): Also set LOOKUP_NO_TEMP_BIND.
-
-2014-06-18 Jason Merrill <jason@redhat.com>
-
- PR c++/59296
- * call.c (add_function_candidate): Set LOOKUP_NO_RVAL_BIND for
- ref-qualifier handling.
-
- PR c++/61507
- * pt.c (resolve_overloaded_unification): Preserve
- ARGUMENT_PACK_EXPLICIT_ARGS.
-
-2014-06-18 Jakub Jelinek <jakub@redhat.com>
-
- * cp-gimplify.c (cxx_omp_finish_clause): Add a gimple_seq *
- argument.
- * cp-tree.h (cxx_omp_finish_clause): Adjust prototype.
-
-2014-06-17 Jason Merrill <jason@redhat.com>
-
- PR c++/60605
- * pt.c (check_default_tmpl_args): Check DECL_LOCAL_FUNCTION_P.
-
-2014-06-15 Jason Merrill <jason@redhat.com>
-
- PR c++/61488
- * pt.c (check_valid_ptrmem_cst_expr): Fix for template context.
-
- PR c++/61500
- * tree.c (lvalue_kind): Handle MEMBER_REF and DOTSTAR_EXPR.
-
-2014-06-15 Jan Hubicka <hubicka@ucw.cz>
-
- * decl.c (grokvardecl): Fix pasto in previous patch.
-
-2014-06-15 Jan Hubicka <hubicka@ucw.cz>
-
- * decl.c (duplicate_decls): Use set_decl_tls_model.
- (grokdeclarator): Likewise.
- * semantics.c (finish_id_expression): Check TLS only for
- static variables.
- (finish_omp_threadprivate): Use decl_default_tls_model.
- * decl2.c (get_guard): Likewise.
- * call.c (make_temporary_var_for_ref_to_temp): Likewise.
-
-2014-06-14 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/33101
- * decl.c (grokparms): Improve error message about void parameters.
- * error.c (type_to_string): Fix aka cut off code.
-
-2014-06-12 Jason Merrill <jason@redhat.com>
-
- * call.c (convert_arg_to_ellipsis): Use abi_version_crosses.
- * cvt.c (type_promotes_to): Likewise.
- * mangle.c (write_type, write_expression): Likewise.
- (write_name, write_template_arg): Likewise.
- (mangle_decl): Make alias based on flag_abi_compat_version.
- Emit -Wabi warning here.
- (finish_mangling_internal): Not here. Drop warn parm.
- (finish_mangling_get_identifier, finish_mangling): Adjust.
- (mangle_type_string, mangle_special_for_type): Adjust.
- (mangle_ctor_vtbl_for_type, mangle_thunk): Adjust.
- (mangle_guard_variable, mangle_tls_init_fn): Adjust.
- (mangle_tls_wrapper_fn, mangle_ref_init_variable): Adjust.
-
- * call.c (build_operator_new_call): Remove -fabi-version=1 support.
- * class.c (walk_subobject_offsets, include_empty_classes): Likewise.
- (layout_nonempty_base_or_field, end_of_class): Likewise.
- (layout_empty_base, build_base_field, layout_class_type): Likewise.
- (is_empty_class, add_vcall_offset_vtbl_entries_1): Likewise.
- (layout_virtual_bases): Likewise.
- * decl.c (compute_array_index_type): Likewise.
- * mangle.c (write_mangled_name, write_prefix): Likewise.
- (write_template_prefix, write_integer_cst, write_expression): Likewise.
- (write_template_arg, write_array_type): Likewise.
- * method.c (lazily_declare_fn): Likewise.
- * rtti.c (get_pseudo_ti_index): Likewise.
- * typeck.c (comp_array_types): Likewise.
-
-2014-06-11 Jan Hubicka <hubicka@ucw.cz>
-
- * vtable-class-hierarchy.c: Update handling for section names
- that are no longer trees.
- * decl.c (duplicate_decls): Likewise.
-
-2014-06-11 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/19200
- * parser.c (cp_parser_init_declarator): Actually pass friend_p
- to cp_parser_declarator.
-
-2014-06-11 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/60265
- * parser.c (cp_parser_using_declaration): Handle unscoped enums.
- * name-lookup.c (validate_nonmember_using_decl): Adjust error
- message.
-
-2014-06-11 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/19200
- * parser.c (cp_parser_declarator): Add bool parameter.
- (cp_parser_direct_declarator): Likewise, use it.
- (cp_parser_member_declaration): Pass friend_p to cp_parser_declarator.
- (cp_parser_condition, cp_parser_explicit_instantiation,
- cp_parser_init_declarator, cp_parser_type_id_1,
- cp_parser_parameter_declaration, cp_parser_exception_declaration,
- cp_parser_cache_defarg, cp_parser_objc_class_ivars,
- cp_parser_objc_struct_declaration, cp_parser_omp_for_loop_init):
- Adjust.
- * decl.c (grokdeclarator): Fix handling of friend declared in
- namespace scope (g++.dg/parse/friend10.C).
-
-2014-06-10 Jan Hubicka <hubicka@ucw.cz>
-
- * vtable-class-hierarchy.c: Use symtab_get_node (var_decl)
- ->implicit_section.
- * optimize.c (cdtor_comdat_group): Fix handling of aliases.
- (maybe_clone_body): Move symbol across comdat groups.
- * method.c (use_thunk): Copy implicit section flag.
-
-2014-06-09 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/22556
- * name-lookup.c (pushdecl_maybe_friend_1): Use comptypes.
-
-2014-06-07 Jan Hubicka <hubicka@ucw.cz>
-
- * method.c (use_thunk): Use set_decl_section_name.
- * optimize.c (maybe_clone_body): Use set_decl_section_name.
- * decl.c (duplicate_decls): Likewise.
- * vtable-class-hierarchy.c: Likewise.
-
-2014-06-06 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/60184
- * class.c (check_field_decls): In C++11 mode do not reject
- static data members and reference-type members in unions.
-
-2014-06-05 Jason Merrill <jason@redhat.com>
-
- PR c++/43453
- * decl.c (check_initializer): Collapse a TREE_LIST here.
- * typeck2.c (store_init_value): Not here.
-
-2014-06-05 Richard Biener <rguenther@suse.de>
- Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/56961
- * cp-gimplify.c (cp_gimplify_expr, [MODIFY_EXPR]): Rework
- handling of empty classes.
-
-2014-06-04 Jason Merrill <jason@redhat.com>
-
- * parser.c (cp_parser_diagnose_invalid_type_name): Give helpful note
- for noexcept and thread_local, too.
-
- PR c++/61343
- * decl.c (check_initializer): Maybe clear
- DECL_INITIALIZED_BY_CONSTANT_EXPRESSION_P.
-
-2014-06-05 Richard Biener <rguenther@suse.de>
-
- PR c++/61004
- * typeck.c (cp_build_indirect_ref): Do not emit strict-aliasing
- warnings for accessing empty classes.
-
-2014-06-05 Marek Polacek <polacek@redhat.com>
-
- PR c/49706
- * parser.c (cp_parser_binary_expression): Warn when logical not is
- used on the left hand side operand of a comparison.
-
-2014-06-04 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/43453
- * typeck.c (cp_build_modify_expr): Handle array of characters
- initialized by a string literal.
- * decl.c (check_initializer): Handle parenthesized string literal
- as initializer.
- * typeck2.c (store_init_value): Remove redundant check.
-
-2014-06-04 Jason Merrill <jason@redhat.com>
-
- PR c++/51253
- PR c++/61382
- * cp-gimplify.c (cp_gimplify_expr): Handle CALL_EXPR_LIST_INIT_P here.
- * semantics.c (simplify_aggr_init_expr): Not here, just copy it.
-
-2014-06-04 Igor Zamyatin <igor.zamyatin@intel.com>
-
- PR c/58942
- * cp-array-notation.c (expand_sec_reduce_builtin): Handle the case
- with a pointer.
-
-2014-06-03 Paolo Carlini <paolo.carlini@oracle.com>
-
- DR 1423
- PR c++/52174
- * call.c (standard_conversion): Convert nullptr to bool only
- in case of direct-initialization.
- (convert_like_real): Provide informative error message.
-
-2014-06-03 Marek Polacek <polacek@redhat.com>
-
- PR c/60439
- * semantics.c (finish_switch_cond): Warn if switch condition has
- boolean value.
-
-2014-06-03 Jason Merrill <jason@redhat.com>
-
- PR c++/60992
- * pt.c (tsubst_copy) [VAR_DECL]: Try lookup first. Add a new
- variable to local_specializations.
-
- PR c++/60848
- * call.c (is_std_init_list): Check CLASSTYPE_TEMPLATE_INFO.
-
-2014-06-02 Jason Merrill <jason@redhat.com>
-
- PR c++/61046
- * decl.c (reshape_init_class): Handle un-folded
- constant-expressions.
-
- PR c++/61134
- * pt.c (pack_deducible_p): Handle canonicalization.
-
-2014-06-02 Paolo Carlini <paolo.carlini@oracle.com>
-
- * pt.c (tsubst_function_type): Initialize arg_types.
-
-2014-06-02 Siva Chandra Reddy <sivachandra@google.com>
-
- PR debug/57519
- * class.c (handle_using_decl): Pass the correct scope to
- cp_emit_debug_info_for_using.
-
-2014-06-02 Ville Voutilainen <ville.voutilainen@gmail.com>
-
- PR c++/59483
- PR c++/61148
- * search.c (accessible_p): Use current_nonlambda_class_type.
- * semantics.c (check_accessibility_of_qualified_id): Likewise.
-
-2014-06-02 Andrew MacLeod <amacleod@redhat.com>
-
- * decl.c: Include builtins.h.
- * semantics.c: Likewise.
-
-2014-05-31 Paolo Carlini <paolo.carlini@oracle.com>
-
- DR 1227
- PR c++/57543
- * cp-tree.h (TYPE_HAS_LATE_RETURN_TYPE): Add.
- * pt.c (tsubst_function_type): Inject the this parameter; do the
- substitutions in the order mandated by the DR.
- (copy_default_args_to_explicit_spec): Copy TYPE_HAS_LATE_RETURN_TYPE.
- * decl.c (grokdeclarator): Maybe set TYPE_HAS_LATE_RETURN_TYPE.
- (static_fn_type): Copy it.
- * decl2.c (build_memfn_type, change_return_type,
- cp_reconstruct_complex_type): Likewise.
- * parser.c (cp_parser_lambda_declarator_opt): Likewise.
- * tree.c (strip_typedefs): Likewise.
- * typeck.c (merge_types): Likewise.
-
-2014-05-30 Jason Merrill <jason@redhat.com>
-
- PR c++/56947
- * pt.c (instantiate_decl): Check that defer_ok is not set for
- local class members.
-
- PR c++/60992
- * pt.c (tsubst_init): Split out from...
- (tsubst_expr) [DECL_EXPR]: Here.
- (tsubst_copy) [VAR_DECL]: Use it.
- * semantics.c (finish_id_expression): Return the decl for static/const.
-
-2014-05-28 Jason Merrill <jason@redhat.com>
-
- PR c++/47202
- * decl.c (cxx_comdat_group): Return a decl.
- * optimize.c (cdtor_comdat_group): Get its DECL_ASSEMBLER_NAME.
-
- * pt.c (tsubst) [ARRAY_TYPE]: Check for array of array of unknown
- bound.
-
- PR c++/61242
- * call.c (build_aggr_conv): Ignore passed in flags.
- (build_array_conv, build_complex_conv): Likewise.
-
-2014-05-23 Jan Hubicka <hubicka@ucw.cz>
-
- * optimize.c (maybe_thunk_body): Use set_comdat_group.
- (maybe_clone_body): Likewise.
- * decl.c (duplicate_decls): Update code duplicating comdat group;
- do not copy symtab pointer; before freeing newdecl remove it
- from symtab.
- * decl2.c (constrain_visibility): Use set_comdat_group.
-
-2014-05-23 Jan Hubicka <hubicka@ucw.cz>
-
- * rtti.c: Include tm_p.h
- (emit_tinfo_decl): Force RTTI data to be aligned to required
- ABI alignment only.
-
-2014-05-23 Jan Hubicka <hubicka@ucw.cz>
-
- * class.c (build_vtable): Align vtables to TARGET_VTABLE_ENTRY_ALIGN
- ignoring other target adjustments.
-
-2014-05-23 Thomas Schwinge <thomas@codesourcery.com>
-
- * semantics.c (finish_omp_clauses): Remove duplicated variable
- initialization.
-
- * parser.c (cp_parser_omp_target): Return bool values.
-
-2014-05-22 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/61088
- * lambda.c (add_capture): Enforce that capture by value requires
- complete type.
- * typeck2.c (cxx_incomplete_type_inform): Early return if
- TYPE_MAIN_DECL is null.
-
-2014-05-21 Jonathan Wakely <jwakely@redhat.com>
-
- PR c/61271
- * cp-array-notation.c (cilkplus_an_triplet_types_ok_p): Fix condition.
-
-2014-05-21 Ville Voutilainen <ville.voutilainen@gmail.com>
-
- PR c++/61133
- * lambda.c (build_capture_proxy, add_capture): Treat normal
- captures and init-captures identically.
-
-2014-05-21 Mark Wielaard <mjw@redhat.com>
-
- PR debug/16063
- * cp-lang.c (cxx_enum_underlying_base_type): New function.
- (LANG_HOOKS_ENUM_UNDERLYING_BASE_TYPE): Define.
-
-2014-05-21 Richard Sandiford <rsandifo@linux.vnet.ibm.com>
-
- * cvt.c (convert_to_void): Use void_node instead of void_zero_node.
- * cp-array-notation.c (replace_invariant_exprs): Likewise.
- (expand_array_notation): Handle VOID_CST.
- * error.c (dump_expr): Likewise.
- * cxx-pretty-print.c (cxx_pretty_printer::primary_expression)
- (cxx_pretty_printer::expression): Likewise.
- (pp_cxx_new_expression): Use void_node instead of void_zero_node.
- * decl.c (register_dtor_fn): Likewise.
- * init.c (build_raw_new_expr, build_new_1, build_vec_init)
- (build_delete, push_base_cleanups): Likewise.
- * mangle.c (write_expression): Likewise.
- * semantics.c (finish_break_stmt, empty_expr_stmt_p): Likewise.
- * pt.c (tsubst_decl, tsubst_copy_and_build): Likewise.
- (tsubst, tsubst_copy, build_non_dependent_expr): Handle VOID_CST.
- * tree.c (cp_tree_equal): Likewise.
- (build_dummy_object, is_dummy_object, stabilize_expr): Use void_node
- instead of void_zero_node.
- * typeck.c (check_return_expr): Likewise.
- * typeck2.c (build_functional_cast): Likewise.
-
-2014-05-21 Igor Zamyatin <igor.zamyatin@intel.com>
-
- PR c/60189
- * parser.c (cp_parser_postfix_expression): Move handling of cilk_sync
- from here to...
- (cp_parser_statement): ...here. Make sure only semicolon can go after
- Cilk_sync.
-
-2014-05-20 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/58753
- PR c++/58930
- PR c++/58704
- * typeck2.c (digest_nsdmi_init): New.
- * parser.c (cp_parser_late_parse_one_default_arg): Use it.
- * init.c (get_nsdmi): Likewise.
- * cp-tree.h (digest_nsdmi_init): Declare.
-
-2014-05-20 Jason Merrill <jason@redhat.com>
-
- * typeck.c (get_member_function_from_ptrfunc): Don't try to look
- up a virtual function in a dummy object.
-
-2014-05-20 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/60373
- * decl.c (duplicate_decls): Replace pair of warning_at with
- warning_at + inform.
- (maybe_commonize_var): Likewise.
-
-2014-05-20 Richard Sandiford <rsandifo@linux.vnet.ibm.com>
-
- PR bootstrap/61210
- * pt.c (tsubst_copy, tsubst_omp_for_iterator, tsubst_expr)
- (tsubst_copy_and_build): Perform recursive substitutions in a
- deterministic order.
-
-2014-05-20 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/58664
- * typeck2.c (cxx_incomplete_type_inform): New.
- (cxx_incomplete_type_diagnostic): Use it.
- * decl.c (grokdeclarator): Check the element type of an
- incomplete array type; call the above.
- * cp-tree.h (cxx_incomplete_type_inform): Declare.
-
-2014-05-19 Jason Merrill <jason@redhat.com>
-
- PR c++/58761
- * pt.c (tsubst_copy): Don't check at_function_scope_p.
- (instantiate_class_template_1): Don't push_to_top_level in an nsdmi.
-
-2014-05-19 Paolo Carlini <paolo.carlini@oracle.com>
-
- * typeck2.c (cxx_incomplete_type_diagnostic): Use inform.
- * parser.c (cp_parser_enum_specifier): Likewise.
-
-2014-05-17 Trevor Saunders <tsaunders@mozilla.com>
-
- * class.c (sorted_fields_type_new): Adjust.
- * cp-cilkplus.c (cilk_install_body_with_frame_cleanup): Likewise.
- * cp-objcp-common.c (decl_shadowed_for_var_insert): Likewise.
- * cp-tree.h: Remove usage of variable_size gty attribute.
- * decl.c (make_label_decl): Adjust.
- (check_goto): Likewise.
- (start_preparsed_function): Likewise.
- (save_function_data): Likewise.
- * lex.c (init_reswords): Likewise.
- (retrofit_lang_decl): Likewise.
- (cxx_dup_lang_specific_decl): Likewise.
- (copy_lang_type): Likewise.
- (cxx_make_type): Likewise.
- * name-lookup.c (binding_entry_make): Likewise.
- (binding_table_construct): Likewise.
- (binding_table_new): Likewise.
- (cxx_binding_make): Likewise.
- (pushdecl_maybe_friend_1): Likewise.
- (begin_scope): Likewise.
- (push_to_top_level): Likewise.
- * parser.c (cp_lexer_alloc): Likewise.
- (cp_lexer_new_from_tokens): Likewise.
- (cp_token_cache_new): Likewise.
- (cp_parser_context_new): Likewise.
- (cp_parser_new): Likewise.
- (cp_parser_nested_name_specifier_opt): Likewise.
- (cp_parser_template_id): Likewise.
- * pt.c (maybe_process_partial_specialization): Likewise.
- (register_specialization): Likewise.
- (add_pending_template): Likewise.
- (lookup_template_class_1): Likewise.
- (push_tinst_level): Likewise.
- * semantics.c (register_constexpr_fundef): Likewise.
- (cxx_eval_call_expression): Likewise.
- * typeck2.c (abstract_virtuals_error_sfinae): Likewise.
-
-2014-05-16 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51640
- * parser.c (cp_parser_diagnose_invalid_type_name): Early return
- when cp_parser_lookup_name sets ambiguous_decls.
-
-2014-05-15 Jason Merrill <jason@redhat.com>
-
- * call.c (print_conversion_rejection): Use loc consistently.
-
-2014-05-14 Paolo Carlini <paolo.carlini@oracle.com>
-
- * cp-tree.h (DIRECT_LIST_INIT_P): Add.
- * call.c (convert_like_real, build_new_method_call_1): Use it.
- * decl2.c (grokfield): Likewise.
- * init.c (perform_member_init, build_aggr_init, expand_default_init,
- build_new_1): Likewise.
- * mangle.c (write_expression): Likewise.
- * parser.c (cp_parser_late_parse_one_default_arg): Likewise.
-
-2014-05-14 Jason Merrill <jason@redhat.com>
-
- PR c++/20332
- PR c++/21631
- * call.c (reference_binding): Treat lvalue/rvalue mismatch and
- dropped cv-quals as a bad conversion.
- (convert_like_real) [ck_ref_bind]: Explain them.
- (compare_ics): Check badness before stripping reference
- bindings. Handle comparing bad reference bindings.
- * typeck.c (comp_cv_qualification): Add overload that just takes
- integers.
- * cp-tree.h: Declare it.
-
- * call.c (struct conversion_info): Rename 'from_type' to 'from'.
- (arg_conversion_rejection, bad_arg_conversion_rejection)
- (explicit_conversion_rejection, template_conversion_rejection): Adjust.
- (add_function_candidate): Pass actual argument, rather than type, to
- bad_arg_conversion_rejection.
- (print_conversion_rejection): Explain what's wrong with the conversion.
- (print_z_candidates): Say "candidate:" before each candidate.
- (splice_viable): Be strict if we see a viable or template candidate.
- (build_user_type_conversion_1): Pass false to strict parameter.
- (perform_overload_resolution, build_conditional_expr_1): Likewise.
- (build_new_op_1, build_new_method_call_1): Likewise.
- (build_op_call_1): Pass true to strict parameter.
-
-2014-05-13 Jason Merrill <jason@redhat.com>
-
- * call.c (print_error_for_call_failure): Say "no match" rather
- than "ambiguous" if there were no strict matches.
- (build_new_method_call_1): Likewise.
-
- PR c++/61151
- * semantics.c (is_this_parameter): Allow capture proxies too.
-
-2014-05-12 Jason Merrill <jason@redhat.com>
-
- * call.c (maybe_print_user_conv_context): New.
- (convert_like_real): Use it. Print call context for bad
- user-defined conversion.
- (build_over_call): Print call context for bad 'this' conversion.
-
- * call.c (convert_like_real): Use inform for identifying the
- declaration point.
-
-2014-05-12 Paolo Carlini <paolo.carlini@oracle.com>
-
- * cvt.c (cp_convert_to_pointer): Don't call error_at if
- complain & tf_error is false.
-
- * decl.c (make_unbound_class_template): Prefer inform for
- "declared here"-type message.
-
-2014-05-09 Momchil Velikov <momchil.velikov@gmail.com>
-
- PR c++/60463
- PR c++/60755
- * lambda.c (lambda_expr_this_capture): Add new parameter
- add_capture_p controlling whether the functions will try to
- capture 'this' via the default capture.
- (maybe_resolve_dummy): Likewise.
- * cp-tree.h: Adjust prototypes.
- * call.c, semantics.c: Change callers of these functions.
- * call.c (build_new_method_call_1): Use the actual 'this' that
- would be potentially captured for the overload resolution, instead
- of the dummy object.
-
-2014-05-09 Paolo Carlini <paolo.carlini@oracle.com>
-
- * pt.c (convert_nontype_argument_function): Add tsubst_flags_t
- parameter.
- (convert_nontype_argument): Adjust calls.
- (coerce_template_parameter_pack): Add missing complain & tf_error
- check.
-
-2014-05-09 Jason Merrill <jason@redhat.com>
-
- DR 587
- PR c++/51317
- * call.c (build_conditional_expr_1, conditional_conversion): Handle
- non-class lvalues and xvalues that differ only in cv-qualifiers.
-
- DR 5
- PR c++/60019
- * call.c (build_user_type_conversion_1): The copy-init temporary
- is cv-unqualified.
-
- PR c++/58714
- * tree.c (stabilize_expr): A stabilized prvalue is an xvalue.
-
- PR c++/54348
- * call.c (build_conditional_expr_1): If overload resolution finds
- no match, just say "different types".
-
- PR c++/32019
- * call.c (build_conditional_expr_1): Improve ambiguity diagnostic.
-
- PR c++/22434
- * call.c (build_conditional_expr_1): Don't try to pool cv-quals
- if we didn't find a conversion.
- Don't accept a bad conversion too early.
-
-2014-05-08 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/13981
- * typeck.c (convert_for_assignment): Provide an inform for pointers
- to incomplete class types.
-
-2014-05-07 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/61083
- * pt.c (convert_nontype_argument): Protect all the error calls
- with complain & tf_error.
-
-2014-05-07 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/61080
- * pt.c (instantiate_decl): Avoid generating the body of a
- deleted function.
-
-2014-05-06 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/60999
- * pt.c (maybe_begin_member_template_processing): Use
- uses_template_parms.
-
-2014-05-06 Kenneth Zadeck <zadeck@naturalbridge.com>
- Mike Stump <mikestump@comcast.net>
- Richard Sandiford <rdsandiford@googlemail.com>
-
- * call.c: Include wide-int.h.
- (type_passed_as): Use tree_int_cst_lt instead of INT_CST_LT_UNSIGNED.
- (convert_for_arg_passing): Likewise.
- * class.c: Include wide-int.h.
- (walk_subobject_offsets): Use tree_int_cst_lt instead of INT_CST_LT.
- (end_of_class): Use tree_int_cst_lt instead of INT_CST_LT_UNSIGNED.
- (include_empty_classes): Likewise
- (layout_class_type): Use tree_int_cst_lt instead of INT_CST_LT.
- * cvt.c: Include wide-int.h.
- (ignore_overflows): Use wide_int_to_tree.
- * decl.c: Include wide-int.h.
- (check_array_designated_initializer): Use wide-int interfaces.
- (compute_array_index_type): Use tree_int_cst_lt instead of INT_CST_LT.
- (finish_enum_value_list): Use signop.
- (build_enumerator): Use wide-int interfaces.
- * init.c: Include wide-int.h.
- (build_new_1): Use wide-int interfaces.
- * mangle.c: Include wide-int.h.
- (write_integer_cst): Use wide-int interfaces.
- (write_array_type): Likewise.
- * tree.c: Include wide-int.h.
- (cp_tree_equal): Use tree_int_cst_equal.
- * typeck2.c: Include wide-int.h.
- (process_init_constructor_array): Use wide-int interfaces.
-
-2014-05-03 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/58582
- * decl.c (grokfndecl): Check duplicate_decls return value for
- error_mark_node.
- * pt.c (instantiate_decl): A deleted function is defined.
-
-2014-05-02 Jason Merrill <jason@redhat.com>
-
- * decl2.c (vague_linkage_p): Local statics have vague linkage.
-
- PR c++/60992
- * lambda.c (lambda_capture_field_type): Wrap anything dependent
- other than 'this'.
- (add_capture): Check for VLA before calling it.
- * semantics.c (is_this_parameter): Accept any 'this' parameter, not
- just the current one. Make non-static.
- * cp-tree.h: Declare it.
- * pt.c (tsubst_copy) [VAR_DECL]: Also build a new VAR_DECL if
- the operand was static or constant.
-
-2014-05-02 Marek Polacek <polacek@redhat.com>
-
- * typeck.c (maybe_warn_about_returning_address_of_local): Separate
- warning_at calls.
-
-2014-05-01 Marek Polacek <polacek@redhat.com>
-
- PR c/43395
- * typeck.c (maybe_warn_about_returning_address_of_local): Distinguish
- between label and variable when warning about returning local address.
-
-2014-04-30 Jason Merrill <jason@redhat.com>
-
- PR c++/60980
- * init.c (build_value_init): Don't try to call an array constructor.
-
- PR c++/60951
- * typeck2.c (massage_init_elt): Use maybe_constant_init.
-
-2014-04-30 Marek Polacek <polacek@redhat.com>
-
- * typeck.c (cp_build_binary_op): Call ubsan_instrument_division
- even when SANITIZE_FLOAT_DIVIDE is on. Set doing_div_or_mod even
- for non-integer types.
-
-2014-04-29 Jason Merrill <jason@redhat.com>
-
- DR 1351
- Represent the unevaluated exception specification of an implicitly
- declared or deleted function with a simple placeholder, not a list
- of functions.
- * cp-tree.h (UNEVALUATED_NOEXCEPT_SPEC_P): New.
- * except.c (unevaluated_noexcept_spec): New.
- * class.c (deduce_noexcept_on_destructor): Use it.
- * decl.c (check_redeclaration_exception_specification): Call
- maybe_instantiate_noexcept.
- (duplicate_decls): Call it before merge_types.
- (start_preparsed_function): Call maybe_instantiate_noexcept.
- * decl2.c (mark_used): Call maybe_instantiate_noexcept earlier.
- * init.c (get_nsdmi): Factor out of perform_member_init.
- * method.c (process_subob_fn): Call maybe_instantiate_noexcept.
- (walk_field_subobs): Consider NSDMI for EH spec.
- (get_defaulted_eh_spec): New.
- (implicitly_declare_fn): Use unevaluated_noexcept_spec.
- (defaulted_late_check): Defer EH checking in non-template classes.
- (after_nsdmi_defaulted_late_checks): New.
- * parser.c (cp_parser_class_specifier_1): Use it.
- (unparsed_classes): New macro.
- * parser.h (cp_unparsed_functions_entry_d): Add classes field.
- * pt.c (maybe_instantiate_noexcept): Use get_defaulted_eh_spec.
- Remove list-of-functions handling.
- * typeck2.c (merge_exception_specifiers): Remove list-of-functions
- handling and FN parameter.
- * typeck.c (merge_types): Adjust.
-
-2014-04-28 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/59120
- * parser.c (cp_parser_alias_declaration): Check return value of
- cp_parser_require.
-
-2014-04-24 Jakub Jelinek <jakub@redhat.com>
-
- * parser.c (cp_parser_omp_atomic): Allow seq_cst before
- atomic-clause, allow comma in between atomic-clause and
- seq_cst.
-
-2014-04-24 Marc Glisse <marc.glisse@inria.fr>
-
- PR libstdc++/43622
- * rtti.c (emit_support_tinfos): Do not iterate on
- registered_builtin_types (partial revert).
-
-2014-04-23 Dinar Temirbulatov <dtemirbulatov@gmail.com>
-
- PR c++/57958
- * semantics.c (apply_deduced_return_type): Complete non-void type
- before estimating whether the type is aggregate.
-
-2014-04-22 Marc Glisse <marc.glisse@inria.fr>
-
- PR libstdc++/43622
- * rtti.c (emit_support_tinfo_1): New function, extracted from
- emit_support_tinfos.
- (emit_support_tinfos): Call it and iterate on registered_builtin_types.
-
-2014-04-22 Jakub Jelinek <jakub@redhat.com>
-
- PR c/59073
- * parser.c (cp_parser_omp_parallel): If cp_parser_omp_for
- fails, don't set OM_PARALLEL_COMBINED and return NULL.
-
-2014-04-18 Jason Merrill <jason@redhat.com>
-
- DR 1571
- * call.c (reference_binding): Recurse on user-defined conversion.
-
- PR c++/60872
- * call.c (standard_conversion): Don't try to apply restrict to void.
-
-2014-04-16 Marc Glisse <marc.glisse@inria.fr>
-
- * decl.c (reshape_init_r): Handle a single element of vector type.
-
-2014-04-16 Patrick Palka <patrick@parcs.ath.cx>
-
- PR c++/60765
- * decl2.c (cplus_decl_attributes): Handle
- pointer-to-member-function declarations.
-
-2014-04-16 Patrick Palka <patrick@parcs.ath.cx>
-
- PR c++/60764
- * call.c (build_user_type_coversion): Use build_dummy_object
- to create the placeholder object for a constructor method call.
- (build_special_member_call): Likewise.
- (build_over_call): Check for the placeholder object with
- is_dummy_object.
- (build_new_method_call_1): Likewise. Don't attempt to resolve
- a dummy object for a constructor method call.
-
-2014-04-16 Paul Pluzhnikov <ppluzhnikov@google.com>
-
- PR c++/59295
- * friend.c (add_friend, make_friend_class): Move repeated friend
- warning under Wredundant_decls.
-
-2014-04-15 Paolo Carlini <paolo.carlini@oracle.com>
-
- * decl.c (duplicate_decls): Remove redundant TYPE_NAME use.
- * name-lookup.c (pushdecl_maybe_friend_1): Likewise.
- (do_class_using_decl): Likewise.
- * mangle.c (dump_substitution_candidates): Use TYPE_NAME_STRING.
-
-2014-04-15 Jakub Jelinek <jakub@redhat.com>
-
- PR plugins/59335
- * Make-lang.h (CP_PLUGIN_HEADERS): Add type-utils.h.
-
-2014-04-14 Paolo Carlini <paolo.carlini@oracle.com>
-
- * cp-tree.h (TYPE_IDENTIFIER): Remove declaration.
-
-2014-04-14 Paolo Carlini <paolo.carlini@oracle.com>
-
- * pt.c (mark_template_parm): Use template_parm_level_and_index.
-
-2014-04-11 Jason Merrill <jason@redhat.com>
-
- * parser.h (struct cp_token): Rename ambiguous_p to error_reported.
- * parser.c: Adjust.
- (cp_lexer_get_preprocessor_token): Always clear it.
- (cp_parser_lambda_expression): Use it to avoid duplicate diagnostics.
-
- DR 1467
- PR c++/51747
- * decl.c (reshape_init_r): Handle a single element of class type.
-
- DR 1338
- * decl.c (cxx_init_decl_processing): Set DECL_IS_MALLOC on
- built-in operator new.
-
-2014-04-11 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/58600
- * name-lookup.c (parse_using_directive): Return early if the
- attribs argument is error_mark_node; use get_attribute_name.
-
-2014-04-11 Jason Merrill <jason@redhat.com>
-
- DR 1030
- PR c++/51253
- * cp-tree.h (CALL_EXPR_LIST_INIT_P): New.
- * call.c (struct z_candidate): Add flags field.
- (add_candidate): Add flags parm.
- (add_function_candidate, add_conv_candidate, build_builtin_candidate)
- (add_template_candidate_real): Pass it.
- (build_over_call): Set CALL_EXPR_LIST_INIT_P.
- * tree.c (build_aggr_init_expr): Copy it.
- * semantics.c (simplify_aggr_init_expr): Preevaluate args if it's set.
-
-2014-04-10 Richard Biener <rguenther@suse.de>
- Jakub Jelinek <jakub@redhat.com>
-
- PR ipa/60761
- * error.c (dump_decl) <case FUNCTION_DECL>: If
- DECL_LANG_SPECIFIC is NULL, but DECL_ABSTRACT_ORIGIN is not,
- recurse on DECL_ABSTRACT_ORIGIN instead of printing
- <built-in>.
-
-2014-04-09 Fabien Chêne <fabien@gcc.gnu.org>
-
- * pt.c (check_template_variable): Check for the return of pedwarn
- before emitting a note.
- * parser.c (cp_parser_lambda_introducer): Likewise.
-
-2014-04-08 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/59115
- * pt.c (process_template_parm): For an invalid non-type parameter
- only set TREE_TYPE to error_mark_node.
- (push_inline_template_parms_recursive, comp_template_parms,
- redeclare_class_template, coerce_template_template_parm,
- coerce_template_template_parms, unify): Use error_operand_p.
-
-2014-04-08 Nathan Sidwell <nathan@codesourcery.com>
-
- * class.c (check_bases_and_members): Warn about non-virtual dtors
- in public bases only. Check warn_ecpp before complaining about
- non-polymorphic bases.
-
-2014-04-04 Fabien Chêne <fabien@gcc.gnu.org>
-
- * decl.c (duplicate_decls): Check for the return of warning_at
- before emitting a note.
- (warn_misplaced_attr_for_class_type): Likewise.
- (check_tag_decl): Likewise.
-
-2014-04-04 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/58207
- * semantics.c (sort_constexpr_mem_initializers): Robustify loop.
-
-2014-04-04 Patrick Palka <patrick@parcs.ath.cx>
-
- PR c++/44613
- * semantics.c (add_stmt): Set STATEMENT_LIST_HAS_LABEL.
- * decl.c (cp_finish_decl): Create a new BIND_EXPR before
- instantiating a variable-sized type.
-
- PR c++/21113
- * decl.c (decl_jump_unsafe): Consider variably-modified decls.
-
-2014-04-04 Fabien Chêne <fabien@gcc.gnu.org>
-
- * class.c (find_abi_tags_r): Check for the return of warning
- before emitting a note.
- (one_inherited_ctor): Likewise.
-
-2014-04-04 Fabien Chêne <fabien@gcc.gnu.org>
-
- * decl.c (duplicate_decls): Check for the return of permerror
- before emitting a note.
-
-2014-04-03 Nathan Sidwell <nathan@codesourcery.com>
-
- * class.c (accessible_nvdtor_p): New.
- (check_bases): Don't check base destructor here ...
- (check_bases_and_members): ... check them here. Trigger on
- Wnon-virtual-dtor flag.
- (finish_struct_1): Use accessible_nvdtor_p.
-
-2014-04-01 Jason Merrill <jason@redhat.com>
-
- * pt.c (process_partial_specialization): Say "not deducible"
- rather than "not used". Use inform.
-
- PR c++/60374
- * pt.c (coerce_template_parms): Check that the pack expansion
- pattern works with the first matching parameter.
-
-2014-04-01 Fabien Chêne <fabien@gcc.gnu.org>
-
- * init.c (perform_member_init): Homogenize uninitialized
- diagnostics.
-
-2014-04-01 Jason Merrill <jason@redhat.com>
-
- PR c++/60708
- * call.c (build_array_conv): Call complete_type.
-
- PR c++/60713
- * typeck2.c (PICFLAG_SIDE_EFFECTS): New.
- (picflag_from_initializer): Return it.
- (process_init_constructor): Handle it.
-
- PR c++/60642
- * decl2.c (is_late_template_attribute): Don't defer abi_tag.
- * mangle.c (write_unqualified_name): Fix abi_tag on templates.
- * pt.c (get_template_info): Handle NAMESPACE_DECL.
- (most_general_template): Handle more kinds of template.
- * tree.c (handle_abi_tag_attribute): Ignore abi_tag on template
- instantiations and specializations.
-
-2014-03-31 Patrick Palka <patrick@parcs.ath.cx>
-
- PR c++/44859
- * typeck.c (maybe_warn_about_returning_address_of_local): Unwrap
- COMPONENT_REFs and ARRAY_REFs sooner.
-
-2014-03-29 Adam Butcher <adam@jessamine.co.uk>
-
- PR c++/60626
- * parser.c (cp_parser_init_declarator): Handle erroneous generic type
- usage in non-functions with pushed scope.
-
-2014-03-28 Adam Butcher <adam@jessamine.co.uk>
-
- PR c++/60573
- * name-lookup.h (cp_binding_level): New transient field defining_class_p
- to indicate whether a scope is in the process of defining a class.
- * semantics.c (begin_class_definition): Set defining_class_p.
- * name-lookup.c (leave_scope): Reset defining_class_p.
- * parser.c (synthesize_implicit_template_parm): Use cp_binding_level::
- defining_class_p rather than TYPE_BEING_DEFINED as the predicate for
- unwinding to class-defining scope to handle the erroneous definition of
- a generic function of an arbitrarily nested class within an enclosing
- class.
-
-2014-03-26 Fabien Chêne <fabien@gcc.gnu.org>
-
- PR c++/52369
- * method.c (walk_field_subobs): Improve the diagnostic
- locations for both REFERENCE_TYPEs and non-static const members.
- * init.c (diagnose_uninitialized_cst_or_ref_member): Use %q#D
- instead of %qD to be consistent with the c++11 diagnostic.
-
-2014-03-25 Jason Merrill <jason@redhat.com>
-
- PR c++/60566
- PR c++/58678
- * class.c (build_vtbl_initializer): Handle abstract dtors here.
- * search.c (get_pure_virtuals): Not here.
-
- PR c++/60375
- * parser.c (cp_parser_lambda_expression): Don't parse the body of
- a lambda in unevaluated context.
-
- PR c++/60628
- * decl.c (create_array_type_for_decl): Complain about array of auto.
-
-2014-03-25 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/60331
- * semantics.c (potential_constant_expression_1): Handle
- DECL_EXPR.
-
-2014-03-24 Adam Butcher <adam@jessamine.co.uk>
-
- PR c++/60627
- * parser.c (cp_parser_parameter_declaration_clause): Prevent 'auto' from
- introducing an implicit function template parameter within an explicit
- instantiation.
-
-2014-03-22 Jason Merrill <jason@redhat.com>
-
- PR c++/60574
- * decl.c (grokdeclarator): Change permerror about 'virtual auto'
- to error.
-
-2014-03-21 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/60384
- * name-lookup.c (push_class_level_binding_1): Check identifier_p
- on the name argument.
-
-2014-03-20 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/60572
- * init.c (build_zero_init_1): Ignore fields with error_mark_node
- type.
-
-2014-03-19 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51474
- * call.c (build_new_method_call_1): Handle pure virtuals called by
- NSDMIs too.
-
-2014-03-17 Adam Butcher <adam@jessamine.co.uk>
-
- PR c++/60390
- * parser.c (cp_parser_member_declaration): Don't allow
- finish_fully_implicit_template to consider friend declarations to be
- class member templates.
- (synthesize_implicit_template_parm): Handling winding back through class
- scope to the class being defined in order to inject a template argument
- list.
-
- PR c++/60391
- * parser.c (cp_parser_skip_to_end_of_block_or_statement): Unwind generic
- function scope as per cp_parser_skip_to_end_of_statement.
-
-2014-03-17 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/59571
- * typeck2.c (check_narrowing): Use fold_non_dependent_expr_sfinae.
-
-2014-03-14 Jason Merrill <jason@redhat.com>
-
- PR c++/60532
- PR c++/58678
- * search.c (get_pure_virtuals): Handle abstract dtor here.
- (dfs_get_pure_virtuals): Not here.
-
- PR c++/58678
- * search.c (dfs_get_pure_virtuals): Treat the destructor of an
- abstract class as pure.
-
-2014-03-13 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/60383
- * pt.c (maybe_process_partial_specialization): Check return value
- of check_specialization_namespace.
-
-2014-03-13 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/60254
- * semantics.c (finish_static_assert): Call cxx_constant_value only
- if require_potential_rvalue_constant_expression returns true.
-
-2014-03-11 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/60389
- * method.c (get_inherited_ctor): New.
- * cp-tree.h (get_inherited_ctor): Declare it.
- * semantics.c (is_valid_constexpr_fn): Use it.
-
-2014-03-10 Jason Merrill <jason@redhat.com>
-
- PR c++/60367
- * call.c (convert_default_arg): Remove special handling for
- CONSTRUCTOR.
-
- PR c++/53492
- * parser.c (cp_parser_class_head): Also check PRIMARY_TEMPLATE_P
- when deciding whether to call push_template_decl for a member class.
- * pt.c (push_template_decl_real): Return after wrong levels error.
-
-2014-03-08 Adam Butcher <adam@jessamine.co.uk>
-
- PR c++/60033
- * pt.c (tsubst_copy): When retrieving a capture pack from a generic
- lambda, remove the lambda's own template argument list prior to fetching
- the specialization.
-
- PR c++/60393
- * parser.c (cp_parser_parameter_declaration_clause): Move generic
- function template unwinding on error into a more general location, ...
- (cp_parser_skip_to_end_of_statement): ... here.
-
-2014-03-07 Jason Merrill <jason@redhat.com>
-
- * Make-lang.in (check_g++_parallelize): Split dg.exp.
-
- * parser.c (cp_parser_type_id_1): Only allow 'auto' in C++1y if
- we're in a trailing return type.
-
- * typeck.c (comp_template_parms_position): 'auto' and
- 'decltype(auto)' are different from real template parms.
-
- * parser.c (cp_parser_using_declaration): Consume the semicolon
- after bare parameter pack error.
-
- * cp-tree.h (REF_PARENTHESIZED_P): New.
- * semantics.c (force_paren_expr): Set it.
- * pt.c (do_auto_deduction): Check it.
- (tsubst) [COMPONENT_REF]: Copy it.
- * typeck.c (maybe_warn_about_useless_cast): Don't strip dereference.
-
- * decl.c (create_array_type_for_decl): Only warn about invalid
- C++1y VLA if flag_iso or warn_vla>0.
- (grokdeclarator): Likewise.
- * pt.c (tsubst): Likewise.
- * semantics.c (finish_decltype_type): Likewise.
- * typeck.c (cxx_sizeof_or_alignof_type): Likewise.
- (cp_build_addr_expr_1): Likewise.
- * init.c (build_new_1): Improve diagnostics.
-
-2014-03-07 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/58609
- * decl.c (check_initializer): Return NULL_TREE after error;
- consistently use inform.
-
-2014-03-07 Paolo Carlini <paolo.carlini@oracle.com>
-
- * decl.c (check_initializer): Remove dead code.
-
-2014-03-06 Marek Polacek <polacek@redhat.com>
-
- PR c/60197
- * typeck.c (check_return_expr): Call contains_cilk_spawn_stmt instead
- of checking tree code.
-
-2014-03-06 Paolo Carlini <paolo.carlini@oracle.com>
-
- * parser.c (cp_lexer_set_source_position): New.
- (cp_parser_mem_initializer): Use it.
- (cp_parser_postfix_open_square_expression): Likewise.
- (cp_parser_parenthesized_expression_list): Likewise.
- (cp_parser_new_initializer): Likewise.
- (cp_parser_jump_statement): Likewise.
- (cp_parser_initializer): Likewise.
- (cp_parser_functional_cast): Likewise.
-
-2014-03-05 Jason Merrill <jason@redhat.com>
-
- PR c++/60409
- * semantics.c (force_paren_expr): Only add a PAREN_EXPR to a
- dependent expression.
-
- PR c++/60361
- * parser.c (cp_parser_template_id): Don't set up a CPP_TEMPLATE_ID
- if re-parsing might succeed.
- * semantics.c (finish_id_expression): Use of a parameter outside
- the function body is a parse error.
-
- * parser.c (cp_parser_mem_initializer): Set input_location
- properly for init-list warning.
- (cp_parser_postfix_open_square_expression): Likewise.
- (cp_parser_parenthesized_expression_list): Likewise.
- (cp_parser_new_initializer): Likewise.
- (cp_parser_jump_statement): Likewise.
- (cp_parser_initializer): Likewise.
- (cp_parser_functional_cast): Likewise.
-
-2014-03-04 Jason Merrill <jason@redhat.com>
-
- PR c++/60417
- * typeck2.c (process_init_constructor_record): Set
- CONSTRUCTOR_IS_DIRECT_INIT on {} for omitted initializers.
-
- PR c++/60415
- PR c++/54359
- * parser.c (cp_parser_direct_declarator): Set declarator to
- cp_error_declarator on invalid qualified-id.
-
-2014-03-04 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/60376
- * parser.c (cp_parser_using_declaration): Early return when
- cp_parser_nested_name_specifier errors out.
-
-2014-03-01 Adam Butcher <adam@jessamine.co.uk>
-
- PR c++/60377
- * parser.c (cp_parser_parameter_declaration_clause): Unwind generic
- function scope on parse error in function parameter list.
-
-2014-03-01 Paolo Carlini <paolo.carlini@oracle.com>
-
- * method.c (implicitly_declare_fn): Remove redundant
- DECL_TEMPLATE_RESULT and STRIP_TEMPLATE uses.
- * semantics.c (is_instantiation_of_constexpr): Likewise.
- * error.c (dump_function_decl): Likewise.
-
-2014-03-01 Jason Merrill <jason@redhat.com>
-
- PR c++/60379
- * semantics.c (begin_maybe_infinite_loop): Use
- fold_non_dependent_expr_sfinae.
-
-2014-02-28 Jason Merrill <jason@redhat.com>
-
- PR c++/58845
- * typeck.c (cp_build_binary_op): Sorry on vector&&vector.
-
-2014-02-28 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/58610
- * cp-tree.h (DECL_DELETED_FN): Use LANG_DECL_FN_CHECK.
- * call.c (print_z_candidate): Remove STRIP_TEMPLATE use.
- * lambda.c (maybe_add_lambda_conv_op): Likewise.
-
-2014-02-27 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/60253
- * call.c (convert_arg_to_ellipsis): Return error_mark_node after
- error_at.
-
-2014-02-27 Jason Merrill <jason@redhat.com>
-
- PR c++/60353
- PR c++/55877
- * decl2.c (tentative_decl_linkage): Don't mess with functions that
- are not yet defined.
-
-2014-02-26 Jason Merrill <jason@redhat.com>
-
- PR c++/60347
- PR lto/53808
- * class.c (clone_function_decl): Don't note_vague_linkage_fn.
- * init.c (build_vtbl_address): Do it here.
-
- PR c++/59231
- PR c++/11586
- PR c++/14710
- PR c++/57132
- * pt.c (struct warning_sentinel): New.
- (tsubst_copy_and_build): Use it instead of
- c_inhibit_evaluation_warnings.
- * typeck.c (maybe_warn_about_useless_cast): Remove
- c_inhibit_evaluation_warnings check.
-
- PR c++/54440
- * pt.c (get_template_parm_index): New.
- (fixed_parameter_pack_p_1, fixed_parameter_pack_p): New.
- (process_template_parm): Allow bare packs in template template
- parm template parms.
- (coerce_template_parameter_pack): Handle fixed template template
- parm packs and fixed packs not at the end of the parm list.
- (coerce_template_parms): Handle template parm packs not at the end
- of the parm list.
- (gen_elem_of_pack_expansion_instantiation): Handle a decl expansion.
-
- PR c++/60182
- * pt.c (unify): Ignore alias templates when deducing a template
- template parameter.
-
- PR c++/60345
- Revert:
- DR 1571
- * call.c (reference_binding): Recurse on user-defined conversion.
- (convert_like_real) [ck_ref_bind]: Explain cv-qual mismatch.
-
-2014-02-25 Jason Merrill <jason@redhat.com>
-
- DR 1571
- * call.c (reference_binding): Recurse on user-defined conversion.
- (convert_like_real) [ck_ref_bind]: Explain cv-qual mismatch.
-
- * call.c (print_conversion_rejection): Handle n_arg of -2.
- (build_user_type_conversion_1): Pass it.
-
- PR c++/55877
- * decl2.c (no_linkage_error): Handle C++98 semantics.
- (reset_type_linkage): Move from decl.c.
- (reset_type_linkage_1, reset_type_linkage_2, bt_reset_linkage_1)
- (bt_reset_linkage_2, reset_decl_linkage): New.
- (tentative_decl_linkage): Factor out of expand_or_defer_fn_1.
- (cp_write_global_declarations): Move condition into no_linkage_error.
- * decl.c (grokfndecl, grokvardecl): Use no_linkage_error.
- * semantics.c (expand_or_defer_fn_1): Factor out
- tentative_decl_linkage.
- * cp-tree.h: Adjust.
-
- * decl2.c (finish_static_data_member_decl): Diagnose static data
- member in unnamed class.
- * class.c (finish_struct_anon_r): Avoid redundant diagnostic.
-
- PR lto/53808
- * class.c (clone_function_decl): Call note_vague_linkage_fn for
- defaulted virtual dtor.
-
- DR 1286
- PR c++/60328
- * pt.c (get_underlying_template): Fix equivalence calculation.
-
-2014-02-25 Adam Butcher <adam@jessamine.co.uk>
-
- PR c++/60311
- * parser.c (function_being_declared_is_template_p): Return false when
- processing a template parameter list.
- (cp_parser_parameter_declaration_clause): Don't set
- auto_is_implicit_function_template_parm_p when processing a
- template parameter list.
-
- * parser.c (synthesize_implicit_template_parm): Inject new template
- argument list appropriately when a generic member function
- of a class template is declared out-of-line.
-
- PR c++/60065
- * parser.c (cp_parser_direct_declarator): Don't save and
- restore num_template_parameter_lists around call to
- cp_parser_parameter_declaration_list.
- (function_being_declared_is_template_p): New predicate.
- (cp_parser_parameter_declaration_list): Use
- function_being_declared_is_template_p as predicate for
- inspecting current function template parameter list length
- rather than num_template_parameter_lists.
-
-2014-02-24 Jason Merrill <jason@redhat.com>
-
- PR c++/60146
- * pt.c (tsubst_omp_for_iterator): Don't let substitution of the
- DECL_EXPR initialize a non-class iterator.
-
- PR c++/60312
- * parser.c (cp_parser_template_type_arg): Check for invalid 'auto'.
-
-2014-02-21 Jason Merrill <jason@redhat.com>
-
- PR c++/58170
- * parser.c (cp_parser_type_name): Always check dependency.
- (cp_parser_type_specifier_seq): Call
- cp_parser_parse_and_diagnose_invalid_type_name.
-
- PR c++/60108
- * semantics.c (expand_or_defer_fn_1): Check DECL_DEFAULTED_FN.
-
- PR c++/60185
- * parser.c (cp_parser_default_argument): Clear
- current_class_ptr/current_class_ref like tsubst_default_argument.
-
- PR c++/60252
- * lambda.c (maybe_resolve_dummy): Check lambda_function rather
- than current_binding_level.
-
- PR c++/60186
- * typeck2.c (massage_init_elt): Call fold_non_dependent_expr_sfinae.
-
- PR c++/60187
- * parser.c (cp_parser_enum_specifier): Call
- check_for_bare_parameter_packs.
-
- PR c++/59347
- * pt.c (tsubst_decl) [TYPE_DECL]: Don't try to instantiate an
- erroneous typedef.
-
- PR c++/60241
- * pt.c (lookup_template_class_1): Update DECL_TEMPLATE_INSTANTIATIONS
- of the partial instantiation, not the most general template.
- (maybe_process_partial_specialization): Reassign everything on
- that list.
-
- PR c++/60216
- * pt.c (register_specialization): Copy DECL_DELETED_FN to clones.
- (check_explicit_specialization): Don't clone.
-
- PR c++/60219
- * pt.c (coerce_template_parms): Bail if argument packing fails.
-
- PR c++/60224
- * decl.c (cp_complete_array_type, maybe_deduce_size_from_array_init):
- Don't get confused by a CONSTRUCTOR that already has a type.
-
- PR c++/60227
- * call.c (build_array_conv): Don't crash on VLA.
-
- PR c++/60248
- * mangle.c (mangle_decl): Don't make an alias for a TYPE_DECL.
-
- PR c++/60252
- * lambda.c (maybe_resolve_dummy): Don't try to capture this
- in declaration context.
-
- DR 1591
- PR c++/60051
- * pt.c (unify): Only unify if deducible. Handle 0-length list.
-
- PR c++/60250
- * parser.c (cp_parser_direct_declarator): Don't wrap a
- type-dependent expression in a NOP_EXPR.
-
- PR c++/60251
- * lambda.c (is_normal_capture_proxy): Handle VLA capture.
-
- PR c++/60167
- PR c++/60222
- PR c++/58606
- * parser.c (cp_parser_template_argument): Restore dereference.
- * pt.c (template_parm_to_arg): Dereference non-pack expansions too.
- (process_partial_specialization): Handle deref.
- (unify): Likewise.
-
-2014-02-21 Adam Butcher <adam@jessamine.co.uk>
-
- PR c++/60052
- PR c++/60053
- * parser.c (cp_parser_parameter_declaration_list): Correctly reset
- implicit_template_scope upon leaving an out-of-line generic member
- function definition.
-
-2014-02-20 Kai Tietz <ktietz@redhat.com>
-
- PR c++/58873
- * parser.c (cp_parser_functional_cast): Treat NULL_TREE
- valued type argument as error_mark_node.
-
- PR c++/58835
- * semantics.c (finish_fname): Handle error_mark_node.
-
-2014-02-19 Jason Merrill <jason@redhat.com>
-
- PR c++/60046
- * pt.c (maybe_instantiate_noexcept): Don't instantiate exception
- spec from template context.
-
-2014-02-19 Jakub Jelinek <jakub@redhat.com>
-
- PR debug/56563
- * cp-objcp-common.c (cp_function_decl_explicit_p): Remove
- FUNCTION_FIRST_USER_PARMTYPE (decl) != void_list_node check.
-
- PR c++/60267
- * pt.c (tsubst_expr): Handle ANNOTATE_EXPR.
-
-2014-02-18 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/60225
- * semantics.c (ensure_literal_type_for_constexpr_object): Use
- strip_array_types.
-
-2014-02-18 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/60215
- * semantics.c (cxx_eval_constant_expression, [COMPONENT_REF]):
- During error recovery allow_non_constant may be false.
-
-2014-02-18 Adam Butcher <adam@jessamine.co.uk>
-
- PR c++/60190
- * parser.c (cp_parser_lambda_declarator_opt): Pop template parameter
- scope whenever a template parameter list has been started, independent
- of whether the function call operator was well-formed or not.
-
- PR c++/60064
- * parser.c (cp_parser_member_declaration): Pop fully implicit template
- scope for generic friend declarations as well as for non-friends.
-
-2014-02-12 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/60047
- * method.c (implicitly_declare_fn): A constructor of a class with
- virtual base classes isn't constexpr (7.1.5p4).
-
-2014-02-05 Jan Hubicka <hubicka@ucw.cz
-
- * parser.c (synthesize_implicit_template_parm): Use grow_tree_vec.
-
-2014-02-05 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/58703
- * parser.c (cp_parser_omp_declare_reduction): Save and free
- declarator_obstack.
-
-2014-02-03 Marc Glisse <marc.glisse@inria.fr>
-
- PR c++/53017
- PR c++/59211
- * tree.c (handle_init_priority_attribute): Call default_conversion on
- the attribute argument.
-
-2014-02-03 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/58871
- * method.c (synthesized_method_walk): If vbases is non-null but
- is_empty is true, likewise don't worry about the virtual bases.
-
-2014-02-01 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51219
- * typeck2.c (process_init_constructor_record): Just skip unnamed
- bit-fields.
-
-2014-01-31 Jason Merrill <jason@redhat.com>
-
- PR c++/59469
- * pt.c (mark_decl_instantiated): Call mark_needed.
-
- PR c++/58672
- * decl2.c (handle_tls_init): Handle null init fn.
-
- PR c++/55800
- * decl2.c (get_tls_init_fn): Copy DECL_EXTERNAL from the variable.
-
-2014-01-31 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/59082
- * class.c (build_vfield_ref): Early return error_mark_node if
- TYPE_VFIELD (type) is null.
- (build_base_path): Check return value of build_vfield_ref.
-
-2014-01-31 Jason Merrill <jason@redhat.com>
-
- PR c++/59646
- * call.c (convert_like_real) [ck_aggr]: Set TARGET_EXPR_LIST_INIT_P.
- [ck_list]: Check for error_mark_node.
- (build_aggr_conv): Set LOOKUP_NO_NARROWING and check_narrowing.
-
- PR c++/57043
- * pt.c (fn_type_unification): Don't do DEDUCE_EXACT check
- during partial ordering.
-
-2014-01-31 Marek Polacek <polacek@redhat.com>
-
- PR c/59963
- * typeck.c (build_function_call_vec): Add dummy arg_loc parameter.
-
-2014-01-30 Jason Merrill <jason@redhat.com>
-
- PR c++/57899
- * cp-tree.h (struct saved_scope): Add x_local_specializations.
- (local_specializations): New macro.
- * pt.c (local_specializations): Remove variable.
-
-2014-01-30 Richard Sandiford <rdsandiford@googlemail.com>
-
- PR c++/58708
- * parser.c (make_string_pack): Use double_int::from_buffer.
-
-2014-01-30 Marek Polacek <polacek@redhat.com>
-
- PR c/59940
- * typeck.c (build_ptrmemfunc1): Call convert_and_check with
- input_location.
- * cvt.c (cp_convert_and_check): Call warnings_for_convert_and_check
- with input_location.
- * call.c (build_conditional_expr_1): Call unsafe_conversion_p with
- loc parameter.
-
-2014-01-30 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/58843
- * typeck.c (lookup_destructor): Check dtor_type for error_mark_node.
-
-2014-01-30 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/58649
- * pt.c (lookup_template_class_1): Check start_enum return value
- for error_mark_node.
-
-2014-01-30 Paolo Carlini <paolo.carlini@oracle.com>
-
- * decl.c (duplicate_decls, typename_hash, typename_compare):
- Use TYPE_IDENTIFIER.
- * error.c (dump_type): Likewise.
- * mangle.c (dump_substitution_candidates): Likewise.
-
-2014-01-30 Jason Merrill <jason@redhat.com>
-
- PR c++/59633
- * decl2.c (attributes_naming_typedef_ok): New.
- * cp-tree.h: Declare it.
- * decl.c (grokdeclarator): Check it.
- * tree.c (no_linkage_check): Handle VECTOR_TYPE.
-
-2014-01-29 Jason Merrill <jason@redhat.com>
-
- PR c++/59707
- * call.c (add_builtin_candidate): Catch dependent types.
-
- PR c++/59989
- * pt.c (expand_template_argument_pack): Correct
- non_default_args_count calculation.
-
- PR c++/58466
- * pt.c (unify_pack_expansion): Call expand_template_argument_pack.
-
- PR c++/59956
- * friend.c (do_friend): Pass the TEMPLATE_DECL to add_friend if we
- have a friend template in a class template.
- * pt.c (tsubst_friend_function): Look through it.
- (push_template_decl_real): A friend member template is
- primary.
-
-2014-01-29 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/58846
- * decl.c (get_dso_handle_node): Don't crash if dso_handle_node
- == error_mark_node.
-
-2014-01-29 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/58674
- * pt.c (instantiate_template_1): Check for error_mark_node the second
- argument too.
-
-2014-01-29 Jason Merrill <jason@redhat.com>
-
- PR c++/59916
- * optimize.c (maybe_thunk_body): Build a RETURN_EXPR for
- cdtor_returns_this case.
-
- PR c++/59315
- * decl.c (cxx_maybe_build_cleanup): Call mark_used.
-
-2014-01-29 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/58702
- * semantics.c (finish_omp_reduction_clause): Check type for
- error_mark_node.
-
-2014-01-28 Jason Merrill <jason@redhat.com>
-
- PR c++/59791
- * pt.c (tsubst_decl) [VAR_DECL]: Allow in unevaluated context.
- (tsubst_copy): Use it if lookup fails.
-
- PR c++/59818
- * pt.c (tsubst_function_type): Make sure we keep the same function
- quals.
-
- PR c++/58701
- * semantics.c (build_anon_member_initialization): Stop walking
- when we run out of COMPONENT_REFs.
-
- PR c++/58632
- * decl.c (lookup_and_check_tag): Ignore template parameters if
- scope == ts_current.
- * pt.c (check_template_shadow): Don't complain about the injected
- class name.
-
- * decl.c (duplicate_decls): Tweak.
-
- PR c++/53756
- * mangle.c (write_unqualified_name): Handle operator auto.
-
-2014-01-27 Jason Merrill <jason@redhat.com>
-
- PR c++/59823
- Core DR 1138
- * call.c (reference_binding): Pass LOOKUP_NO_TEMP_BIND for
- list-initialization. A conversion to rvalue ref that involves
- an lvalue-rvalue conversion is bad.
- (convert_like_real): Give helpful error message.
-
- PR c++/54652
- * decl.c (duplicate_decls): Always use oldtype for TYPE_DECL.
-
- PR c++/58504
- * pt.c (tsubst_copy_and_build) [TRAIT_EXPR]: Use tsubst for
- types.
-
- PR c++/58606
- * pt.c (template_parm_to_arg): Call convert_from_reference.
- (tsubst_template_arg): Don't strip reference refs.
-
- PR c++/58639
- * call.c (build_aggr_conv): Reject value-initialization of reference.
-
- PR c++/58812
- PR c++/58651
- * call.c (convert_like_real): Give helpful error about excess braces
- for ck_rvalue of scalar type.
-
- Core DR 1288
- * call.c (reference_binding): Only elide braces if the single
- element is reference-related.
-
- PR c++/58814
- * typeck.c (cp_build_modify_expr): Make the RHS an rvalue before
- stabilizing.
-
- PR c++/58837
- * typeck.c (cp_truthvalue_conversion): Use explicit comparison for
- FUNCTION_DECL.
-
- PR c++/59097
- * decl.c (compute_array_index_type): Don't call
- maybe_constant_value for a non-integral expression.
-
-2014-01-24 Balaji V. Iyer <balaji.v.iyer@intel.com>
-
- * call.c (magic_varargs_p): Replaced flag_enable_cilkplus with
- flag_cilkplus.
- * cp-gimplify.c (cp_genericize): Likewise.
- * decl.c (grokfndecl): Likewise.
- * parser.c (cp_parser_postfix_expression): Likewise.
- (cp_parser_postfix_open_square_expression): Likewise.
- (cp_parser_direct_declarator): Likewise.
- (is_cilkplus_vector_p): Likewise.
- (cp_parser_omp_clause_name): Likewise.
- (cp_parser_omp_all_clauses): Likewise.
- * pt.c (apply_late_template_attributes): Likewise.
- * typeck.c (cp_build_array_ref): Likewise.
- (cp_build_compound_expr): Likewise.
- (check_return_expr): Likewise.
-
-2014-01-24 Jason Merrill <jason@redhat.com>
-
- PR c++/58550
- * decl.c (grokdeclarator): Turn pedwarn about auto return type in
- c++11 into error.
-
- PR c++/59886
- PR c++/59659
- * typeck2.c (process_init_constructor_array): Don't create
- RANGE_EXPR yet.
-
-2014-01-24 Jakub Jelinek <jakub@redhat.com>
-
- * typeck2.c (split_nonconstant_init_1): Fix num_split_elts
- handling for RANGE_ARRAY case.
-
-2014-01-24 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/57524
- * name-lookup.c (push_using_directive): Use timevar_cond_start.
-
-2014-01-23 Marek Polacek <polacek@redhat.com>
-
- PR c/59846
- * typeck.c (cp_build_binary_op): Pass location to shorten_compare.
-
-2014-01-23 Marek Polacek <polacek@redhat.com>
-
- PR c/58346
- * typeck.c (pointer_diff): Give an error on arithmetic on pointer to
- an empty aggregate.
-
-2014-01-23 Jason Merrill <jason@redhat.com>
-
- PR c++/55189
- * cp-tree.h (struct language_function): Add infinite_loop and
- infinite_loops.
- (current_function_infinite_loop): New.
- * semantics.c (begin_maybe_infinite_loop, end_maybe_infinite_loop)
- (break_maybe_infinite_loop): New.
- (finish_while_stmt_cond, finish_while_stmt, begin_do_stmt)
- (finish_do_stmt, finish_for_cond, finish_for_stmt)
- (begin_range_for_stmt): Use them.
- * decl.c (finish_function): Don't warn about missing return
- if current_function_infinite_loop.
- * pt.c (instantiate_decl): Copy current_function_infinite_loop.
- * parser.c (cp_parser_jump_statement): Call break_maybe_infinite_loop.
-
- * call.c (build_op_delete_call): Use make_tree_vector and
- release_tree_vector.
-
-2014-01-23 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/58980
- * parser.c (cp_parser_enum_specifier): Handle TYPENAME_TYPE as
- nested_name_specifier.
-
-2014-01-23 Balaji V. Iyer <balaji.v.iyer@intel.com>
-
- * parser.c (cp_parser_direct_declarator): When Cilk Plus is enabled
- see if there is an attribute after function decl. If so, then
- parse them now.
- (cp_parser_late_return_type_opt): Handle parsing of Cilk Plus SIMD
- enabled function late parsing.
- (cp_parser_gnu_attribute_list): Parse all the tokens for the vector
- attribute for a SIMD-enabled function.
- (cp_parser_omp_all_clauses): Skip parsing to the end of pragma when
- the function is used by SIMD-enabled function (indicated by NULL
- pragma token). Added 3 new clauses: PRAGMA_CILK_CLAUSE_MASK,
- PRAGMA_CILK_CLAUSE_NOMASK and PRAGMA_CILK_CLAUSE_VECTORLENGTH
- (cp_parser_cilk_simd_vectorlength): Modified this function to handle
- vectorlength clause in SIMD-enabled function and #pragma SIMD's
- vectorlength clause. Added a new bool parameter to differentiate
- between the two.
- (cp_parser_cilk_simd_fn_vector_attrs): New function.
- (is_cilkplus_vector_p): Likewise.
- (cp_parser_late_parsing_elem_fn_info): Likewise.
- (cp_parser_omp_clause_name): Added a check for "mask", "nomask"
- and "vectorlength" clauses when Cilk Plus is enabled.
- (cp_parser_omp_clause_linear): Added a new parameter of type bool
- and emit a sorry message when step size is a parameter.
- * parser.h (cp_parser::cilk_simd_fn_info): New field.
- * decl.c (grokfndecl): Added flag_enable_cilkplus along with
- flag_openmp.
- * pt.c (apply_late_template_attributes): Likewise.
-
-2014-01-23 Jakub Jelinek <jakub@redhat.com>
-
- PR middle-end/58809
- * semantics.c (finish_omp_reduction_clause): Reject
- BIT_AND_EXPR, BIT_IOR_EXPR and BIT_XOR_EXPR on COMPLEX_TYPEs.
-
-2014-01-22 Ville Voutilainen <ville.voutilainen@gmail.com>
-
- PR c++/59482
- * parser.c (cp_parser_class_head): Push the class before parsing
- the base-clause, pop after it.
-
-2014-01-20 Eric Botcazou <ebotcazou@adacore.com>
-
- * decl2.c (cpp_check): Revert prototype change.
-
-2014-01-17 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/59270
- PR c++/58811
- * init.c (build_value_init_noctor): Don't pass error_mark_node to
- build_value_init.
-
-2014-01-17 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/59269
- * init.c (build_value_init_noctor): Assert !TYPE_HAS_COMPLEX_DFLT
- only when errorcount == 0.
-
-2014-01-17 Marek Polacek <polacek@redhat.com>
-
- PR c++/59838
- * cvt.c (ocp_convert): Don't segfault on non-existing
- ENUM_UNDERLYING_TYPE.
-
-2014-01-16 Jason Merrill <jason@redhat.com>
-
- PR c++/59821
- * tree.c (bot_manip): Update the location of builtin_LINE and
- builtin_FILE calls.
-
-2014-01-14 Jason Merrill <jason@redhat.com>
-
- PR c++/59659
- * typeck2.c (massage_init_elt): New.
- (process_init_constructor_record)
- (process_init_constructor_union): Use it.
- (process_init_constructor_array): Use it. Use RANGE_EXPR.
- (split_nonconstant_init_1): Handle it.
- * semantics.c (cxx_eval_vec_init_1): Use force_rvalue.
-
-2014-01-09 Balaji V. Iyer <balaji.v.iyer@intel.com>
-
- PR c++/59631
- * parser.c (cp_parser_postfix_expression): Added a new if-statement
- and replaced an existing if-statement with else-if statement.
- Changed an existing error message wording to match the one from the C
- parser.
-
-2014-01-08 Jason Merrill <jason@redhat.com>
-
- PR c++/59614
- * class.c (abi_tag_data): Add tags field.
- (check_abi_tags): Initialize it.
- (find_abi_tags_r): Support collecting missing tags.
- (mark_type_abi_tags): Don't look at template args.
- (inherit_targ_abi_tags): New.
- (check_bases_and_members): Use it.
- * cp-tree.h (ABI_TAG_IMPLICIT): New.
- * mangle.c (write_abi_tags): Check it.
-
-2014-01-07 Jason Merrill <jason@redhat.com>
-
- PR c++/58856
- * pt.c (num_innermost_template_parms): New.
- (get_underlying_template): Use it.
-
- PR c++/58965
- * mangle.c (write_guarded_var_name): Handle null DECL_NAME.
-
-2014-01-07 Paolo Carlini <paolo.carlini@oracle.com>
-
- * semantics.c (trait_expr_value, [CPTK_IS_BASE_OF]): Implement
- the letter of 20.11.6 about Base and Derived naming the same
- class type modulo cv-qualifiers.
-
-2014-01-06 Adam Butcher <adam@jessamine.co.uk>
-
- PR c++/59635
- * lambda.c (maybe_add_lambda_conv_op): Handle marking conversion
- function as unimplemented for generic lambdas with varargs.
-
- PR c++/59636
- * parser.c (cp_parser_template_parameter): Early out with
- error_mark_node if parameter declaration was not parsed.
-
- PR c++/59629
- * parser.c (cp_parser_lambda_expression): Save/reset/restore
- auto_is_implicit_function_template_parm_p around lambda body.
-
- PR c++/59638
- * parser.c (cp_parser_init_declarator): Undo fully implicit
- template parameter list when declarator is not a function.
-
-2014-01-03 Marc Glisse <marc.glisse@inria.fr>
-
- PR c++/58950
- * cvt.c (convert_to_void): Handle VEC_PERM_EXPR and VEC_COND_EXPR.
-
-2014-01-03 Tobias Burnus <burnus@net-b.de>
-
- PR c++/58567
- * pt.c (tsubst_omp_for_iterator): Early return for error_mark_node.
-
-2014-01-03 Paolo Carlini <paolo.carlini@oracle.com>
-
- Core DR 1442
- PR c++/59165
- * parser.c (cp_parser_perform_range_for_lookup): Don't pass true
- as include_std to perform_koenig_lookup.
- (cp_parser_postfix_expression): Adjust.
- * pt.c (tsubst_copy_and_build): Likewise.
- * semantics.c (perform_koenig_lookup): Remove bool parameter.
- (omp_reduction_lookup): Adjust.
- * name-lookup.c (lookup_arg_dependent_1): Remove bool parameter.
- (lookup_arg_dependent): Likewise.
- (lookup_function_nonclass): Adjust.
- * name-lookup.h: Adjust declaration.
- * cp-tree.h: Likewise.
-
-2014-01-02 Marc Glisse <marc.glisse@inria.fr>
-
- PR c++/59087
- * parser.c (cp_parser_userdef_numeric_literal): Mention
- -fext-numeric-literals in the message.
-
-2014-01-02 Marc Glisse <marc.glisse@inria.fr>
-
- PR c++/59641
- * call.c (build_conditional_expr_1): Check the return value of
- force_rvalue.
-
-2014-01-02 Marc Glisse <marc.glisse@inria.fr>
-
- * call.c (convert_like_real): Check complain.
-
-2014-01-02 Marc Glisse <marc.glisse@inria.fr>
-
- PR c++/59378
- * typeck.c (build_x_vec_perm_expr): Handle non-dependent arguments
- in templates.
-
-2014-01-02 Richard Sandiford <rdsandiford@googlemail.com>
-
- Update copyright years
-
-2014-01-02 Richard Sandiford <rdsandiford@googlemail.com>
-
- * cp-array-notation.c, cp-cilkplus.c, vtable-class-hierarchy.c: Use
- the standard form for the copyright notice.
-Copyright (C) 2014 Free Software Foundation, Inc.
+Copyright (C) 2015 Free Software Foundation, Inc.
Copying and distribution of this file, with or without modification,
are permitted in any medium without royalty provided the copyright
diff --git a/gcc/cp/ChangeLog-2014 b/gcc/cp/ChangeLog-2014
new file mode 100644
index 00000000000..a6ce50bc685
--- /dev/null
+++ b/gcc/cp/ChangeLog-2014
@@ -0,0 +1,4041 @@
+2014-12-31 Iain Sandoe <iain@codesourcery.com>
+
+ * parser.c (cp_parser_primary_expression): If parsing an
+ objective-c++ message expression fails, see if a lambda is present.
+ (cp_parser_objc_message_receiver): Don't assume that, if a message
+ receiver expression fails, it is a hard error.
+
+2014-12-25 Jason Merrill <jason@redhat.com>
+
+ * pt.c (check_default_tmpl_args): Uses the parameter source
+ location in the diagnostic.
+ (convert_template_argument): Just return if parm is error_mark_node.
+
+ PR c++/63522
+ * parser.c (cp_parser_type_parameter): Call
+ check_for_bare_parameter_packs on default argument.
+
+2014-12-24 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/63985
+ * parser.c (cp_parser_init_declarator): Add location_t* parameter.
+ (cp_parser_simple_declaration): Provide proper diagnostic for
+ multiple declarations and initializers in range-based for loops.
+ (cp_parser_single_declaration): Adjust call.
+
+2014-12-20 Jason Merrill <jason@redhat.com>
+
+ PR c++/64359
+ * pt.c (iterative_hash_template_arg): Hash alias specializations
+ differently from their TYPE_CANONICAL.
+ (alias_template_specialization_p): Optimize.
+ (template_args_equal): Optimize alias handling.
+ (dependent_alias_template_spec_p): Only check innermost args.
+
+2014-12-19 Kai Tietz <ktietz@redhat.com>
+
+ PR c++/61198
+ * pt.c (most_general_template): Don't break for template-alias.
+
+2014-12-18 Jason Merrill <jason@redhat.com>
+
+ PR c++/64105
+ * parser.c (cp_parser_simple_type_specifier): Make auto parameter
+ before -std=c++14 an error.
+
+ PR c++/64352
+ * pt.c (tsubst_copy_and_build): Pass complain to mark_used.
+
+ PR c++/64251
+ * decl2.c (mark_used): Don't mark if in_template_function.
+
+2014-12-18 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/60955
+ * pt.c (struct warning_sentinel): Move it...
+ * cp-tree.h: ... here.
+ * semantics.c (force_paren_expr): Use it.
+
+2014-12-17 Jason Merrill <jason@redhat.com>
+
+ PR c++/64333
+ * constexpr.c (cxx_bind_parameters_in_call): non_constant_args parm.
+ (cxx_eval_call_expression): Don't cache calls with non-constant args.
+ (cxx_eval_constant_expression) [COMPOUND_EXPR]: Pass true for lval.
+ (cxx_eval_unary_expression, cxx_eval_binary_expression)
+ (cxx_eval_conditional_expression): Pass false for lval.
+
+ * constexpr.c: Change "addr" parm names to "lval".
+
+ * constexpr.c: Tweak comments and formatting.
+
+2014-12-16 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/58650
+ * parser.c (cp_parser_member_declaration): Fix error recovery for
+ initialized non-static data member declared friend.
+
+2014-12-15 Jan Hubicka <hubicka@ucw.cz>
+
+ * decl2.c (decl_needed_p): When not optimizing, do not consider external
+ decls as needed.
+
+2014-12-15 Jason Merrill <jason@redhat.com>
+
+ PR c++/64297
+ * typeck.c (apply_memfn_quals): Correct wrong TYPE_CANONICAL.
+
+ N3778: Sized Deallocation
+ * call.c (non_placement_deallocation_fn_p): A global sized
+ operator delete is not a usual deallocation function until C++14.
+ (build_op_delete_call): Choose the global sized op delete if we
+ know the size.
+ * cp-tree.h: Declare non_placement_deallocation_fn_p.
+ (enum cp_tree_index): Remove CPTI_GLOBAL_DELETE_FNDECL.
+ (global_delete_fndecl): Remove.
+ * decl.c (cxx_init_decl_processing): Also declare sized op deletes.
+ (grok_op_properties): Warn about sized dealloc without the flag.
+ * init.c (build_builtin_delete_call): Remove.
+ (build_vec_delete_1, build_delete): Don't call it.
+ * decl2.c (maybe_warn_sized_delete): New.
+ (cp_write_global_declarations): Call it.
+
+2014-12-15 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/58882
+ * decl.c (check_array_designated_initializer): Diagnose gracefully
+ C99 designators which aren't integral constant-expressions; allow
+ constexpr user-defined type conversion operators.
+
+2014-12-12 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/59628
+ * semantics.c (finish_omp_reduction_clause): Early return true
+ if DECL_SAVED_TREE (id) is NULL_TREE.
+
+2014-12-12 Jason Merrill <jason@redhat.com>
+
+ N3922
+ * pt.c (do_auto_deduction): In direct-init context, { x } deduces
+ from x.
+
+ * cp-tree.h (NAMESPACE_ABI_TAG): New.
+ * name-lookup.c (handle_namespace_attrs): Set it.
+ * class.c (check_tag): Split out from find_abi_tags_r.
+ (find_abi_tags_r): Also check namespace tags.
+ (mark_type_abi_tags): Also mark namespace tags.
+
+2014-12-12 Kai Tietz <ktietz@redhat.com>
+
+ PR c++/63996
+ * constexpr.c (cxx_eval_loop_expr): Don't loop
+ endless on none-constant expression.
+
+2014-12-12 Jason Merrill <jason@redhat.com>
+
+ PR c++/61402
+ * lambda.c (add_capture): Don't pass a dependent type to
+ variably_modified_type_p.
+
+2014-12-11 Jason Merrill <jason@redhat.com>
+
+ Remove N3639 "array of runtime length" from -std=c++14.
+ * decl.c (compute_array_index_type): VLAs are not part of C++14.
+ (create_array_type_for_decl, grokdeclarator): Likewise.
+ * lambda.c (add_capture): Likewise.
+ * pt.c (tsubst): Likewise.
+ * rtti.c (get_tinfo_decl): Likewise.
+ * semantics.c (finish_decltype_type): Likewise.
+ * typeck.c (cxx_sizeof_or_alignof_type): Likewise.
+ (cp_build_addr_expr_1): Likewise.
+ * init.c (build_vec_init): Don't throw bad_array_length.
+
+ PR c++/64248
+ Revert:
+ * parser.c (cp_parser_unqualified_id): Handle __func__ here.
+ (cp_parser_primary_expression): Not here.
+
+ PR c++/57510
+ * typeck2.c (split_nonconstant_init_1): Handle arrays here.
+ (store_init_value): Not here.
+ (split_nonconstant_init): Look through TARGET_EXPR. No longer static.
+ * cp-tree.h: Declare split_nonconstant_init.
+ * call.c (set_up_extended_ref_temp): Use split_nonconstant_init.
+
+2014-12-11 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * typeck.c (maybe_warn_about_useless_cast): Remove unnecessary
+ conditional.
+
+2014-12-10 Kai Tietz <ktietz@redhat.com>
+
+ PR c++/64127
+ * parser.c (cp_parser_diagnose_invalid_type_name): Check id
+ for being an identifier before accessing it.
+
+ PR c++/64100
+ * typeck.c (lookup_destructor): Handle incomplete type.
+
+2014-12-09 Jason Merrill <jason@redhat.com>
+
+ PR c++/64129
+ * decl.c (grokdeclarator): Recover from variable template
+ specialization declared as function.
+
+ PR c++/64222
+ * parser.c (cp_parser_unqualified_id): Don't declare fname while
+ parsing function parms.
+
+2014-12-03 Jason Merrill <jason@redhat.com>
+
+ PR c++/64029
+ * decl.c (grok_reference_init): Complete array type.
+
+ PR c++/64080
+ * constexpr.c (cxx_eval_store_expression): Handle non-decl store
+ targets.
+
+2014-12-03 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/63558
+ * decl.c (identify_goto): Return a bool if diagnostic is emitted.
+ (check_previous_goto_1): Consistently emit permerror + inform.
+ (check_goto): Likewise.
+
+2014-12-03 Richard Biener <rguenther@suse.de>
+
+ * constexpr.c (cxx_eval_builtin_function_call): Use
+ fold_build_call_array_loc.
+
+2014-12-02 Marek Polacek <polacek@redhat.com>
+
+ * constexpr.c (cxx_eval_check_shift_p): New function.
+ (cxx_eval_binary_expression): Call it. Set NON_CONSTANT_P if it
+ returns true.
+
+2014-12-01 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/60859
+ * decl.c (reshape_init_r): Do not reject value-initialization of
+ scalar array element.
+
+2014-12-01 Marek Polacek <polacek@redhat.com>
+
+ PR sanitizer/63956
+ * constexpr.c: Include ubsan.h.
+ (cxx_eval_call_expression): Bail out for IFN_UBSAN_{NULL,BOUNDS}
+ internal functions and for ubsan builtins.
+ * error.c: Include internal-fn.h.
+ (dump_expr): Add printing of internal functions.
+
+2014-12-01 Marek Polacek <polacek@redhat.com>
+
+ * constexpr.c (literal_type_p): Return true for void type in C++14.
+
+2014-12-01 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/60845
+ * typeck.c (finish_class_member_access_expr): Use %q#T instead of
+ %qD in error message.
+
+2014-11-29 Jakub Jelinek <jakub@redhat.com>
+
+ * cp-gimplify.c (cxx_omp_clause_apply_fn): Remove NULL last argument
+ from create_tmp_var calls.
+
+2014-11-28 Marek Polacek <polacek@redhat.com>
+
+ PR c/63862
+ * typeck.c (cp_build_binary_op) <RSHIFT_EXPR, LSHIFT_EXPR>: Don't
+ convert the right operand to integer type.
+
+2014-11-27 Kai Tietz <ktietz@redhat.com>
+
+ PR c++/63904
+ * constexpr.c (cxx_eval_vec_init_1): Avoid
+ type-overflow issue.
+
+2014-11-26 Jason Merrill <jason@redhat.com>
+
+ Allow partial specialization of variable templates.
+ * cp-tree.h (TINFO_USED_TEMPLATE_ID): New.
+ * decl.c (duplicate_decls): Copy it.
+ * error.c (dump_decl) [TEMPLATE_ID_EXPR]: Handle variables.
+ * parser.c (cp_parser_decltype_expr): Do call finish_id_expression
+ on template-ids.
+ * pt.c (register_specialization): Remember variable template insts.
+ (instantiate_template_1): Find the matching partial specialization.
+ (check_explicit_specialization): Allow variable partial specialization.
+ (process_partial_specialization): Likewise.
+ (push_template_decl_real): Likewise.
+ (more_specialized_partial_spec): Rename from more_specialized_class.
+ (most_specialized_partial_spec): Rename from most_specialized_class.
+ (get_partial_spec_bindings): Rename from get_class_bindings.
+
+2014-11-26 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/63757
+ * call.c (standard_conversion): Do not require expr to be non-null
+ when NULLPTR_TYPE_P (from) is true.
+
+2014-11-26 Jason Merrill <jason@redhat.com>
+
+ * constexpr.c (cxx_eval_constant_expression) [SAVE_EXPR]: Avoid
+ multiple evaluation.
+
+ * constexpr.c (cxx_eval_call_expression): Don't talk about
+ flowing off the end if we're already non-constant.
+
+2014-11-26 Ville Voutilainen <ville.voutilainen@gmail.com>
+
+ Diagnose string constant conversion to char* in c++11 and above
+ as forbidden, not deprecated.
+ * typeck.c (string_conv_p): Do a pedwarn in c++11 and above,
+ change the diagnostic for the Wwrite-strings case for c++11 and above.
+
+2014-11-24 Jason Merrill <jason@redhat.com>
+
+ * pt.c (lookup_template_variable): Always unknown_type_node.
+
+2014-11-25 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/63786
+ * parser.c (cp_parser_label_for_labeled_statement): Check the case
+ with check_for_bare_parameter_packs.
+
+2014-11-24 Jonathan Wakely <jwakely@redhat.com>
+ Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/63203
+ * decl.c (initialize_local_var): Add -Winit-self warning for
+ references initialized with themselves.
+
+2014-11-24 Jason Merrill <jason@redhat.com>
+
+ PR c++/63942
+ * mangle.c (mangle_decl): If we aren't going to create a symbol
+ alias, don't build the alias DECL either.
+
+2014-11-24 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/63905
+ * cp-tree.h (lang_decl_fn): Remove constructor_attr, destructor_attr.
+
+2014-11-21 Jason Merrill <jason@redhat.com>
+
+ PR c++/63657
+ PR c++/38958
+ * call.c (set_up_extended_ref_temp): Set TREE_USED on the reference
+ if the temporary has a non-trivial destructor.
+ * decl.c (poplevel): Don't look through references.
+
+ PR c++/63942
+ * name-lookup.c (supplement_binding_1): Override a mangling alias.
+ * mangle.c (maybe_remove_implicit_alias): New.
+ (mangle_decl): Always avoid creating conflicting alias.
+ * cp-tree.h: Adjust.
+
+ PR c++/63849
+ * mangle.c (decl_mangling_context): Use template_type_parameter_p.
+
+ PR c++/63588
+ * pt.c (uses_template_parms): Handle null argument.
+
+2014-11-21 Jakub Jelinek <jakub@redhat.com>
+
+ PR target/63764
+ * typeck.c (cp_build_array_ref): Adjust
+ convert_vector_to_pointer_for_subscript caller. If it returns true,
+ call non_lvalue_loc on the result.
+
+2014-11-20 Jason Merrill <jason@redhat.com>
+
+ PR c++/63658
+ * pt.c (convert_nontype_argument): Call convert_from_reference.
+ (check_instantiated_arg): Don't be confused by reference refs.
+ (unify): Look through reference refs on the arg, too.
+ * mangle.c (write_template_arg): Look through reference refs.
+
+ * error.c (dump_expr): Avoid printing (*&i) for references.
+
+2014-11-20 Ville Voutilainen <ville.voutilainen@gmail.com>
+
+ PR c++/63959
+ * tree.c (trivially_copyable_p): Check for CP_TYPE_VOLATILE_P.
+
+2014-11-20 Trevor Saunders <tsaunders@mozilla.com>
+
+ * cp-objcp-common.c: Use hash_table instead of htab.
+
+2014-11-19 Jason Merrill <jason@redhat.com>
+
+ PR c++/56041
+ * cp-tree.h (struct processing_template_decl_sentinel): New.
+ * pt.c (instantiate_non_dependent_expr_internal): Split out from...
+ (instantiate_non_dependent_expr_sfinae): Here.
+ (convert_nontype_argument): Use them.
+ * constexpr.c (fold_non_dependent_expr): Use them.
+
+ PR c++/63885
+ * constexpr.c (cxx_eval_constant_expression) [PARM_DECL]: Don't
+ complain yet about a reference.
+ [TARGET_EXPR]: Handle TARGET_EXPR with addr == true.
+ [ADDR_EXPR]: Make sure we don't take the address of a CONSTRUCTOR.
+ (cxx_bind_parameters_in_call): In the new scheme addr is always false.
+ * typeck.c (build_address): Don't take the address of a CONSTRUCTOR.
+
+ PR c++/57979
+ * init.c (decl_really_constant_value): Rename from
+ integral_constant_value.
+ (scalar_constant_value): Similar but limited to scalar results.
+ (decl_constant_value_safe): Remove.
+ (constant_value_1): Respect return_aggregate_cst_ok_p.
+ * typeck.c (decay_conversion): Use scalar_constant_value.
+ * call.c (convert_like_real): Likewise.
+ * cvt.c (ocp_convert): No need to check CLASS_TYPE_P.
+ * typeck.c (decay_conversion): Or ARRAY_TYPE.
+ * constexpr.c (struct constexpr_ctx): Add strict field.
+ (cxx_eval_constant_expression) [VAR_DECL]: Use it to select between
+ decl_constant_value and decl_really_constant_value.
+ (cxx_eval_outermost_constant_expr): Add strict parm.
+ (maybe_constant_init): Not strict.
+ (potential_constant_expression_1): Add strict parm.
+ Shorten most internal calls with RECUR macro.
+ * cp-tree.h, pt.c, semantics.c: Adjust.
+
+2014-11-19 Jason Merrill <jason@redhat.com>
+
+ PR c++/63928
+ * constexpr.c (cxx_eval_store_expression): Return init, not *valp.
+
+2014-11-19 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/55425
+ * constexpr.c (constexpr_fn_retval): Accept __func__, __FUNCTION__,
+ and __PRETTY_FUNCTION__.
+
+2014-11-18 Jason Merrill <jason@redhat.com>
+
+ PR c++/63924
+ * constexpr.c (cxx_eval_constant_expression) [PARM_DECL]: A load
+ from a variable of empty class type is constant.
+
+ * constexpr.c (cxx_eval_statement_list): Handle statement-expressions.
+ (potential_constant_expression_1): Handle STMT_EXPR.
+
+ * constexpr.c (cxx_eval_constant_expression): Give jump_target a
+ default argument.
+ (lots): Omit NULL jump_target arguments.
+
+ * constexpr.c (struct constexpr_ctx): Add quiet field.
+ (cxx_eval_outermost_constant_expr, is_sub_constant_expr): Set it.
+ (lots): Replace allow_non_constant parameter with ctx->quiet.
+
+ PR c++/63940
+ * constexpr.c (cxx_eval_binary_expression): Don't assume the
+ expression was already folded.
+ (cxx_eval_unary_expression): Likewise.
+
+2014-11-18 Marc Glisse <marc.glisse@inria.fr>
+
+ PR libstdc++/43622
+ * rtti.c (emit_support_tinfos): Handle __float128.
+
+2014-11-18 Jason Merrill <jason@redhat.com>
+
+ PR c++/63925
+ * constexpr.c (cxx_eval_increment_expression): Use POINTER_PLUS_EXPR.
+
+ PR c++/63934
+ * constexpr.c (cxx_eval_call_expression): Check DECL_CONSTRUCTOR_P
+ rather than VOID_TYPE_P.
+
+ * pt.c (instantiate_template_1): Use tsubst_aggr_type for context.
+
+ PR c++/58102
+ * typeck2.c (store_init_value): Set it.
+ * cp-tree.h (CONSTRUCTOR_MUTABLE_POISON): New.
+ * constexpr.c (cxx_eval_outermost_constant_expr): Check it.
+
+2014-11-17 Jason Merrill <jason@redhat.com>
+
+ PR c++/33911
+ * call.c (build_call_a): Don't warn_deprecated_use here.
+ (build_over_call): Or here.
+ * decl2.c (mark_used): Do it here.
+ (is_late_template_attribute): Attribute deprecated is not deferred.
+ (cplus_decl_attributes): Propagate TREE_DEPRECATED out to the template.
+ * parser.c (cp_parser_template_name): Warn about deprecated template.
+ (cp_parser_template_argument): Likewise.
+
+ PR c++/50473
+ * decl.c (cp_finish_decl): Don't try to process a non-dependent
+ constant initializer for a reference.
+ * pt.c (value_dependent_expression_p): A reference is always
+ dependent.
+ * call.c (extend_ref_init_temps_1): Also clear TREE_SIDE_EFFECTS
+ on any NOP_EXPRs.
+
+ Handle C++14 constexpr flow control.
+ * constexpr.c (cxx_eval_loop_expr, cxx_eval_switch_expr): New.
+ (cxx_eval_statement_list): New.
+ (cxx_eval_constant_expression): Handle LABEL_EXPR,
+ CASE_LABEL_EXPR, GOTO_EXPR, LOOP_EXPR, SWITCH_EXPR. Handle jump
+ semantics of RETURN_EXPR.
+ (many functions): Add jump_target parameter.
+ (returns, breaks, continues, switches, label_matches): New.
+ * cp-tree.h (LABEL_DECL_BREAK, LABEL_DECL_CONTINUE): New.
+ * cp-gimplify.c (begin_bc_block): Set them.
+
+ * cp-gimplify.c (genericize_cp_loop): Use LOOP_EXPR.
+ (genericize_for_stmt): Handle null statement-list.
+
+ * constexpr.c (use_new_call): Always use new call handling.
+
+ C++14 constexpr support (minus loops and multiple returns)
+ * constexpr.c (use_new_call): New macro.
+ (build_data_member_initialization): Ignore non-mem-inits.
+ (check_constexpr_bind_expr_vars): Remove C++14 checks.
+ (constexpr_fn_retval): Likewise.
+ (check_constexpr_ctor_body): Do nothing in C++14.
+ (massage_constexpr_body): In C++14 only collect mem-inits.
+ (get_function_named_in_call): Handle null CALL_EXPR_FN.
+ (cxx_bind_parameters_in_call): Build bindings in same order as
+ parameters. Don't treat iniviref parms specially in new call mode.
+ (cxx_eval_call_expression): If use_new_call, do constexpr expansion
+ based on DECL_SAVED_TREE rather than the massaged constexpr body.
+ Set up ctx->object from AGGR_INIT_EXPR_SLOT if we don't have one.
+ (is_sub_constant_expr): Don't mess with ctx.ctor here.
+ (cxx_eval_component_reference): A null element means we're mid-
+ initialization.
+ (cxx_eval_store_expression, cxx_eval_increment_expression): New.
+ (cxx_eval_constant_expression): Handle RESULT_DECL, DECL_EXPR,
+ MODIFY_EXPR, STATEMENT_LIST, BIND_EXPR, USING_STMT,
+ PREINCREMENT_EXPR, POSTINCREMENT_EXPR, PREDECREMENT_EXPR,
+ POSTDECREMENT_EXPR. Don't look into DECL_INITIAL of variables in
+ constexpr functions. In new-call mode find parms in the values table.
+ (potential_constant_expression_1): Handle null CALL_EXPR_FN.
+ Handle STATEMENT_LIST, MODIFY_EXPR, MODOP_EXPR, IF_STMT,
+ PREINCREMENT_EXPR, POSTINCREMENT_EXPR, PREDECREMENT_EXPR,
+ POSTDECREMENT_EXPR, BIND_EXPR, WITH_CLEANUP_EXPR,
+ CLEANUP_POINT_EXPR, MUST_NOT_THROW_EXPR, TRY_CATCH_EXPR,
+ EH_SPEC_BLOCK, EXPR_STMT, DECL_EXPR, CASE_LABEL_EXPR, BREAK_STMT,
+ CONTINUE_STMT, USING_STMT, IF_STMT, DO_STMT, FOR_STMT, WHILE_STMT,
+ SWITCH_STMT, ASM_EXPR.
+ (cxx_eval_vec_init_1): Call build_aggr_init_expr.
+ (cxx_eval_indirect_ref): Don't return a CONSTRUCTOR when the
+ caller wants an lvalue.
+ (cxx_eval_outermost_constant_expr): Pull object out of AGGR_INIT_EXPR.
+ (maybe_constant_init): Look through INIT_EXPR.
+ (ensure_literal_type_for_constexpr_object): Set
+ cp_function_chain->invalid_constexpr.
+ * cp-tree.h (struct language_function): Add invalid_constexpr bitfield.
+ * decl.c (start_decl): Set cp_function_chain->invalid_constexpr.
+ (check_for_uninitialized_const_var): Likewise.
+ (maybe_save_function_definition): Check it.
+ * parser.c (cp_parser_jump_statement): Set
+ cp_function_chain->invalid_constexpr.
+ (cp_parser_asm_definition): Likewise.
+
+ PR c++/52282
+ * decl.c (build_ptrmemfunc_type): Don't build a different
+ RECORD_TYPE for a qualified PMF.
+ * cp-tree.h (TYPE_PTRMEMFUNC_FN_TYPE): Merge cv-quals.
+ (TYPE_PTRMEMFUNC_FN_TYPE_RAW): New.
+ * decl2.c (cplus_decl_attributes): Use TYPE_PTRMEMFUNC_FN_TYPE_RAW.
+ * tree.c (cp_walk_subtrees): Likewise.
+ (cp_build_qualified_type_real): Remove special PMF handling.
+
+2014-11-15 Jason Merrill <jason@redhat.com>
+
+ * parser.c (cp_parser_omp_declare_reduction_exprs): A block is not
+ an expression.
+
+ * constexpr.c (cxx_eval_builtin_function_call): Use
+ fold_builtin_call_array.
+
+ * constexpr.c (cx_check_missing_mem_inits): Clarify error message.
+
+2014-11-14 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * semantics.c (end_maybe_infinite_loop): Use fold_non_dependent_expr.
+ * parser.c (cp_parser_omp_clause_collapse): Likewise.
+ (cp_parser_enumerator_definition): Don't call
+ instantiate_non_dependent_expr...
+ * decl.c (build_enumerator): ... call fold_non_dependent_expr here.
+ * typeck2.c (massage_init_elt): Use fold_non_dependent_expr.
+ * constexpr.c (maybe_constant_value): Allow VIEW_CONVERT_EXPR in
+ the final gcc_assert.
+
+ * constexpr.c (fold_non_dependent_expr): Add.
+ * cp-tree.h (fold_non_dependent_expr): Declare it.
+ * call.c (null_ptr_cst_p): Use it.
+ * pt.c (tsubst_copy_and_build, build_non_dependent_expr): Likewise.
+ * semantics.c (begin_maybe_infinite_loop): Likewise.
+ * typeck.c (cp_build_binary_op): Likewise.
+ * typeck2.c (check_narrowing): Likewise.
+
+ * pt.c (fold_non_dependent_expr): Rename to
+ instantiate_non_dependent_expr.
+ (fold_non_dependent_expr_sfinae): Rename to
+ instantiate_non_dependent_expr_sfinae.
+ (convert_nontype_argument, build_non_dependent_expr): Adjust.
+ * decl.c (compute_array_index_type): Likewise.
+ * parser.c (cp_parser_parenthesized_expression_list,
+ cp_parser_enumerator_definition, cp_parser_omp_clause_collapse):
+ Likewise.
+ * semantics.c (end_maybe_infinite_loop, finish_static_assert):
+ Likewise.
+ * typeck.c (cxx_alignas_expr): Likewise.
+ * typeck2.c (store_init_value, massage_init_elt): Likewise.
+ * call.c: Adjust comments.
+ * class.c: Likewise.
+ * constexpr.c: Likewise.
+ * decl2.c: Likewise.
+ * tree.c: Likewise.
+
+2014-11-14 Jonathan Wakely <jwakely@redhat.com>
+
+ * mangle.c (find_substitution): Look for abi_tag on class templates.
+
+2014-11-13 Bernd Schmidt <bernds@codesourcery.com>
+ Thomas Schwinge <thomas@codesourcery.com>
+ Ilya Verbin <ilya.verbin@intel.com>
+ Andrey Turetskiy <andrey.turetskiy@intel.com>
+
+ * Make-lang.in (c++.install-common): Do not install for the offload
+ compiler.
+
+2014-11-13 Kai Tietz <ktietz@redhat.com>
+
+ * cp-tree.h (cp_build_function_call): Remove prototype.
+ (cp_build_addr_expr_strict): Likewise.
+ (build_typed_address): Likewise.
+ * typeck.c (build_typed_address): Removed.
+ (cp_build_addr_expr_strict): Make static.
+ (cp_build_function_call): Likewise.
+
+2014-11-12 Paolo Carlini <paolo.carlini@oracle.com>
+
+ DR 1510
+ PR c++/60420
+ * cp-tree.h (struct cp_decl_specifier_seq): Add decltype_p bool field.
+ * decl.c (grokdeclarator): Use it.
+ * parser.c (cp_parser_simple_type_specifier): Likewise.
+ * pt.c (tsubst, case DECLTYPE_TYPE): Use tf_ignore_bad_quals.
+
+2014-11-11 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/63265
+ * pt.c (tsubst_copy_and_build, case COND_EXPR): Maybe fold to
+ constant the condition.
+
+2014-11-10 Andi Kleen <ak@linux.intel.com>
+
+ * semantics.c (finish_goto_stmt): Call check_no_cilk.
+ (finish_while_stmt_cond): Dito.
+ (finish_do_stmt): Dito.
+ (finish_for_cond): Dito.
+ (finish_switch_cond): Dito.
+
+2014-11-10 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * typeck.c (cp_build_binary_op): Use OPT_Wshift_count_negative and
+ OPT_Wshift_count_overflow in the warnings.
+
+2014-11-09 Jason Merrill <jason@redhat.com>
+
+ DR 799
+ * typeck.c (build_reinterpret_cast_1): reinterpret_cast to the
+ same scalar type is an rvalue.
+
+ DR 2007
+ * call.c (build_new_op_1): Don't do non-class lookup for =, -> or [].
+
+2014-11-07 Jason Merrill <jason@redhat.com>
+
+ DR 1558
+ * pt.c (dependent_alias_template_spec_p): New.
+ (dependent_type_p_r): Handle dependent alias template specialization.
+ (template_args_equal): A dependent alias template specializations
+ is not equal to its underlying type as a template argument.
+ * tree.c (strip_typedefs): Don't strip a dependent alias
+ template-id.
+
+ * parser.c (cp_parser_unqualified_id): Handle __func__ here.
+ (cp_parser_primary_expression): Not here.
+
+2014-11-07 Thomas Preud'homme <thomas.preudhomme@arm.com>
+
+ PR c++/63366
+ * decl.c (grokdeclarator): Fix __complex meaning __complex double.
+
+2014-10-29 Richard Sandiford <richard.sandiford@arm.com>
+
+ * constexpr.c: Remove redundant enum from machine_mode.
+
+2014-10-28 Jason Merrill <jason@redhat.com>
+
+ * constexpr.c (cxx_eval_outermost_constant_expr): Tweak.
+
+2014-10-28 Andrew MacLeod <amacleod@redhat.com>
+
+ * call.c: Adjust include files.
+ * class.c: Ditto.
+ * decl2.c: Ditto.
+ * decl.c: Ditto.
+ * lambda.c: Ditto.
+ * mangle.c: Ditto.
+ * method.c: Ditto.
+ * optimize.c: Ditto.
+ * parser.c: Ditto.
+ * semantics.c: Ditto.
+ * tree.c: Ditto.
+ * vtable-class-hierarchy.c: Ditto.
+
+2014-10-24 Jason Merrill <jason@redhat.com>
+
+ Implement N3653 (Member initializers and aggregates) and fix
+ references to 'this' in constexpr constructors.
+ * class.c (check_field_decls): In C++14 an NSDMI does not make the
+ class non-aggregate.
+ * constexpr.c (struct constexpr_ctx): New.
+ (cxx_bind_parameters_in_call): Handle 'this'.
+ (cxx_eval_call_expression): Create new constexpr_ctx.
+ (cxx_eval_component_reference): Check CONSTRUCTOR_NO_IMPLICIT_ZERO.
+ (initialized_type, init_subob_ctx, verify_ctor_sanity): New.
+ (cxx_eval_bare_aggregate): Use them. Build CONSTRUCTOR early.
+ (cxx_eval_vec_init_1): Likewise.
+ (cxx_eval_constant_expression) [PARM_DECL]: Allow 'this'.
+ [TARGET_EXPR]: Build new constexpr_ctx.
+ [PLACEHOLDER_EXPR]: New.
+ (cxx_eval_outermost_constant_expr): Build new constexpr_ctx. Add
+ object parameter.
+ (is_sub_constant_expr): Build new constexpr_ctx.
+ (potential_constant_expression_1): Handle PLACEHOLDER_EXPR.
+ Allow 'this'.
+ * cp-gimplify.c (cp_gimplify_init_expr): Call replace_placeholders.
+ * cp-tree.h (CONSTRUCTOR_NO_IMPLICIT_ZERO): New.
+ * error.c (dump_expr): Handle PLACEHOLDER_EXPR.
+ * init.c (get_nsdmi): Generate PLACEHOLDER_EXPR.
+ * tree.c (lvalue_kind): Handle PLACEHOLDER_EXPR.
+ (build_ctor_subob_ref, replace_placeholders): New.
+ * typeck2.c (store_init_value): Use replace_placeholders.
+ (process_init_constructor_record): Make zero-init before NSDMI
+ explicit.
+
+2014-10-27 Andrew MacLeod <amacleod@redhat.com>
+
+ * cp-gimplify.c: Adjust include files.
+
+2014-10-26 Manuel López-Ibáñez <manu@gcc.gnu.org>
+
+ PR c++/53061
+ * cp-objcp-common.c: Do not include new.
+ (cxx_initialize_diagnostics): Move from here to ...
+ * error.c (cxx_initialize_diagnostics): : ... here. Move
+ diagnostics initialization here from init_error.
+ (cxx_pp): Use a real pointer not a macro.
+ (init_error): Just initialize cxx_pp.
+ * cxx-pretty-print.c (cxx_pretty_printer::cxx_pretty_printer): Do
+ not set maximum line length.
+
+2014-10-23 Jonathan Wakely <jwakely@redhat.com>
+
+ PR c++/63619
+ * decl2.c (delete_sanity): Use OPT_Wdelete_incomplete in warning.
+
+2014-10-21 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * parser.c (cp_parser_unary_expression): Add default arguments.
+ (cp_parser_cast_expression, cp_parser_sizeof_operand,
+ cp_parser_omp_atomic): Adjust.
+
+2014-10-20 Jason Merrill <jason@redhat.com>
+
+ PR c++/63601
+ * lambda.c (current_nonlambda_function): New.
+ * semantics.c (finish_this_expr): Use it.
+ * cp-tree.h: Declare it.
+
+2014-10-17 Alan Modra <amodra@gmail.com>
+
+ PR middle-end/61848
+ * decl.c (merge_decls): Don't merge section name, comdat group or
+ tls model to newdecl symtab node, instead merge to olddecl.
+ Override existing olddecl section name. Set tls_model for all
+ thread-local vars, not just OMP thread-private ones. Remove
+ incorrect comment.
+
+2014-10-16 Andrew MacLeod <amacleod@redhat.com>
+
+ * cp-tree.h: Adjust include files.
+
+2014-10-15 Jason Merrill <jason@redhat.com>
+
+ PR c++/63528
+ * pt.c (lookup_template_variable): Call coerce_template_parms.
+
+2014-10-15 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * semantics.c (is_instantiation_of_constexpr, literal_type_p,
+ ensure_literal_type_for_constexpr_object,
+ constexpr_fundef_hasher::equal, constexpr_fundef_hasher::hash,
+ retrieve_constexpr_fundef, is_valid_constexpr_fn,
+ build_anon_member_initialization, build_data_member_initialization,
+ check_constexpr_bind_expr_vars, check_constexpr_ctor_body_1,
+ check_constexpr_ctor_body, sort_constexpr_mem_initializers,
+ build_constexpr_constructor_member_initializers, constexpr_fn_retval,
+ massage_constexpr_body, cx_check_missing_mem_inits,
+ register_constexpr_fundef, explain_invalid_constexpr_fn,
+ constexpr_call_hasher::hash, constexpr_call_hasher::equal,
+ maybe_initialize_constexpr_call_table, get_function_named_in_call,
+ get_nth_callarg, lookup_parameter_binding,
+ cxx_eval_builtin_function_call, adjust_temp_type,
+ cxx_bind_parameters_in_call, push_cx_call_context,
+ pop_cx_call_context, cx_error_context, cxx_eval_call_expression,
+ reduced_constant_expression_p, verify_constant,
+ cxx_eval_unary_expression, cxx_eval_binary_expression,
+ cxx_eval_conditional_expression, cxx_eval_array_reference,
+ cxx_eval_component_reference, cxx_eval_bit_field_ref,
+ cxx_eval_logical_expression, base_field_constructor_elt,
+ cxx_eval_bare_aggregate, cxx_eval_vec_init_1, cxx_eval_vec_init,
+ cxx_fold_indirect_ref, cxx_eval_indirect_ref, non_const_var_error,
+ cxx_eval_trinary_expression, var_in_constexpr_fn,
+ cxx_eval_constant_expression, cxx_eval_outermost_constant_expr,
+ is_sub_constant_expr, cxx_constant_value, maybe_constant_value,
+ maybe_constant_init, potential_constant_expression_1,
+ potential_constant_expression, potential_rvalue_constant_expression,
+ require_potential_constant_expression,
+ require_potential_rvalue_constant_expression): Moved definitions...
+ * constexpr.c: ... here, new file.
+ * Make-lang.in: Update.
+ * config-lang.in: Likewise.
+
+2014-10-14 Jason Merrill <jason@redhat.com>
+
+ PR c++/63455
+ * parser.c (struct saved_token_sentinel): New.
+ (cp_parser_statement): Use it.
+ (cp_parser_start_tentative_firewall): New.
+ (cp_parser_end_tentative_firewall): New.
+ (cp_parser_lambda_expression): Use them.
+ (cp_parser_statement_expr): New.
+ (cp_parser_primary_expression): Use it.
+
+2014-10-14 DJ Delorie <dj@redhat.com>
+
+ * typeck.c (cp_common_type): Check for all __intN types, not just
+ __int128.
+ * decl.c (grokdeclarator): Likewise.
+ * rtti.c (emit_support_tinfos): Check for all __intN types, not just
+ __int128.
+ * parser.c (cp_lexer_next_token_is_decl_specifier_keyword): Check
+ for all __intN types, not just __int128.
+ (cp_parser_simple_type_specifier): Likewise.
+ * mangle.c (integer_type_codes): Remove int128-specific codes.
+ * cp-tree.h (cp_decl_specifier_seq): Add int_n_idx to store which
+ __intN was specified.
+ * lex.c (init_reswords): Reserve all __intN keywords.
+
+2014-10-14 Marc Glisse <marc.glisse@inria.fr>
+
+ * typeck.c (cp_build_unary_op) [TRUTH_NOT_EXPR]: Accept float vectors.
+
+2014-10-13 H.J. Lu <hongjiu.lu@intel.com>
+
+ * mangle.c (mangle_conv_op_name_for_type): Cast elements to
+ unsigned long.
+ (print_template_statistics): Cast size and elements to long.
+
+2014-10-12 Trevor Saunders <tsaunders@mozilla.com>
+
+ * cp-gimplify.c, cp-tree.h, decl.c, mangle.c, name-lookup.c,
+ pt.c, semantics.c, tree.c, typeck2.c: Use hash_table instead of
+ hashtab.
+
+2014-10-10 Jason Merrill <jason@redhat.com>
+
+ PR c++/62115
+ * class.c (build_base_path): Preserve rvalueness.
+ * call.c (convert_like_real) [ck_base]: Let convert_to_base handle &/*.
+ * rtti.c (build_dynamic_cast_1): Call convert_to_reference later.
+
+ PR c++/63194
+ * method.c (defaulted_late_check): Call maybe_instantiate_noexcept.
+
+ * method.c (implicitly_declare_fn): Handle deleted lambda default
+ ctor and copy assop here.
+ * class.c (check_bases_and_members): Not here.
+ (add_implicitly_declared_members): And don't set
+ CLASSTYPE_LAZY_MOVE_ASSIGN.
+
+ * semantics.c (finish_id_expression): Check for error_mark_node.
+
+2014-10-09 Jason Merrill <jason@redhat.com>
+
+ PR c++/63207
+ * semantics.c (outer_var_p): Non-static.
+ (process_outer_var_ref): Split out from finish_id_expression.
+ * pt.c (tsubst_copy_and_build): Call them.
+ * cp-tree.h: Declare them.
+
+2014-10-09 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * semantics.c (check_constexpr_ctor_body_1): New.
+ (check_constexpr_ctor_body): Use it; add bool parameter.
+ (build_data_member_initialization): Handle BIND_EXPR and
+ USING_STMT in the main conditional.
+ (build_constexpr_constructor_member_initializers): Do not
+ handle BIND_EXPR here.
+ (constexpr_fn_retval): Handle BIND_EXPR in the switch.
+ (massage_constexpr_body): Don't do it here.
+ * parser.c (cp_parser_ctor_initializer_opt_and_function_body):
+ Adjust check_constexpr_ctor_body call.
+ (cp_parser_compound_statement): Do not pedwarn for compound-statement
+ in constexpr function in C++14 mode.
+ * cp-tree.h (check_constexpr_ctor_body): Update declaration.
+
+2014-10-09 Jason Merrill <jason@redhat.com>
+
+ PR c++/63309
+ * parser.c (cp_parser_class_head): push_template_decl for members
+ of templates, too.
+
+ PR c++/63415
+ * pt.c (value_dependent_expression_p) [CONSTRUCTOR]: Check the type.
+ (iterative_hash_template_arg): Likewise.
+
+ PR c++/63437
+ * cp-tree.h (REF_PARENTHESIZED_P): Also allow INDIRECT_REF.
+ * semantics.c (force_paren_expr): And set it.
+ * typeck.c (check_return_expr): And handle it.
+
+2014-10-09 Marc Glisse <marc.glisse@inria.fr>
+
+ * decl.c (grokdeclarator): constexpr only implies const in C++11.
+
+2014-10-08 Jason Merrill <jason@redhat.com>
+
+ PR c++/63405
+ * pt.c (tsubst_pack_expansion): Limit simple expansion to type packs.
+
+ PR c++/63485
+ * tree.c (build_cplus_array_type): Look for a type with no
+ typedef-name or attributes.
+
+ * call.c (call_copy_ctor): New.
+ (build_over_call): Use it to avoid infinite recursion on invalid code.
+
+2014-10-07 Jason Merrill <jason@redhat.com>
+
+ * tree.c (cp_tree_equal) [TRAIT_EXPR]: Use cp_tree_equal for type2.
+
+2014-10-06 Edward Smith-Rowland <3dw4rd@verizon.net>
+
+ * cp/parser.c: Allow [[deprecated]] for C++11. Issue a pedwarn.
+
+2014-10-06 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/55250
+ * semantics.c (check_constexpr_bind_expr_vars): New.
+ (check_constexpr_ctor_body, massage_constexpr_body): Use it.
+ (build_constexpr_constructor_member_initializers): Handle
+ BIND_EXPR in the main conditional.
+
+2014-10-02 Mark Wielaard <mjw@redhat.com>
+
+ PR debug/63239
+ * cp-objcp-common.h (LANG_HOOKS_FUNCTION_DECL_DELETED_P): Define.
+ (cp_function_decl_deleted_p): New prototype.
+ * cp-objcp-common.c (cp_function_deleted_p): New function.
+
+2014-10-03 Marc Glisse <marc.glisse@inria.fr>
+
+ PR c++/54427
+ PR c++/57198
+ PR c++/58845
+ * typeck.c (cp_build_binary_op): save_expr after convert to save
+ redundant operations.
+ [TRUTH_ANDIF_EXPR, TRUTH_ORIF_EXPR]: Handle vectors.
+ (cp_build_unary_op) [TRUTH_NOT_EXPR]: Likewise.
+
+2014-10-03 Jason Merrill <jason@redhat.com>
+
+ * decl.c (start_decl): Complain about static/thread_local vars
+ in constexpr function.
+ (check_for_uninitialized_const_var): Also uninitialized vars.
+ * parser.c (cp_parser_jump_statement): And gotos.
+ (cp_parser_asm_operand_list): And asm.
+ (cp_parser_try_block): And try.
+ * semantics.c (ensure_literal_type_for_constexpr_object): And
+ non-literal.
+
+ * semantics.c (constexpr_fn_retval): Ignore declarations in C++14.
+ (var_in_constexpr_fn): New.
+ (cxx_eval_constant_expression): Look into DECL_INITIAL.
+ (potential_constant_expression_1): Allow constexpr-local vars.
+
+ PR c++/63362
+ * tree.c (strip_typedefs): Handle TREE_LIST.
+
+2014-10-03 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * parser.c (cp_parser_assignment_expression,
+ cp_parser_constant_expression): Add default arguments.
+ (cp_parser_primary_expression,
+ cp_parser_postfix_open_square_expression,
+ cp_parser_parenthesized_expression_list,
+ cp_parser_question_colon_clause,
+ cp_parser_expression, cp_parser_constant_expression,
+ cp_parser_label_for_labeled_statement, cp_parser_static_assert,
+ cp_parser_template_argument, cp_parser_enumerator_definition,
+ cp_parser_member_declaration, cp_parser_constant_initializer,
+ cp_parser_noexcept_specification_opt, cp_parser_throw_expression,
+ cp_parser_std_attribute_spec, cp_parser_objc_message_args,
+ cp_parser_objc_class_ivars, cp_parser_omp_clause_collapse,
+ cp_parser_omp_clause_aligned, cp_parser_omp_clause_safelen,
+ cp_parser_omp_clause_simdlen, cp_parser_omp_clause_dist_schedule,
+ cp_parser_omp_for_incr, cp_parser_omp_for_loop_init,
+ cp_parser_cilk_simd_vectorlength, cp_parser_cilk_simd_linear): Adjust.
+
+2014-10-02 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/53025
+ * cp-tree.h (struct saved_scope): Add noexcept_operand.
+ (cp_noexcept_operand): Define.
+ * call.c (build_over_call): Use it.
+ * parser.c (cp_parser_unary_expression, [RID_NOEXCEPT]): Likewise.
+ * pt.c (tsubst_copy_and_build, [NOEXCEPT_EXPR]): Likewise.
+
+2014-10-01 Jason Merrill <jason@redhat.com>
+
+ PR c++/63362
+ * method.c (constructible_expr): Handle value-init of non-class.
+ * parser.c (cp_parser_trait_expr): Allow pack expansion.
+ * pt.c (tsubst_copy_and_build): Handle pack expansion.
+
+ PR c++/63362
+ * class.c (type_has_non_user_provided_default_constructor): Rename
+ from type_has_user_provided_default_constructor, reverse sense.
+ (default_init_uninitialized_part, explain_non_literal_class): Adjust.
+ (check_bases_and_members): Set TYPE_HAS_COMPLEX_DFLT.
+ * call.c (build_new_method_call_1): Adjust.
+ * cp-tree.h: Adjust.
+ * decl.c (grok_special_member_properties): Don't set
+ TYPE_HAS_COMPLEX_DFLT.
+ * init.c (build_value_init_noctor): Don't use
+ type_has_user_provided_default_constructor.
+
+2014-09-30 Jason Merrill <jason@redhat.com>
+
+ * cp-tree.h (cp_trait_kind): Add CPTK_IS_TRIVIALLY_ASSIGNABLE and
+ CPTK_IS_TRIVIALLY_CONSTRUCTIBLE.
+ * cxx-pretty-print.c (pp_cxx_trait_expression): Likewise.
+ * parser.c (cp_parser_primary_expression): Likewise.
+ (cp_parser_trait_expr): Likewise. Handle variadic trait.
+ * semantics.c (trait_expr_value): Likewise.
+ (finish_trait_expr): Likewise.
+ (check_trait_type): Handle variadic trait. Return bool.
+ * method.c (build_stub_object): Add rvalue reference here.
+ (locate_fn_flags): Not here.
+ (check_nontriv, assignable_expr, constructible_expr): New.
+ (is_trivially_xible): New.
+
+ * cp-tree.h (cp_trait_kind): Add CPTK_IS_TRIVIALLY_COPYABLE.
+ * cxx-pretty-print.c (pp_cxx_trait_expression): Likewise.
+ * parser.c (cp_parser_primary_expression): Likewise.
+ (cp_parser_trait_expr): Likewise.
+ * semantics.c (trait_expr_value): Likewise.
+ (finish_trait_expr): Likewise.
+
+ * method.c (build_stub_object): Use CONVERT_EXPR.
+ * tree.c (build_dummy_object): Likewise.
+ (is_dummy_object): Adjust.
+
+ * cp-tree.h (cp_trait_kind): Remove CPTK_IS_CONVERTIBLE_TO.
+ * cxx-pretty-print.c (pp_cxx_trait_expression): Likewise.
+ * semantics.c (trait_expr_value): Likewise.
+ (finish_trait_expr): Likewise.
+ * parser.c (cp_parser_primary_expression): Likewise.
+ (cp_parser_trait_expr): Likewise. Remove redundant grokdeclarator.
+
+2014-09-30 Manuel López-Ibáñez <manu@gcc.gnu.org>
+
+ PR c++/16564
+ * error.c (print_instantiation_context): Delete.
+ * typeck2.c (build_x_arrow): Record location when pushing
+ template instantiation.
+ * pt.c (push_tinst_level): Make it a wrapper around ...
+ (push_tinst_level_loc): ... this. New function. Make excessive
+ template instantiation depth a fatal error. Record location. Use
+ bool as return type.
+ (instantiate_pending_templates): Make excessive
+ template instantiation depth a fatal error.
+ (problematic_instantiation_changed): Use bool as return type.
+ * cp-tree.h (print_instantiation_context): Delete.
+ (push_tinst_level): Update declaration.
+ (problematic_instantiation_changed): Likewise.
+ (push_tinst_level_loc): New.
+
+2014-09-29 Richard Biener <rguenther@suse.de>
+
+ * typeck.c (enum_cast_to_int): Use CONVERT_EXPR_P to check
+ for conversions.
+
+2014-09-26 Jason Merrill <jason@redhat.com>
+
+ * mangle.c (find_substitution): Use write_abi_tags.
+
+2014-09-25 Marek Polacek <polacek@redhat.com>
+
+ PR c++/61945
+ * class.c (warn_hidden): Check for FUNCTION_DECL.
+
+2014-09-25 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/63249
+ * semantics.c (handle_omp_array_sections_1): Call mark_rvalue_use
+ on low_bound and length.
+
+2014-09-24 Aldy Hernandez <aldyh@redhat.com>
+
+ * class.c, decl.c, optimize.c: Rename all instances of
+ DECL_ABSTRACT to DECL_ABSTRACT_P.
+
+2014-09-24 Marek Polacek <polacek@redhat.com>
+
+ PR c/61405
+ PR c/53874
+ * semantics.c (finish_switch_cond): Call unlowered_expr_type.
+ * tree.c (bot_manip): Add default case.
+ * parser.c (cp_parser_primary_expression): Cast the controlling
+ expression of a switch to an int.
+ (cp_parser_unqualified_id): Likewise.
+
+2014-09-23 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/61857
+ * parser.c (cp_parser_skip_to_closing_square_bracket,
+ cp_parser_array_designator_p): New.
+ (cp_parser_initializer_list): Use the latter.
+
+2014-09-22 Jason Merrill <jason@redhat.com>
+
+ * semantics.c (finish_non_static_data_member): In diagnostic, give
+ error at point of use and note at point of declaration.
+
+ PR c++/63320
+ PR c++/60463
+ PR c++/60755
+ * lambda.c (maybe_resolve_dummy, lambda_expr_this_capture): Handle
+ not finding 'this'.
+
+2014-09-22 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/62219
+ * pt.c (check_default_tmpl_args): Check LAMBDA_FUNCTION_P.
+
+2014-09-22 Jason Merrill <jason@redhat.com>
+
+ * decl.c (poplevel): Don't warn about unused vars in template scope.
+ * error.c (dump_decl): Handle variable templates.
+
+2014-09-20 Jason Merrill <jason@redhat.com>
+
+ PR c++/62017
+ * decl.c (begin_destructor_body): Only clobber the as-base part of
+ *this.
+
+2014-09-19 Jason Merrill <jason@redhat.com>
+
+ PR c++/61392
+ * mangle.c (write_expression): Use unresolved-name mangling for
+ DR850 case.
+
+ PR c++/61465
+ * call.c (convert_like_real) [ck_identity]: Call mark_rvalue_use
+ after pulling out an element from a CONSTRUCTOR.
+
+2014-09-18 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/63248
+ * semantics.c (finish_omp_clauses): Don't call cp_omp_mappable_type
+ on type of type dependent expressions, and don't call it if
+ handle_omp_array_sections has kept TREE_LIST because something
+ was type dependent.
+ * pt.c (tsubst_expr) <case OMP_TARGET, case OMP_TARGET_DATA>:
+ Use keep_next_level, begin_omp_structured_block and
+ finish_omp_structured_block instead of push_stmt_list and
+ pop_stmt_list.
+
+2014-09-18 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/62232
+ * class.c (finish_struct_1): Do not -Wnon-virtual-dtor warn
+ for final class types.
+
+2014-09-15 Jason Merrill <jason@redhat.com>
+
+ * pt.c (lookup_template_class_1): Splice out abi_tag attribute if
+ necessary. Call inherit_targ_abi_tags here.
+ * class.c (check_bases_and_members): Not here.
+ (inherit_targ_abi_tags): Check CLASS_TYPE_P.
+ * cp-tree.h: Declare inherit_targ_abi_tags.
+
+2014-09-15 Ville Voutilainen <ville.voutilainen@gmail.com>
+
+ Do not diagnose lambda default arguments in c++14 modes.
+ * parser.c (cp_parser_lambda_declarator_opt): Make the pedwarn
+ conditional.
+
+2014-09-15 Jakub Jelinek <jakub@redhat.com>
+
+ * Make-lang.in (check_g++_parallelize): Change to just an upper bound
+ number.
+
+2014-09-13 Marek Polacek <polacek@redhat.com>
+
+ PR c++/60862
+ * parser.c (cp_parser_postfix_expression) <case CPP_OPEN_PAREN>: Set
+ location of a call expression.
+
+2014-09-11 Jason Merrill <jason@redhat.com>
+
+ PR c++/63201
+ * decl.c (start_decl): Handle specialization of member variable
+ template.
+ * pt.c (check_explicit_specialization): Adjust error.
+
+2014-09-11 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/61489
+ * typeck2.c (process_init_constructor_record): Do not warn about
+ missing field initializer if EMPTY_CONSTRUCTOR_P (init).
+
+2014-09-11 Jason Merrill <jason@redhat.com>
+
+ PR c++/63139
+ * pt.c (tsubst_pack_expansion): Simplify substitution into T....
+ (tsubst): Don't throw away PACK_EXPANSION_EXTRA_ARGS.
+
+2014-09-10 Jason Merrill <jason@redhat.com>
+
+ PR c++/61659
+ * decl.c (grokfndecl): Don't set DECL_COMDAT on static inlines.
+ (duplicate_decls, start_decl): Likewise.
+ * pt.c (check_explicit_specialization): Likewise.
+ (push_template_decl_real): Or static templates.
+
+2014-09-08 Jason Merrill <jason@redhat.com>
+
+ * typeck.c (build_class_member_access_expr): Move
+ -Winvalid-offsetof code...
+ * semantics.c (finish_offsetof): ...here.
+ * parser.c (cp_parser_builtin_offsetof): Remember the location of
+ the type argument.
+ * pt.c (tsubst_copy_and_build) [OFFSETOF_EXPR]: Preserve it.
+
+ PR c++/62255
+ * pt.c (instantiate_decl): Handle recursive instantiation of
+ static data member.
+
+2014-09-05 Jason Merrill <jason@redhat.com>
+
+ PR c++/62659
+ * semantics.c (potential_constant_expression_1): Handle un-folded
+ pointer to member constants.
+
+2014-09-04 Markus Trippelsdorf <markus@trippelsdorf.de>
+
+ PR ipa/61659
+ * decl.c (duplicate_decls): Check DECL_DECLARED_INLINE_P on
+ newdecl, not olddecl.
+
+2014-09-02 Paolo Carlini <paolo.carlini@oracle.com>
+
+ DR 1453
+ * class.c (check_field_decls): A class of literal type cannot have
+ volatile non-static data members and base classes.
+ (explain_non_literal_class): Update.
+
+2014-09-02 Jakub Jelinek <jakub@redhat.com>
+ Balaji V. Iyer <balaji.v.iyer@intel.com>
+ Igor Zamyatin <igor.zamyatin@intel.com>
+
+ * cp-cilkplus.c (cpp_validate_cilk_plus_loop_aux): Loc definition
+ simplified.
+ * parser.c (cp_parser_cilk_for): New function.
+ (cp_parser_cilk_grainsize): Likewise.
+ (cp_parser_statement): Added RID_CILK_FOR case.
+ (cp_parser_omp_for_cond): Added CILK_FOR check.
+ (cp_parser_omp_for_loop_init): Change function argument to accept
+ tree_code instead just a bool flag; change the check to use that
+ tree_code; check for initialization declaration in case of Cilk_for.
+ (cp_parser_omp_for_loop): Added checks for CILK_FOR and RID_CILK_FOR;
+ changed call to cp_parser_omp_for_loop_init according new arguments'
+ list.
+ (cp_parser_pragma): Added PRAGMA_CILK_GRAINSIZE case.
+ * pt.c (tsubst_expr): Added CILK_FOR case.
+ * semantics.c: Include convert.h.
+ (finish_omp_clauses): Properly handle OMP_CLAUSE_SCHEDULE_CILKFOR
+ case; added OMP_CLAUSE__CILK_FOR_COUNT_.
+ (handle_omp_for_class_iterator): New argument lastp and its usage;
+ added NE_EXPR case.
+ (finish_omp_for): Changed call to handle_omp_for_class_iterator
+ according new arguments' list; in case of Cilk_for save very first
+ decl and create empty stmt_list block; use block to build correct
+ statement tree.
+
+2014-08-31 Jason Merrill <jason@redhat.com>
+
+ PR c++/62302
+ * optimize.c (cdtor_comdat_group): Just look at the
+ DECL_ASSEMBLER_NAME of the 'tors.
+
+2014-08-27 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/52892
+ * semantics.c (cxx_eval_call_expression): Use STRIP_NOPS on the
+ result of cxx_eval_constant_expression.
+
+2014-08-26 Jason Merrill <jason@redhat.com>
+
+ PR c++/58624
+ * pt.c (tsubst_decl) [VAR_DECL]: Copy TLS model.
+ (tsubst_copy_and_build) [VAR_DECL]: Use TLS wrapper.
+ * semantics.c (finish_id_expression): Don't call TLS wrapper in a
+ template.
+
+2014-08-25 Jason Merrill <jason@redhat.com>
+
+ * pt.c (check_explicit_specialization): Don't complain about
+ non-template variable.
+ (template_for_substitution): Allow variable templates.
+ (check_template_variable): Fix logic for member var template.
+ * decl.c (start_decl): Don't complain about extra template header
+ here.
+
+ * decl.c (start_decl): Look through member variable template.
+ * pt.c (tsubst_decl) [VAR_DECL]: Handle member variable templates.
+ * decl2.c (grokfield): Set DECL_CONTEXT earlier on
+ variables.
+
+2014-08-25 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/34938
+ * cp-tree.h (TFF_POINTER): Add.
+ * cxx-pretty-print.h (pp_cxx_cv_qualifiers): Forward the third
+ argument too.
+ * error.c (dump_type_suffix): Actually print the const and noreturn
+ attribute when appropriate.
+
+2014-08-23 Edward Smith-Rowland <3dw4rd@verizon.net>
+
+ * decl.c (compute_array_index_type, grokdeclarator,
+ undeduced_auto_decl): Change from cxx1y to cxx14.
+ *lambda.c(add_capture()): Change error message from C++1y to C++14.
+ * parser.c (cp_parser_unqualified_id, cp_parser_pseudo_destructor_name,
+ cp_parser_lambda_introducer, cp_parser_lambda_declarator_opt,
+ cp_parser_decltype, cp_parser_conversion_type_id,
+ cp_parser_simple_type_specifier, cp_parser_type_id_1,
+ cp_parser_template_type_arg, cp_parser_std_attribute,
+ cp_parser_template_declaration_after_export): Ditto.
+ * pt.c (tsubst): Ditto.
+ * semantics.c (force_paren_expr, finish_decltype_type): Ditto.
+ * tree.c: Change comment.
+ * typeck.c (comp_template_parms_position, cxx_sizeof_or_alignof_type,
+ cp_build_addr_expr_1, maybe_warn_about_useless_cast): Ditto.
+
+2014-08-23 Jason Merrill <jason@redhat.com>
+
+ Allow non-constexpr variable templates.
+ * decl2.c (note_variable_template_instantiation): New.
+ * cp-tree.h: Declare it.
+ * pt.c (instantiate_decl): Call it.
+ (push_template_decl_real): Allow non-constexpr variable templates.
+ * semantics.c (finish_id_expression): Mark the variable template
+ instantiation as used.
+ * mangle.c (write_mangled_name): Variable template instantiations
+ are mangled.
+ * parser.c (cp_parser_init_declarator): Complain about
+ non-function implicit templates.
+
+2014-08-22 Marek Polacek <polacek@redhat.com>
+
+ PR c++/62199
+ * parser.c (cp_parser_binary_expression): Check each LHS if it's
+ preceded with logical not. Adjust call to
+ warn_logical_not_parentheses.
+
+2014-08-22 Manuel López-Ibáñez <manu@gcc.gnu.org>
+
+ PR c++/57709
+ * name-lookup.c (pushdecl_maybe_friend_1): Do not warn if a
+ declaration shadows a function declaration, unless the former
+ declares a function, pointer to function or pointer to member
+ function, because this is a common and valid case in real-world
+ code.
+ * cp-tree.h (TYPE_PTRFN_P,TYPE_REFFN_P,TYPE_PTRMEMFUNC_P):
+ Improve description.
+
+2014-08-22 Jason Merrill <jason@redhat.com>
+
+ PR c++/62129
+ * class.c (outermost_open_class): Fix logic.
+ * decl.c (complete_vars): Fix logic.
+
+2014-08-22 Jason Merrill <jason@redhat.com>
+
+ PR c++/62129
+ * class.c (outermost_open_class): New.
+ * cp-tree.h: Declare it.
+ * decl.c (maybe_register_incomplete_var): Use it.
+ (complete_vars): Handle any constant variable.
+ * expr.c (cplus_expand_constant): Handle CONSTRUCTOR.
+
+2014-08-22 Igor Zamyatin <igor.zamyatin@intel.com>
+
+ PR other/62008
+ * cp-array-notation.c (build_array_notation_ref): Added correct
+ handling of case with incorrect array.
+
+2014-08-21 Manuel López-Ibáñez <manu@gcc.gnu.org>
+
+ PR fortran/44054
+ * error.c (cp_diagnostic_finalizer): Delete.
+ (init_error): Do not set diagnostic_finalizer here.
+
+2014-08-19 Marek Polacek <polacek@redhat.com>
+
+ PR c++/62153
+ * call.c (build_new_op_1): Remember the type of arguments for
+ a comparison. If either operand of a comparison is a boolean
+ expression, call maybe_warn_bool_compare.
+
+2014-08-19 Jason Merrill <jason@redhat.com>
+
+ PR tree-optimization/62091
+ * decl2.c (decl_needed_p): Return true for virtual functions when
+ devirtualizing.
+
+ PR lto/53808
+ PR c++/61659
+ * decl.c (maybe_commonize_var): Don't use DECL_COMDAT to trigger
+ comdat_linkage.
+
+2014-08-19 Gerald Pfeifer <gerald@pfeifer.com>
+
+ * class.c (contains_empty_class_p): Remove.
+
+2014-08-18 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * parser.c (cp_parser_expression): Add default arguments.
+ (cp_parser_primary_expression, cp_parser_postfix_expression,
+ cp_parser_array_notation, cp_parser_postfix_open_square_expression,
+ cp_parser_unary_expression, cp_parser_direct_new_declarator,
+ cp_parser_question_colon_clause, cp_parser_assignment_operator_opt,
+ cp_parser_lambda_body, cp_parser_expression_statement,
+ cp_parser_condition, cp_parser_c_for, cp_parser_range_for,
+ cp_parser_iteration_statement, cp_parser_jump_statement,
+ cp_parser_decltype_expr, cp_parser_noexcept_specification_opt,
+ cp_parser_asm_operand_list, cp_parser_objc_message_receiver,
+ cp_parser_objc_synchronized_statement, cp_parser_objc_throw_statement,
+ cp_parser_omp_var_list_no_open, cp_parser_omp_clause_num_threads,
+ cp_parser_omp_clause_num_teams, cp_parser_omp_clause_thread_limit,
+ cp_parser_omp_clause_linear, cp_parser_omp_clause_device,
+ cp_parser_omp_atomic, cp_parser_omp_for_loop_init,
+ cp_parser_omp_for_loop, cp_parser_omp_declare_reduction_exprs,
+ cp_parser_transaction_expression): Adjust.
+
+2014-08-15 Jason Merrill <jason@redhat.com>
+
+ PR c++/61566
+ * pt.c (lookup_template_class_1): Revert recent change.
+ * mangle.c (CLASSTYPE_TEMPLATE_ID_P): Revert recent change.
+
+ PR c++/61566
+ * pt.c (instantiate_class_template_1): Ignore lambda on
+ CLASSTYPE_DECL_LIST.
+ (push_template_decl_real): A lambda is not primary.
+ (lookup_template_class_1): Don't look for a lambda partial
+ instantiation.
+ * lambda.c (maybe_add_lambda_conv_op): Distinguish between being
+ currently in a function and the lambda living in a function.
+ * mangle.c (CLASSTYPE_TEMPLATE_ID_P): False for lambda.
+
+2014-08-15 Richard Biener <rguenther@suse.de>
+ Jason Merrill <jason@redhat.com>
+
+ PR bootstrap/62077
+ * tree.c (build_min_array_type, set_array_type_canon): Split out...
+ (build_cplus_array_type): ...from here. Only call build_array_type
+ for main variants.
+
+2014-08-15 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/62072
+ Revert:
+ 2014-07-09 Paolo Carlini <paolo.carlini@oracle.com>
+
+ DR 1584
+ PR c++/57466
+ * pt.c (check_cv_quals_for_unify): Implement resolution, disregard
+ cv-qualifiers of function types.
+
+2014-08-15 Manuel Lopez-Ibanez <manu@gcc.gnu.org>
+
+ * call.c (build_conditional_expr_1): Use OPT_Wextra in warning.
+
+2014-08-14 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * typeck.c (composite_pointer_type, cxx_sizeof_or_alignof_type,
+ cp_build_array_ref, cp_build_function_call_vec): When a
+ pedwarn is suppressed under SFINAE, return error_mark_node.
+
+ * typeck.c (cxx_sizeof_or_alignof_type): Fix complain &
+ tf_warning_or_error, where complain is a bool, glitch.
+
+2014-08-14 Ville Voutilainen <ville.voutilainen@gmail.com>
+
+ PR c++/62101
+ * decl.c (grokdeclarator): Move the check for friend initializers..
+ * decl2.c (grokfield) ..here. Postpone early return for friends
+ until after the initializer check.
+
+2014-08-14 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/54377
+ * pt.c (coerce_template_parms): Improve error message vs default
+ arguments.
+
+2014-08-14 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * parser.c (cp_parser_init_declarator): Remove redundant check of
+ decl_specifiers->type.
+
+2014-08-13 Jason Merrill <jason@redhat.com>
+
+ * call.c (build_x_va_arg): Support passing non-POD through ....
+ (convert_arg_to_ellipsis): Likewise.
+
+2014-08-13 Andrew Sutton <andrew.n.sutton@gmail.com>
+
+ * pt.c (lookup_template_variable): Make dependent variable templates
+ have unknown type.
+
+2014-08-13 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * parser.c (cp_parser_elaborated_type_specifier): Handle
+ specially cp_parser_template_id returning a BASELINK.
+
+2014-08-13 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * parser.c (cp_parser_diagnose_invalid_type_name,
+ cp_parser_make_typename_type): Remove scope parameter.
+ (cp_parser_parse_and_diagnose_invalid_type_name,
+ cp_parser_elaborated_type_specifier): Adjust calls.
+
+2014-08-12 Ville Voutilainen <ville.voutilainen@gmail.com>
+
+ Reject virt-specifiers on friends and member templates
+ * friend.c (do_friend): Diagnose virt-specifiers.
+ * pt.c (push_template_decl_real): Diagnose virt-specifiers.
+
+2014-08-09 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * typeck2.c (check_narrowing): Add tsubst_flags_t parameter, change
+ return type to bool; in C++11 for constants give errors, not pedwarns.
+ * cp-tree.h (check_narrowing): Adjust declaration.
+ * call.c (convert_like_real): Update calls.
+ * semantics.c (finish_compound_literal): Likewise.
+
+2014-08-08 Jason Merrill <jason@redhat.com>
+
+ * pt.c (lookup_template_class_1): Copy abi_tag.
+
+2014-08-08 Kai Tietz <ktietz@redhat.com>
+
+ * semantics.c (expand_or_defer_fn_1): Check for keep-inline-dllexport
+ that we operate on a true inline.
+
+2014-08-07 Trevor Saunders <tsaunders@mozilla.com>
+
+ * class.c, cp-gimplify.c, decl.c, decl2.c, error.c, method.c,
+ optimize.c, pt.c, semantics.c: Remove includes of pointer-set.h.
+
+2014-08-07 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51312
+ * decl.c (build_enumerator): Handle class types with conversion
+ operators via perform_implicit_conversion_flags and
+ build_expr_type_conversion.
+
+ * cvt.c (build_expr_type_conversion): Replace pair of errors
+ with error + inform.
+
+2014-08-07 Jason Merrill <jason@redhat.com>
+
+ PR c++/62043
+ * parser.c (c_parse_file): Change sorry to fatal_error.
+
+ PR c++/61959
+ * semantics.c (cxx_eval_bare_aggregate): Handle POINTER_PLUS_EXPR.
+
+2014-08-07 Trevor Saunders <tsaunders@mozilla.com>
+
+ * cp-tree.h, pt.c: Use hash_map instead of pointer_map.
+
+2014-08-06 Jason Merrill <jason@redhat.com>
+
+ * init.c (build_vec_init): Fix constant initialization of
+ trailing elements.
+ (build_value_init_noctor): Call maybe_constant_init.
+ * semantics.c (maybe_constant_init): See through EXPR_STMT and
+ conversion to void.
+
+ PR c++/60417
+ * init.c (build_vec_init): Reorganize earlier change a bit.
+
+ PR c++/61994
+ * init.c (build_vec_init): Leave atype an ARRAY_TYPE
+ if we're just returning an INIT_EXPR.
+
+2014-08-06 Jason Merrill <jason@redhat.com>
+ Braden Obrzut <admin@maniacsvault.net>
+
+ * pt.c (check_explicit_specialization): Don't test
+ DECL_DECLARED_INLINE_P for a variable template.
+
+2014-08-06 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/43906
+ * typeck.c (cp_build_binary_op): Extend to more cases the
+ -Waddress warning.
+
+2014-08-01 Braden Obrzut <admin@maniacsvault.net>
+
+ Implement constexpr variable templates
+ * decl.c (grokvardecl): Handle specializations of variable templates.
+ (grokdeclarator): Handle variable template id expressions and NULL_TREE
+ return from grokvardecl.
+ * decl2.c (check_member_template): Allow declaration of template member
+ variables.
+ * parser.c (cp_parser_template_id): Build a TEMPLATE_ID_EXPR for
+ variable templates.
+ * pt.c (check_template_variable): Accept variable temploids at
+ non-class scope.
+ (push_template_decl_real): The current instantiation of a template
+ can be a VAR_DECL.
+ (determine_specialization): Accept variable templates.
+ (check_explicit_specialization): Handle and check for malformed
+ variable template specializations.
+ (lookup_template_variable): New.
+ (tsubst_decl): Handle variable template specializations.
+ (do_decl_instantiation): Handle template variables.
+ (instantiate_decl): Handle template variables.
+ * semantics.c (finish_template_variable): New.
+ (finish_id_expression): Instantiate variable templates.
+ * cp-tree.h (variable_template_p): New.
+
+2014-08-02 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/15339
+ * decl.c (check_redeclaration_no_default_args): New.
+ (duplicate_decls): Use it, handle default arguments
+ in redeclarations of function templates.
+
+2014-08-02 Trevor Saunders <tsaunders@mozilla.com>
+
+ * optimize.c, semantics.c: Use hash_map instead of pointer_map.
+
+2014-08-02 Trevor Saunders <tsaunders@mozilla.com>
+
+ * class.c, cp-gimplify.c, cp-tree.h, decl.c, decl2.c, error.c,
+ method.c, name-lookup.c, pt.c, semantics.c, tree.c: Use hash_set
+ instead of pointer_set.
+
+2014-08-01 Jason Merrill <jason@redhat.com>
+
+ PR c++/60417
+ * init.c (build_vec_init): Set CONSTRUCTOR_IS_DIRECT_INIT on
+ init-list for trailing elements.
+ * typeck2.c (process_init_constructor_array): Likewise.
+
+2014-08-01 Paolo Carlini <paolo.carlini@oracle.com>
+
+ DR 217 again
+ * decl.c (duplicate_decls): Handle static member functions too.
+
+2014-08-01 Igor Zamyatin <igor.zamyatin@intel.com>
+
+ * cp-array-notation.c (expand_an_in_modify_expr): Fix the misprint
+ in error output.
+
+2014-08-01 Igor Zamyatin <igor.zamyatin@intel.com>
+
+ PR other/61963
+ * parser.c (cp_parser_array_notation): Added check for array_type.
+
+2014-08-01 Igor Zamyatin <igor.zamyatin@intel.com>
+
+ PR middle-end/61455
+ * cp-array-notation.c (expand_array_notation_exprs): Handling of
+ DECL_EXPR improved. Changed handling for INIT_EXPR.
+
+2014-08-01 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * pt.c (lookup_template_class_1): Use DECL_TYPE_TEMPLATE_P.
+
+2014-08-01 Jakub Jelinek <jakub@redhat.com>
+
+ * cp-gimplify.c (cp_genericize_r): For -fsanitize=null and/or
+ -fsanitize=alignment call ubsan_maybe_instrument_reference
+ for casts to REFERENCE_TYPE and ubsan_maybe_instrument_member_call
+ for calls to member functions.
+
+2014-07-31 Marc Glisse <marc.glisse@inria.fr>
+
+ PR c++/60517
+ * typeck.c (maybe_warn_about_returning_address_of_local): Return
+ whether it is returning the address of a local variable.
+ (check_return_expr): Return 0 instead of the address of a local
+ variable.
+
+2014-07-30 Jason Merrill <jason@redhat.com>
+
+ PR lto/53808
+ PR c++/61659
+ * pt.c (push_template_decl_real): Don't set DECL_COMDAT on friends.
+
+2014-07-30 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/57397
+ * pt.c (unify_arity): Add boolean parameter.
+ (unify_too_few_arguments): Likewise.
+ (type_unification_real): Diagnose correctly insufficient
+ arguments in the presence of trailing variadic parameters;
+ deducing multiple trailing packs as empty is fine.
+
+2014-07-30 Jason Merrill <jason@redhat.com>
+
+ PR c++/61659
+ PR c++/61687
+ Revert:
+ * decl2.c (mark_all_virtuals): New variable.
+ (maybe_emit_vtables): Check it instead of flag_devirtualize.
+ (cp_write_global_declarations): Set it and give helpful diagnostic
+ if it introduces errors.
+ * class.c (finish_struct_1): Check it.
+
+ PR lto/53808
+ PR c++/61659
+ * pt.c (push_template_decl_real): Set DECL_COMDAT on templates.
+ (check_explicit_specialization): Clear it on specializations.
+ * decl.c (duplicate_decls, start_decl): Likewise.
+ (grokmethod, grokfndecl): Set DECL_COMDAT on inlines.
+ * method.c (implicitly_declare_fn): Set DECL_COMDAT. Determine
+ linkage after setting the appropriate flags.
+ * tree.c (decl_linkage): Don't check DECL_COMDAT.
+ * decl2.c (mark_needed): Mark clones.
+ (import_export_decl): Not here.
+
+2014-07-25 Edward Smith-Rowland <3dw4rd@verizon.net>
+
+ Implement N4051 - Allow typename in a template template parameter
+ * parser.c (cp_parser_type_parameter_key): New funtion;
+ (cp_parser_token_is_type_parameter_key): Ditto;
+ (cp_parser_type_parameter): Look for type-parameter-key for all versions
+ but pedwarn for less than cxx1z.
+
+2014-07-17 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50961
+ * call.c (standard_conversion): Use resolve_nondeduced_context
+ for type_unknown_p (EXPR) && TREE_CODE (TO) == BOOLEAN_TYPE.
+
+2014-07-17 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/61804
+ * parser.c (cp_parser_tokens_start_cast_expression): Return -1
+ for '++' and '--'.
+
+2014-07-15 Jason Merrill <jason@redhat.com>
+
+ PR c++/61811
+ * decl2.c (maybe_emit_vtables): Return true for -fuse-all-virtuals.
+
+ PR c++/60848
+ PR c++/61723
+ * call.c (is_std_init_list): Don't check CLASSTYPE_TEMPLATE_INFO.
+ * class.c (finish_struct): Reject invalid definition of
+ std::initializer_list.
+
+2014-07-15 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * call.c (convert_like_real): Call print_z_candidate and inform only
+ if permerror returns true.
+
+2014-07-14 Jan Hubicka <hubicka@ucw.cz>
+
+ * class.c (build_clone): Do not clear assembler names of
+ templates.
+ * decl.c (cp_tree_node_structure): Add TEMPLATE_DECL.
+ * cp-objcp-common.c (cp_tree_size): Add TEMPLATE_DECL
+ as a special case return sizeof (struct tree_decl_non_common)
+ for other decls.
+ (cp_common_init_ts): Do not initialize NAMESPACE_DECL;
+ initialize TEMPLATE_DECL as MARK_TS_DECL_COMMON.
+ * cp/cp-tree.h (tree_template_decl): New structure.
+ (cp_tree_node_structure_enum): Add TS_CP_TEMPLATE_DECL.
+ (union cp_lang_tree_node): Add template_decl.
+ (DECL_TEMPLATE_PARMS, DECL_TEMPLATE_RESULT): Update.
+
+2014-07-14 Jason Merrill <jason@redhat.com>
+
+ PR c++/61445
+ PR c++/56947
+ * pt.c (instantiate_decl): Don't check defer_ok for local class
+ members.
+
+2014-07-14 Jakub Jelinek <jakub@redhat.com>
+
+ PR middle-end/61294
+ * cp-tree.h (LITERAL_ZERO_P): Define.
+ * parser.c (cp_parser_parenthesized_expression_list): Add
+ want_literal_zero_p argument, if true, for literal zeros
+ insert INTEGER_CSTs with LITERAL_ZERO_P flag set.
+ (cp_parser_postfix_expression): Adjust
+ cp_parser_parenthesized_expression_list caller, handle
+ -Wmemset-transposed-args.
+ (literal_zeros): New variable.
+
+2014-07-13 Jason Merrill <jason@redhat.com>
+
+ PR c++/58511
+ * semantics.c (is_instantiation_of_constexpr): Return true for
+ defaulted functions, too.
+ (explain_invalid_constexpr_fn): Only use
+ explain_implicit_non_constexpr if !DECL_DECLARED_CONSTEXPR_P.
+ * method.c (explain_implicit_non_constexpr): Pass
+ DECL_INHERITED_CTOR_BASE to explain_implicit_non_constexpr.
+
+ PR c++/58611
+ * decl.c (check_initializer): Don't finish_compound_literal
+ on erroneous constexpr init.
+
+ PR c++/58612
+ * tree.c (bot_replace): Only replace a dummy 'this' parm.
+
+ PR c++/60628
+ * decl.c (create_array_type_for_decl): Only check for auto once.
+
+ PR c++/58636
+ * call.c (build_list_conv): Don't try to build a list of references.
+
+2014-07-13 Edward Smith-Rowland <3dw4rd@verizon.net>
+
+ PR C++/60209 - Declaration of user-defined literal operator cause error
+ * parser.c (cp_parser_operator): Fold treatment of strings
+ and user-defined string literals. Use the full string parser.
+ (cp_parser_string_literal): Add flag to not look for literal operator.
+
+2014-07-11 Jason Merrill <jason@redhat.com>
+
+ PR c++/22434
+ PR c++/61288
+ * call.c (build_conditional_expr_1): Avoid reading freed memory.
+
+2014-07-11 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/53159
+ * call.c (build_user_type_conversion_1): Copy LOOKUP_NO_NARROWING
+ into convflags.
+ * decl.c (check_initializer): Don't call check_narrowing here,
+ set LOOKUP_NO_NARROWING.
+ * typeck2.c (digest_init_r): Likewise.
+
+2014-07-10 Jason Merrill <jason@redhat.com>
+
+ PR c++/61661
+ * semantics.c (reduced_constant_expression_p): Handle CONSTRUCTOR.
+
+ PR c++/61659
+ PR c++/61687
+ * decl2.c (mark_all_virtuals): New variable.
+ (maybe_emit_vtables): Check it instead of flag_devirtualize.
+ (cp_write_global_declarations): Set it and give helpful diagnostic
+ if it introduces errors.
+ * class.c (finish_struct_1): Check it.
+ * decl.c (grokdeclarator): Clear virtualp after 'virtual auto' error.
+
+2014-07-09 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/60686
+ * decl.c (grokdeclarator): Adjust error messages about 'explicit'
+ outside class declaration, in friend declaration, and neither on
+ constructor nor conversion operator.
+
+2014-07-09 Paolo Carlini <paolo.carlini@oracle.com>
+
+ DR 1584
+ PR c++/57466
+ * pt.c (check_cv_quals_for_unify): Implement resolution, disregard
+ cv-qualifiers of function types.
+
+2014-07-09 Andrew Sutton <andrew.n.sutton@gmail.com>
+ Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/59361
+ * parser.c (cp_parser_tokens_start_cast_expression): Return 0 for
+ CPP_ELLIPSIS too.
+
+2014-07-07 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * class.c (check_for_override): Wrap the 'final' and 'override'
+ keywords in %< and %>.
+
+2014-07-06 Marek Polacek <polacek@redhat.com>
+
+ PR c/6940
+ * cp-tree.h (DECL_ARRAY_PARAMETER_P): Define.
+ * decl.c (grokdeclarator): Set DECL_ARRAY_PARAMETER_P.
+ * typeck.c (cxx_sizeof_expr): Warn when using sizeof on an array
+ function parameter.
+
+2014-07-02 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * pt.c (convert_template_argument): Use inform instead of error in
+ three places.
+
+2014-06-30 Edward Smith-Rowland <3dw4rd@verizon.net>
+
+ PR c++/58781
+ PR c++/60249
+ PR c++/59867
+ * parser.c (cp_parser_userdef_string_literal): Take a tree
+ not a cp_token*.
+ (cp_parser_string_literal): Don't hack the token stream.
+
+2014-06-30 Jason Merrill <jason@redhat.com>
+
+ PR c++/61659
+ PR lto/53808
+ * decl2.c (maybe_emit_vtables): Mark all vtable entries if
+ devirtualizing.
+ * init.c (build_vtbl_address): Don't mark destructor.
+ * class.c (finish_struct_1): Add all classes to keyed_classes
+ if devirtualizing.
+
+ PR c++/61647
+ * pt.c (type_dependent_expression_p): Check BASELINK_OPTYPE.
+
+ PR c++/61566
+ * mangle.c (decl_mangling_context): Look through a TEMPLATE_DECL.
+
+ * decl.c (build_ptrmemfunc_type): Don't give a PMF RECORD_TYPE
+ TYPE_BINFO or TYPE_LANG_SPECIFIC.
+ * cp-tree.h (TYPE_PTRMEMFUNC_FLAG): Use TYPE_LANG_FLAG_2.
+ (TYPE_PTRMEMFUNC_P): Don't expect TYPE_LANG_SPECIFIC.
+ * typeck.c (build_ptrmemfunc_access_expr): Don't use lookup_member.
+ * pt.c (unify): Also check whether the argument is a PMF.
+
+2014-06-30 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/54891
+ * parser.c (cp_parser_tokens_start_cast_expression): In C++11
+ a '[' can also start a primary-expression.
+ (cp_parser_cast_expression): Parse a cast-expression only tentatively
+ when cp_parser_tokens_start_cast_expression returns -1.
+
+2014-06-30 Jason Merrill <jason@redhat.com>
+
+ PR c++/61539
+ * pt.c (unify_one_argument): Type/expression mismatch just causes
+ deduction failure.
+
+ * semantics.c (simplify_aggr_init_expr): Remove remnants of
+ 2014-04-11 change.
+
+2014-06-30 Marek Polacek <polacek@redhat.com>
+
+ * cp-gimplify.c (cp_genericize): Don't instrument returns if the
+ function has no_sanitize_undefined attribute.
+ * decl.c (compute_array_index_type): Don't instrument VLAs if the
+ function has no_sanitize_undefined attribute.
+
+2014-06-30 Igor Zamyatin <igor.zamyatin@intel.com>
+
+ PR middle-end/57541
+ * cp-array-notation.c (expand_sec_reduce_builtin):
+ Check that bultin argument is correct.
+ * call.c (build_cxx_call): Check for 0 arguments in builtin call.
+
+2014-06-28 Jonathan Wakely <jwakely@redhat.com>
+
+ DR 1579
+ PR c++/58051
+ * typeck.c (check_return_expr): Lookup as an rvalue even when the
+ types aren't the same.
+
+2014-06-27 Jason Merrill <jason@redhat.com>
+
+ PR c++/61433
+ * error.c (dump_template_bindings): Don't tsubst in a clone.
+
+2014-06-27 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/61614
+ * semantics.c (finish_compound_literal): Revert r204228.
+
+2014-06-27 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * parser.c (cp_parser_compound_literal_p): New.
+ (cp_parser_postfix_expression, cp_parser_sizeof_operand): Use it.
+
+2014-06-26 Jason Merrill <jason@redhat.com>
+
+ * parser.c (cp_parser_for_init_statement): Change range-for error
+ to pedwarn.
+
+ N3994 Ranged-based for-loops: The Next Generation
+ * parser.c (cp_lexer_nth_token_is): New.
+ (cp_parser_for_init_statement): Allow "for (id : init)".
+
+2014-06-26 Teresa Johnson <tejohnson@google.com>
+
+ * class.c (dump_class_hierarchy): Use saved dump files.
+ (dump_vtable): Ditto.
+ (dump_vtt): Ditto.
+
+2014-06-26 Adam Butcher <adam@jessamine.co.uk>
+
+ PR c++/61537
+ * parser.c (cp_parser_elaborated_type_specifier): Only consider template
+ parameter lists outside of function parameter scope.
+
+2014-06-25 Paolo Carlini <paolo.carlini@oracle.com>
+
+ DR 178
+ PR c++/49132
+ * typeck2.c (process_init_constructor_record): Do not complain about
+ uninitialized const members, because within aggregate-initialization,
+ members without explicit initializers are value-initialized.
+
+2014-06-25 Jakub Jelinek <jakub@redhat.com>
+
+ * semantics.c (finish_omp_clauses): Make sure
+ OMP_CLAUSE_LINEAR_STEP has correct type.
+
+2014-06-24 Jan Hubicka <hubicka@ucw.cz>
+
+ * class.c (check_methods, create_vtable_ptr, determine_key_method,
+ add_vcall_offset_vtbl_entries_1): Guard VINDEX checks by
+ FUNCTION_DECL check.
+ * cp-tree.h (lang_decl_ns): Add ns_using and ns_users.
+ (DECL_NAMESPACE_USING, DECL_NAMESPACE_USERS): Use lang_decl_ns.
+ (DECL_NAMESPACE_ASSOCIATIONS): Use DECL_INITIAL.
+ (DECL_TEMPLATE_INSTANTIATIONS): Use DECL_SIZE_UNIT.
+
+2014-06-24 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/33972
+ * decl.c (grokdeclarator): Do not early check for operator-function-id
+ as non-function.
+
+2014-06-24 Trevor Saunders <tsaunders@mozilla.com>
+
+ * class.c, semantics.c, tree.c, vtable-class-hierarchy.c:
+ Adjust.
+
+2014-06-24 Jakub Jelinek <jakub@redhat.com>
+
+ * parser.c (cp_parser_omp_for_loop): For
+ #pragma omp parallel for simd move lastprivate clause from parallel
+ to for rather than simd.
+
+2014-06-23 Paolo Carlini <paolo.carlini@oracle.com>
+
+ DR 577
+ PR c++/33101
+ * decl.c (grokparms): Accept a single parameter of type 'void'.
+
+2014-06-20 Jason Merrill <jason@redhat.com>
+
+ PR c++/59296
+ * call.c (add_function_candidate): Avoid special 'this' handling
+ if we have a ref-qualifier.
+
+ PR c++/61556
+ * call.c (build_over_call): Call build_this in template path.
+
+2014-06-19 Jason Merrill <jason@redhat.com>
+
+ PR c++/59296
+ * call.c (add_function_candidate): Also set LOOKUP_NO_TEMP_BIND.
+
+2014-06-18 Jason Merrill <jason@redhat.com>
+
+ PR c++/59296
+ * call.c (add_function_candidate): Set LOOKUP_NO_RVAL_BIND for
+ ref-qualifier handling.
+
+ PR c++/61507
+ * pt.c (resolve_overloaded_unification): Preserve
+ ARGUMENT_PACK_EXPLICIT_ARGS.
+
+2014-06-18 Jakub Jelinek <jakub@redhat.com>
+
+ * cp-gimplify.c (cxx_omp_finish_clause): Add a gimple_seq *
+ argument.
+ * cp-tree.h (cxx_omp_finish_clause): Adjust prototype.
+
+2014-06-17 Jason Merrill <jason@redhat.com>
+
+ PR c++/60605
+ * pt.c (check_default_tmpl_args): Check DECL_LOCAL_FUNCTION_P.
+
+2014-06-15 Jason Merrill <jason@redhat.com>
+
+ PR c++/61488
+ * pt.c (check_valid_ptrmem_cst_expr): Fix for template context.
+
+ PR c++/61500
+ * tree.c (lvalue_kind): Handle MEMBER_REF and DOTSTAR_EXPR.
+
+2014-06-15 Jan Hubicka <hubicka@ucw.cz>
+
+ * decl.c (grokvardecl): Fix pasto in previous patch.
+
+2014-06-15 Jan Hubicka <hubicka@ucw.cz>
+
+ * decl.c (duplicate_decls): Use set_decl_tls_model.
+ (grokdeclarator): Likewise.
+ * semantics.c (finish_id_expression): Check TLS only for
+ static variables.
+ (finish_omp_threadprivate): Use decl_default_tls_model.
+ * decl2.c (get_guard): Likewise.
+ * call.c (make_temporary_var_for_ref_to_temp): Likewise.
+
+2014-06-14 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/33101
+ * decl.c (grokparms): Improve error message about void parameters.
+ * error.c (type_to_string): Fix aka cut off code.
+
+2014-06-12 Jason Merrill <jason@redhat.com>
+
+ * call.c (convert_arg_to_ellipsis): Use abi_version_crosses.
+ * cvt.c (type_promotes_to): Likewise.
+ * mangle.c (write_type, write_expression): Likewise.
+ (write_name, write_template_arg): Likewise.
+ (mangle_decl): Make alias based on flag_abi_compat_version.
+ Emit -Wabi warning here.
+ (finish_mangling_internal): Not here. Drop warn parm.
+ (finish_mangling_get_identifier, finish_mangling): Adjust.
+ (mangle_type_string, mangle_special_for_type): Adjust.
+ (mangle_ctor_vtbl_for_type, mangle_thunk): Adjust.
+ (mangle_guard_variable, mangle_tls_init_fn): Adjust.
+ (mangle_tls_wrapper_fn, mangle_ref_init_variable): Adjust.
+
+ * call.c (build_operator_new_call): Remove -fabi-version=1 support.
+ * class.c (walk_subobject_offsets, include_empty_classes): Likewise.
+ (layout_nonempty_base_or_field, end_of_class): Likewise.
+ (layout_empty_base, build_base_field, layout_class_type): Likewise.
+ (is_empty_class, add_vcall_offset_vtbl_entries_1): Likewise.
+ (layout_virtual_bases): Likewise.
+ * decl.c (compute_array_index_type): Likewise.
+ * mangle.c (write_mangled_name, write_prefix): Likewise.
+ (write_template_prefix, write_integer_cst, write_expression): Likewise.
+ (write_template_arg, write_array_type): Likewise.
+ * method.c (lazily_declare_fn): Likewise.
+ * rtti.c (get_pseudo_ti_index): Likewise.
+ * typeck.c (comp_array_types): Likewise.
+
+2014-06-11 Jan Hubicka <hubicka@ucw.cz>
+
+ * vtable-class-hierarchy.c: Update handling for section names
+ that are no longer trees.
+ * decl.c (duplicate_decls): Likewise.
+
+2014-06-11 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/19200
+ * parser.c (cp_parser_init_declarator): Actually pass friend_p
+ to cp_parser_declarator.
+
+2014-06-11 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/60265
+ * parser.c (cp_parser_using_declaration): Handle unscoped enums.
+ * name-lookup.c (validate_nonmember_using_decl): Adjust error
+ message.
+
+2014-06-11 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/19200
+ * parser.c (cp_parser_declarator): Add bool parameter.
+ (cp_parser_direct_declarator): Likewise, use it.
+ (cp_parser_member_declaration): Pass friend_p to cp_parser_declarator.
+ (cp_parser_condition, cp_parser_explicit_instantiation,
+ cp_parser_init_declarator, cp_parser_type_id_1,
+ cp_parser_parameter_declaration, cp_parser_exception_declaration,
+ cp_parser_cache_defarg, cp_parser_objc_class_ivars,
+ cp_parser_objc_struct_declaration, cp_parser_omp_for_loop_init):
+ Adjust.
+ * decl.c (grokdeclarator): Fix handling of friend declared in
+ namespace scope (g++.dg/parse/friend10.C).
+
+2014-06-10 Jan Hubicka <hubicka@ucw.cz>
+
+ * vtable-class-hierarchy.c: Use symtab_get_node (var_decl)
+ ->implicit_section.
+ * optimize.c (cdtor_comdat_group): Fix handling of aliases.
+ (maybe_clone_body): Move symbol across comdat groups.
+ * method.c (use_thunk): Copy implicit section flag.
+
+2014-06-09 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/22556
+ * name-lookup.c (pushdecl_maybe_friend_1): Use comptypes.
+
+2014-06-07 Jan Hubicka <hubicka@ucw.cz>
+
+ * method.c (use_thunk): Use set_decl_section_name.
+ * optimize.c (maybe_clone_body): Use set_decl_section_name.
+ * decl.c (duplicate_decls): Likewise.
+ * vtable-class-hierarchy.c: Likewise.
+
+2014-06-06 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/60184
+ * class.c (check_field_decls): In C++11 mode do not reject
+ static data members and reference-type members in unions.
+
+2014-06-05 Jason Merrill <jason@redhat.com>
+
+ PR c++/43453
+ * decl.c (check_initializer): Collapse a TREE_LIST here.
+ * typeck2.c (store_init_value): Not here.
+
+2014-06-05 Richard Biener <rguenther@suse.de>
+ Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/56961
+ * cp-gimplify.c (cp_gimplify_expr, [MODIFY_EXPR]): Rework
+ handling of empty classes.
+
+2014-06-04 Jason Merrill <jason@redhat.com>
+
+ * parser.c (cp_parser_diagnose_invalid_type_name): Give helpful note
+ for noexcept and thread_local, too.
+
+ PR c++/61343
+ * decl.c (check_initializer): Maybe clear
+ DECL_INITIALIZED_BY_CONSTANT_EXPRESSION_P.
+
+2014-06-05 Richard Biener <rguenther@suse.de>
+
+ PR c++/61004
+ * typeck.c (cp_build_indirect_ref): Do not emit strict-aliasing
+ warnings for accessing empty classes.
+
+2014-06-05 Marek Polacek <polacek@redhat.com>
+
+ PR c/49706
+ * parser.c (cp_parser_binary_expression): Warn when logical not is
+ used on the left hand side operand of a comparison.
+
+2014-06-04 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/43453
+ * typeck.c (cp_build_modify_expr): Handle array of characters
+ initialized by a string literal.
+ * decl.c (check_initializer): Handle parenthesized string literal
+ as initializer.
+ * typeck2.c (store_init_value): Remove redundant check.
+
+2014-06-04 Jason Merrill <jason@redhat.com>
+
+ PR c++/51253
+ PR c++/61382
+ * cp-gimplify.c (cp_gimplify_expr): Handle CALL_EXPR_LIST_INIT_P here.
+ * semantics.c (simplify_aggr_init_expr): Not here, just copy it.
+
+2014-06-04 Igor Zamyatin <igor.zamyatin@intel.com>
+
+ PR c/58942
+ * cp-array-notation.c (expand_sec_reduce_builtin): Handle the case
+ with a pointer.
+
+2014-06-03 Paolo Carlini <paolo.carlini@oracle.com>
+
+ DR 1423
+ PR c++/52174
+ * call.c (standard_conversion): Convert nullptr to bool only
+ in case of direct-initialization.
+ (convert_like_real): Provide informative error message.
+
+2014-06-03 Marek Polacek <polacek@redhat.com>
+
+ PR c/60439
+ * semantics.c (finish_switch_cond): Warn if switch condition has
+ boolean value.
+
+2014-06-03 Jason Merrill <jason@redhat.com>
+
+ PR c++/60992
+ * pt.c (tsubst_copy) [VAR_DECL]: Try lookup first. Add a new
+ variable to local_specializations.
+
+ PR c++/60848
+ * call.c (is_std_init_list): Check CLASSTYPE_TEMPLATE_INFO.
+
+2014-06-02 Jason Merrill <jason@redhat.com>
+
+ PR c++/61046
+ * decl.c (reshape_init_class): Handle un-folded
+ constant-expressions.
+
+ PR c++/61134
+ * pt.c (pack_deducible_p): Handle canonicalization.
+
+2014-06-02 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * pt.c (tsubst_function_type): Initialize arg_types.
+
+2014-06-02 Siva Chandra Reddy <sivachandra@google.com>
+
+ PR debug/57519
+ * class.c (handle_using_decl): Pass the correct scope to
+ cp_emit_debug_info_for_using.
+
+2014-06-02 Ville Voutilainen <ville.voutilainen@gmail.com>
+
+ PR c++/59483
+ PR c++/61148
+ * search.c (accessible_p): Use current_nonlambda_class_type.
+ * semantics.c (check_accessibility_of_qualified_id): Likewise.
+
+2014-06-02 Andrew MacLeod <amacleod@redhat.com>
+
+ * decl.c: Include builtins.h.
+ * semantics.c: Likewise.
+
+2014-05-31 Paolo Carlini <paolo.carlini@oracle.com>
+
+ DR 1227
+ PR c++/57543
+ * cp-tree.h (TYPE_HAS_LATE_RETURN_TYPE): Add.
+ * pt.c (tsubst_function_type): Inject the this parameter; do the
+ substitutions in the order mandated by the DR.
+ (copy_default_args_to_explicit_spec): Copy TYPE_HAS_LATE_RETURN_TYPE.
+ * decl.c (grokdeclarator): Maybe set TYPE_HAS_LATE_RETURN_TYPE.
+ (static_fn_type): Copy it.
+ * decl2.c (build_memfn_type, change_return_type,
+ cp_reconstruct_complex_type): Likewise.
+ * parser.c (cp_parser_lambda_declarator_opt): Likewise.
+ * tree.c (strip_typedefs): Likewise.
+ * typeck.c (merge_types): Likewise.
+
+2014-05-30 Jason Merrill <jason@redhat.com>
+
+ PR c++/56947
+ * pt.c (instantiate_decl): Check that defer_ok is not set for
+ local class members.
+
+ PR c++/60992
+ * pt.c (tsubst_init): Split out from...
+ (tsubst_expr) [DECL_EXPR]: Here.
+ (tsubst_copy) [VAR_DECL]: Use it.
+ * semantics.c (finish_id_expression): Return the decl for static/const.
+
+2014-05-28 Jason Merrill <jason@redhat.com>
+
+ PR c++/47202
+ * decl.c (cxx_comdat_group): Return a decl.
+ * optimize.c (cdtor_comdat_group): Get its DECL_ASSEMBLER_NAME.
+
+ * pt.c (tsubst) [ARRAY_TYPE]: Check for array of array of unknown
+ bound.
+
+ PR c++/61242
+ * call.c (build_aggr_conv): Ignore passed in flags.
+ (build_array_conv, build_complex_conv): Likewise.
+
+2014-05-23 Jan Hubicka <hubicka@ucw.cz>
+
+ * optimize.c (maybe_thunk_body): Use set_comdat_group.
+ (maybe_clone_body): Likewise.
+ * decl.c (duplicate_decls): Update code duplicating comdat group;
+ do not copy symtab pointer; before freeing newdecl remove it
+ from symtab.
+ * decl2.c (constrain_visibility): Use set_comdat_group.
+
+2014-05-23 Jan Hubicka <hubicka@ucw.cz>
+
+ * rtti.c: Include tm_p.h
+ (emit_tinfo_decl): Force RTTI data to be aligned to required
+ ABI alignment only.
+
+2014-05-23 Jan Hubicka <hubicka@ucw.cz>
+
+ * class.c (build_vtable): Align vtables to TARGET_VTABLE_ENTRY_ALIGN
+ ignoring other target adjustments.
+
+2014-05-23 Thomas Schwinge <thomas@codesourcery.com>
+
+ * semantics.c (finish_omp_clauses): Remove duplicated variable
+ initialization.
+
+ * parser.c (cp_parser_omp_target): Return bool values.
+
+2014-05-22 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/61088
+ * lambda.c (add_capture): Enforce that capture by value requires
+ complete type.
+ * typeck2.c (cxx_incomplete_type_inform): Early return if
+ TYPE_MAIN_DECL is null.
+
+2014-05-21 Jonathan Wakely <jwakely@redhat.com>
+
+ PR c/61271
+ * cp-array-notation.c (cilkplus_an_triplet_types_ok_p): Fix condition.
+
+2014-05-21 Ville Voutilainen <ville.voutilainen@gmail.com>
+
+ PR c++/61133
+ * lambda.c (build_capture_proxy, add_capture): Treat normal
+ captures and init-captures identically.
+
+2014-05-21 Mark Wielaard <mjw@redhat.com>
+
+ PR debug/16063
+ * cp-lang.c (cxx_enum_underlying_base_type): New function.
+ (LANG_HOOKS_ENUM_UNDERLYING_BASE_TYPE): Define.
+
+2014-05-21 Richard Sandiford <rsandifo@linux.vnet.ibm.com>
+
+ * cvt.c (convert_to_void): Use void_node instead of void_zero_node.
+ * cp-array-notation.c (replace_invariant_exprs): Likewise.
+ (expand_array_notation): Handle VOID_CST.
+ * error.c (dump_expr): Likewise.
+ * cxx-pretty-print.c (cxx_pretty_printer::primary_expression)
+ (cxx_pretty_printer::expression): Likewise.
+ (pp_cxx_new_expression): Use void_node instead of void_zero_node.
+ * decl.c (register_dtor_fn): Likewise.
+ * init.c (build_raw_new_expr, build_new_1, build_vec_init)
+ (build_delete, push_base_cleanups): Likewise.
+ * mangle.c (write_expression): Likewise.
+ * semantics.c (finish_break_stmt, empty_expr_stmt_p): Likewise.
+ * pt.c (tsubst_decl, tsubst_copy_and_build): Likewise.
+ (tsubst, tsubst_copy, build_non_dependent_expr): Handle VOID_CST.
+ * tree.c (cp_tree_equal): Likewise.
+ (build_dummy_object, is_dummy_object, stabilize_expr): Use void_node
+ instead of void_zero_node.
+ * typeck.c (check_return_expr): Likewise.
+ * typeck2.c (build_functional_cast): Likewise.
+
+2014-05-21 Igor Zamyatin <igor.zamyatin@intel.com>
+
+ PR c/60189
+ * parser.c (cp_parser_postfix_expression): Move handling of cilk_sync
+ from here to...
+ (cp_parser_statement): ...here. Make sure only semicolon can go after
+ Cilk_sync.
+
+2014-05-20 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/58753
+ PR c++/58930
+ PR c++/58704
+ * typeck2.c (digest_nsdmi_init): New.
+ * parser.c (cp_parser_late_parse_one_default_arg): Use it.
+ * init.c (get_nsdmi): Likewise.
+ * cp-tree.h (digest_nsdmi_init): Declare.
+
+2014-05-20 Jason Merrill <jason@redhat.com>
+
+ * typeck.c (get_member_function_from_ptrfunc): Don't try to look
+ up a virtual function in a dummy object.
+
+2014-05-20 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/60373
+ * decl.c (duplicate_decls): Replace pair of warning_at with
+ warning_at + inform.
+ (maybe_commonize_var): Likewise.
+
+2014-05-20 Richard Sandiford <rsandifo@linux.vnet.ibm.com>
+
+ PR bootstrap/61210
+ * pt.c (tsubst_copy, tsubst_omp_for_iterator, tsubst_expr)
+ (tsubst_copy_and_build): Perform recursive substitutions in a
+ deterministic order.
+
+2014-05-20 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/58664
+ * typeck2.c (cxx_incomplete_type_inform): New.
+ (cxx_incomplete_type_diagnostic): Use it.
+ * decl.c (grokdeclarator): Check the element type of an
+ incomplete array type; call the above.
+ * cp-tree.h (cxx_incomplete_type_inform): Declare.
+
+2014-05-19 Jason Merrill <jason@redhat.com>
+
+ PR c++/58761
+ * pt.c (tsubst_copy): Don't check at_function_scope_p.
+ (instantiate_class_template_1): Don't push_to_top_level in an nsdmi.
+
+2014-05-19 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * typeck2.c (cxx_incomplete_type_diagnostic): Use inform.
+ * parser.c (cp_parser_enum_specifier): Likewise.
+
+2014-05-17 Trevor Saunders <tsaunders@mozilla.com>
+
+ * class.c (sorted_fields_type_new): Adjust.
+ * cp-cilkplus.c (cilk_install_body_with_frame_cleanup): Likewise.
+ * cp-objcp-common.c (decl_shadowed_for_var_insert): Likewise.
+ * cp-tree.h: Remove usage of variable_size gty attribute.
+ * decl.c (make_label_decl): Adjust.
+ (check_goto): Likewise.
+ (start_preparsed_function): Likewise.
+ (save_function_data): Likewise.
+ * lex.c (init_reswords): Likewise.
+ (retrofit_lang_decl): Likewise.
+ (cxx_dup_lang_specific_decl): Likewise.
+ (copy_lang_type): Likewise.
+ (cxx_make_type): Likewise.
+ * name-lookup.c (binding_entry_make): Likewise.
+ (binding_table_construct): Likewise.
+ (binding_table_new): Likewise.
+ (cxx_binding_make): Likewise.
+ (pushdecl_maybe_friend_1): Likewise.
+ (begin_scope): Likewise.
+ (push_to_top_level): Likewise.
+ * parser.c (cp_lexer_alloc): Likewise.
+ (cp_lexer_new_from_tokens): Likewise.
+ (cp_token_cache_new): Likewise.
+ (cp_parser_context_new): Likewise.
+ (cp_parser_new): Likewise.
+ (cp_parser_nested_name_specifier_opt): Likewise.
+ (cp_parser_template_id): Likewise.
+ * pt.c (maybe_process_partial_specialization): Likewise.
+ (register_specialization): Likewise.
+ (add_pending_template): Likewise.
+ (lookup_template_class_1): Likewise.
+ (push_tinst_level): Likewise.
+ * semantics.c (register_constexpr_fundef): Likewise.
+ (cxx_eval_call_expression): Likewise.
+ * typeck2.c (abstract_virtuals_error_sfinae): Likewise.
+
+2014-05-16 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51640
+ * parser.c (cp_parser_diagnose_invalid_type_name): Early return
+ when cp_parser_lookup_name sets ambiguous_decls.
+
+2014-05-15 Jason Merrill <jason@redhat.com>
+
+ * call.c (print_conversion_rejection): Use loc consistently.
+
+2014-05-14 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * cp-tree.h (DIRECT_LIST_INIT_P): Add.
+ * call.c (convert_like_real, build_new_method_call_1): Use it.
+ * decl2.c (grokfield): Likewise.
+ * init.c (perform_member_init, build_aggr_init, expand_default_init,
+ build_new_1): Likewise.
+ * mangle.c (write_expression): Likewise.
+ * parser.c (cp_parser_late_parse_one_default_arg): Likewise.
+
+2014-05-14 Jason Merrill <jason@redhat.com>
+
+ PR c++/20332
+ PR c++/21631
+ * call.c (reference_binding): Treat lvalue/rvalue mismatch and
+ dropped cv-quals as a bad conversion.
+ (convert_like_real) [ck_ref_bind]: Explain them.
+ (compare_ics): Check badness before stripping reference
+ bindings. Handle comparing bad reference bindings.
+ * typeck.c (comp_cv_qualification): Add overload that just takes
+ integers.
+ * cp-tree.h: Declare it.
+
+ * call.c (struct conversion_info): Rename 'from_type' to 'from'.
+ (arg_conversion_rejection, bad_arg_conversion_rejection)
+ (explicit_conversion_rejection, template_conversion_rejection): Adjust.
+ (add_function_candidate): Pass actual argument, rather than type, to
+ bad_arg_conversion_rejection.
+ (print_conversion_rejection): Explain what's wrong with the conversion.
+ (print_z_candidates): Say "candidate:" before each candidate.
+ (splice_viable): Be strict if we see a viable or template candidate.
+ (build_user_type_conversion_1): Pass false to strict parameter.
+ (perform_overload_resolution, build_conditional_expr_1): Likewise.
+ (build_new_op_1, build_new_method_call_1): Likewise.
+ (build_op_call_1): Pass true to strict parameter.
+
+2014-05-13 Jason Merrill <jason@redhat.com>
+
+ * call.c (print_error_for_call_failure): Say "no match" rather
+ than "ambiguous" if there were no strict matches.
+ (build_new_method_call_1): Likewise.
+
+ PR c++/61151
+ * semantics.c (is_this_parameter): Allow capture proxies too.
+
+2014-05-12 Jason Merrill <jason@redhat.com>
+
+ * call.c (maybe_print_user_conv_context): New.
+ (convert_like_real): Use it. Print call context for bad
+ user-defined conversion.
+ (build_over_call): Print call context for bad 'this' conversion.
+
+ * call.c (convert_like_real): Use inform for identifying the
+ declaration point.
+
+2014-05-12 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * cvt.c (cp_convert_to_pointer): Don't call error_at if
+ complain & tf_error is false.
+
+ * decl.c (make_unbound_class_template): Prefer inform for
+ "declared here"-type message.
+
+2014-05-09 Momchil Velikov <momchil.velikov@gmail.com>
+
+ PR c++/60463
+ PR c++/60755
+ * lambda.c (lambda_expr_this_capture): Add new parameter
+ add_capture_p controlling whether the functions will try to
+ capture 'this' via the default capture.
+ (maybe_resolve_dummy): Likewise.
+ * cp-tree.h: Adjust prototypes.
+ * call.c, semantics.c: Change callers of these functions.
+ * call.c (build_new_method_call_1): Use the actual 'this' that
+ would be potentially captured for the overload resolution, instead
+ of the dummy object.
+
+2014-05-09 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * pt.c (convert_nontype_argument_function): Add tsubst_flags_t
+ parameter.
+ (convert_nontype_argument): Adjust calls.
+ (coerce_template_parameter_pack): Add missing complain & tf_error
+ check.
+
+2014-05-09 Jason Merrill <jason@redhat.com>
+
+ DR 587
+ PR c++/51317
+ * call.c (build_conditional_expr_1, conditional_conversion): Handle
+ non-class lvalues and xvalues that differ only in cv-qualifiers.
+
+ DR 5
+ PR c++/60019
+ * call.c (build_user_type_conversion_1): The copy-init temporary
+ is cv-unqualified.
+
+ PR c++/58714
+ * tree.c (stabilize_expr): A stabilized prvalue is an xvalue.
+
+ PR c++/54348
+ * call.c (build_conditional_expr_1): If overload resolution finds
+ no match, just say "different types".
+
+ PR c++/32019
+ * call.c (build_conditional_expr_1): Improve ambiguity diagnostic.
+
+ PR c++/22434
+ * call.c (build_conditional_expr_1): Don't try to pool cv-quals
+ if we didn't find a conversion.
+ Don't accept a bad conversion too early.
+
+2014-05-08 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/13981
+ * typeck.c (convert_for_assignment): Provide an inform for pointers
+ to incomplete class types.
+
+2014-05-07 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/61083
+ * pt.c (convert_nontype_argument): Protect all the error calls
+ with complain & tf_error.
+
+2014-05-07 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/61080
+ * pt.c (instantiate_decl): Avoid generating the body of a
+ deleted function.
+
+2014-05-06 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/60999
+ * pt.c (maybe_begin_member_template_processing): Use
+ uses_template_parms.
+
+2014-05-06 Kenneth Zadeck <zadeck@naturalbridge.com>
+ Mike Stump <mikestump@comcast.net>
+ Richard Sandiford <rdsandiford@googlemail.com>
+
+ * call.c: Include wide-int.h.
+ (type_passed_as): Use tree_int_cst_lt instead of INT_CST_LT_UNSIGNED.
+ (convert_for_arg_passing): Likewise.
+ * class.c: Include wide-int.h.
+ (walk_subobject_offsets): Use tree_int_cst_lt instead of INT_CST_LT.
+ (end_of_class): Use tree_int_cst_lt instead of INT_CST_LT_UNSIGNED.
+ (include_empty_classes): Likewise
+ (layout_class_type): Use tree_int_cst_lt instead of INT_CST_LT.
+ * cvt.c: Include wide-int.h.
+ (ignore_overflows): Use wide_int_to_tree.
+ * decl.c: Include wide-int.h.
+ (check_array_designated_initializer): Use wide-int interfaces.
+ (compute_array_index_type): Use tree_int_cst_lt instead of INT_CST_LT.
+ (finish_enum_value_list): Use signop.
+ (build_enumerator): Use wide-int interfaces.
+ * init.c: Include wide-int.h.
+ (build_new_1): Use wide-int interfaces.
+ * mangle.c: Include wide-int.h.
+ (write_integer_cst): Use wide-int interfaces.
+ (write_array_type): Likewise.
+ * tree.c: Include wide-int.h.
+ (cp_tree_equal): Use tree_int_cst_equal.
+ * typeck2.c: Include wide-int.h.
+ (process_init_constructor_array): Use wide-int interfaces.
+
+2014-05-03 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/58582
+ * decl.c (grokfndecl): Check duplicate_decls return value for
+ error_mark_node.
+ * pt.c (instantiate_decl): A deleted function is defined.
+
+2014-05-02 Jason Merrill <jason@redhat.com>
+
+ * decl2.c (vague_linkage_p): Local statics have vague linkage.
+
+ PR c++/60992
+ * lambda.c (lambda_capture_field_type): Wrap anything dependent
+ other than 'this'.
+ (add_capture): Check for VLA before calling it.
+ * semantics.c (is_this_parameter): Accept any 'this' parameter, not
+ just the current one. Make non-static.
+ * cp-tree.h: Declare it.
+ * pt.c (tsubst_copy) [VAR_DECL]: Also build a new VAR_DECL if
+ the operand was static or constant.
+
+2014-05-02 Marek Polacek <polacek@redhat.com>
+
+ * typeck.c (maybe_warn_about_returning_address_of_local): Separate
+ warning_at calls.
+
+2014-05-01 Marek Polacek <polacek@redhat.com>
+
+ PR c/43395
+ * typeck.c (maybe_warn_about_returning_address_of_local): Distinguish
+ between label and variable when warning about returning local address.
+
+2014-04-30 Jason Merrill <jason@redhat.com>
+
+ PR c++/60980
+ * init.c (build_value_init): Don't try to call an array constructor.
+
+ PR c++/60951
+ * typeck2.c (massage_init_elt): Use maybe_constant_init.
+
+2014-04-30 Marek Polacek <polacek@redhat.com>
+
+ * typeck.c (cp_build_binary_op): Call ubsan_instrument_division
+ even when SANITIZE_FLOAT_DIVIDE is on. Set doing_div_or_mod even
+ for non-integer types.
+
+2014-04-29 Jason Merrill <jason@redhat.com>
+
+ DR 1351
+ Represent the unevaluated exception specification of an implicitly
+ declared or deleted function with a simple placeholder, not a list
+ of functions.
+ * cp-tree.h (UNEVALUATED_NOEXCEPT_SPEC_P): New.
+ * except.c (unevaluated_noexcept_spec): New.
+ * class.c (deduce_noexcept_on_destructor): Use it.
+ * decl.c (check_redeclaration_exception_specification): Call
+ maybe_instantiate_noexcept.
+ (duplicate_decls): Call it before merge_types.
+ (start_preparsed_function): Call maybe_instantiate_noexcept.
+ * decl2.c (mark_used): Call maybe_instantiate_noexcept earlier.
+ * init.c (get_nsdmi): Factor out of perform_member_init.
+ * method.c (process_subob_fn): Call maybe_instantiate_noexcept.
+ (walk_field_subobs): Consider NSDMI for EH spec.
+ (get_defaulted_eh_spec): New.
+ (implicitly_declare_fn): Use unevaluated_noexcept_spec.
+ (defaulted_late_check): Defer EH checking in non-template classes.
+ (after_nsdmi_defaulted_late_checks): New.
+ * parser.c (cp_parser_class_specifier_1): Use it.
+ (unparsed_classes): New macro.
+ * parser.h (cp_unparsed_functions_entry_d): Add classes field.
+ * pt.c (maybe_instantiate_noexcept): Use get_defaulted_eh_spec.
+ Remove list-of-functions handling.
+ * typeck2.c (merge_exception_specifiers): Remove list-of-functions
+ handling and FN parameter.
+ * typeck.c (merge_types): Adjust.
+
+2014-04-28 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/59120
+ * parser.c (cp_parser_alias_declaration): Check return value of
+ cp_parser_require.
+
+2014-04-24 Jakub Jelinek <jakub@redhat.com>
+
+ * parser.c (cp_parser_omp_atomic): Allow seq_cst before
+ atomic-clause, allow comma in between atomic-clause and
+ seq_cst.
+
+2014-04-24 Marc Glisse <marc.glisse@inria.fr>
+
+ PR libstdc++/43622
+ * rtti.c (emit_support_tinfos): Do not iterate on
+ registered_builtin_types (partial revert).
+
+2014-04-23 Dinar Temirbulatov <dtemirbulatov@gmail.com>
+
+ PR c++/57958
+ * semantics.c (apply_deduced_return_type): Complete non-void type
+ before estimating whether the type is aggregate.
+
+2014-04-22 Marc Glisse <marc.glisse@inria.fr>
+
+ PR libstdc++/43622
+ * rtti.c (emit_support_tinfo_1): New function, extracted from
+ emit_support_tinfos.
+ (emit_support_tinfos): Call it and iterate on registered_builtin_types.
+
+2014-04-22 Jakub Jelinek <jakub@redhat.com>
+
+ PR c/59073
+ * parser.c (cp_parser_omp_parallel): If cp_parser_omp_for
+ fails, don't set OM_PARALLEL_COMBINED and return NULL.
+
+2014-04-18 Jason Merrill <jason@redhat.com>
+
+ DR 1571
+ * call.c (reference_binding): Recurse on user-defined conversion.
+
+ PR c++/60872
+ * call.c (standard_conversion): Don't try to apply restrict to void.
+
+2014-04-16 Marc Glisse <marc.glisse@inria.fr>
+
+ * decl.c (reshape_init_r): Handle a single element of vector type.
+
+2014-04-16 Patrick Palka <patrick@parcs.ath.cx>
+
+ PR c++/60765
+ * decl2.c (cplus_decl_attributes): Handle
+ pointer-to-member-function declarations.
+
+2014-04-16 Patrick Palka <patrick@parcs.ath.cx>
+
+ PR c++/60764
+ * call.c (build_user_type_coversion): Use build_dummy_object
+ to create the placeholder object for a constructor method call.
+ (build_special_member_call): Likewise.
+ (build_over_call): Check for the placeholder object with
+ is_dummy_object.
+ (build_new_method_call_1): Likewise. Don't attempt to resolve
+ a dummy object for a constructor method call.
+
+2014-04-16 Paul Pluzhnikov <ppluzhnikov@google.com>
+
+ PR c++/59295
+ * friend.c (add_friend, make_friend_class): Move repeated friend
+ warning under Wredundant_decls.
+
+2014-04-15 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (duplicate_decls): Remove redundant TYPE_NAME use.
+ * name-lookup.c (pushdecl_maybe_friend_1): Likewise.
+ (do_class_using_decl): Likewise.
+ * mangle.c (dump_substitution_candidates): Use TYPE_NAME_STRING.
+
+2014-04-15 Jakub Jelinek <jakub@redhat.com>
+
+ PR plugins/59335
+ * Make-lang.h (CP_PLUGIN_HEADERS): Add type-utils.h.
+
+2014-04-14 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * cp-tree.h (TYPE_IDENTIFIER): Remove declaration.
+
+2014-04-14 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * pt.c (mark_template_parm): Use template_parm_level_and_index.
+
+2014-04-11 Jason Merrill <jason@redhat.com>
+
+ * parser.h (struct cp_token): Rename ambiguous_p to error_reported.
+ * parser.c: Adjust.
+ (cp_lexer_get_preprocessor_token): Always clear it.
+ (cp_parser_lambda_expression): Use it to avoid duplicate diagnostics.
+
+ DR 1467
+ PR c++/51747
+ * decl.c (reshape_init_r): Handle a single element of class type.
+
+ DR 1338
+ * decl.c (cxx_init_decl_processing): Set DECL_IS_MALLOC on
+ built-in operator new.
+
+2014-04-11 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/58600
+ * name-lookup.c (parse_using_directive): Return early if the
+ attribs argument is error_mark_node; use get_attribute_name.
+
+2014-04-11 Jason Merrill <jason@redhat.com>
+
+ DR 1030
+ PR c++/51253
+ * cp-tree.h (CALL_EXPR_LIST_INIT_P): New.
+ * call.c (struct z_candidate): Add flags field.
+ (add_candidate): Add flags parm.
+ (add_function_candidate, add_conv_candidate, build_builtin_candidate)
+ (add_template_candidate_real): Pass it.
+ (build_over_call): Set CALL_EXPR_LIST_INIT_P.
+ * tree.c (build_aggr_init_expr): Copy it.
+ * semantics.c (simplify_aggr_init_expr): Preevaluate args if it's set.
+
+2014-04-10 Richard Biener <rguenther@suse.de>
+ Jakub Jelinek <jakub@redhat.com>
+
+ PR ipa/60761
+ * error.c (dump_decl) <case FUNCTION_DECL>: If
+ DECL_LANG_SPECIFIC is NULL, but DECL_ABSTRACT_ORIGIN is not,
+ recurse on DECL_ABSTRACT_ORIGIN instead of printing
+ <built-in>.
+
+2014-04-09 Fabien Chêne <fabien@gcc.gnu.org>
+
+ * pt.c (check_template_variable): Check for the return of pedwarn
+ before emitting a note.
+ * parser.c (cp_parser_lambda_introducer): Likewise.
+
+2014-04-08 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/59115
+ * pt.c (process_template_parm): For an invalid non-type parameter
+ only set TREE_TYPE to error_mark_node.
+ (push_inline_template_parms_recursive, comp_template_parms,
+ redeclare_class_template, coerce_template_template_parm,
+ coerce_template_template_parms, unify): Use error_operand_p.
+
+2014-04-08 Nathan Sidwell <nathan@codesourcery.com>
+
+ * class.c (check_bases_and_members): Warn about non-virtual dtors
+ in public bases only. Check warn_ecpp before complaining about
+ non-polymorphic bases.
+
+2014-04-04 Fabien Chêne <fabien@gcc.gnu.org>
+
+ * decl.c (duplicate_decls): Check for the return of warning_at
+ before emitting a note.
+ (warn_misplaced_attr_for_class_type): Likewise.
+ (check_tag_decl): Likewise.
+
+2014-04-04 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/58207
+ * semantics.c (sort_constexpr_mem_initializers): Robustify loop.
+
+2014-04-04 Patrick Palka <patrick@parcs.ath.cx>
+
+ PR c++/44613
+ * semantics.c (add_stmt): Set STATEMENT_LIST_HAS_LABEL.
+ * decl.c (cp_finish_decl): Create a new BIND_EXPR before
+ instantiating a variable-sized type.
+
+ PR c++/21113
+ * decl.c (decl_jump_unsafe): Consider variably-modified decls.
+
+2014-04-04 Fabien Chêne <fabien@gcc.gnu.org>
+
+ * class.c (find_abi_tags_r): Check for the return of warning
+ before emitting a note.
+ (one_inherited_ctor): Likewise.
+
+2014-04-04 Fabien Chêne <fabien@gcc.gnu.org>
+
+ * decl.c (duplicate_decls): Check for the return of permerror
+ before emitting a note.
+
+2014-04-03 Nathan Sidwell <nathan@codesourcery.com>
+
+ * class.c (accessible_nvdtor_p): New.
+ (check_bases): Don't check base destructor here ...
+ (check_bases_and_members): ... check them here. Trigger on
+ Wnon-virtual-dtor flag.
+ (finish_struct_1): Use accessible_nvdtor_p.
+
+2014-04-01 Jason Merrill <jason@redhat.com>
+
+ * pt.c (process_partial_specialization): Say "not deducible"
+ rather than "not used". Use inform.
+
+ PR c++/60374
+ * pt.c (coerce_template_parms): Check that the pack expansion
+ pattern works with the first matching parameter.
+
+2014-04-01 Fabien Chêne <fabien@gcc.gnu.org>
+
+ * init.c (perform_member_init): Homogenize uninitialized
+ diagnostics.
+
+2014-04-01 Jason Merrill <jason@redhat.com>
+
+ PR c++/60708
+ * call.c (build_array_conv): Call complete_type.
+
+ PR c++/60713
+ * typeck2.c (PICFLAG_SIDE_EFFECTS): New.
+ (picflag_from_initializer): Return it.
+ (process_init_constructor): Handle it.
+
+ PR c++/60642
+ * decl2.c (is_late_template_attribute): Don't defer abi_tag.
+ * mangle.c (write_unqualified_name): Fix abi_tag on templates.
+ * pt.c (get_template_info): Handle NAMESPACE_DECL.
+ (most_general_template): Handle more kinds of template.
+ * tree.c (handle_abi_tag_attribute): Ignore abi_tag on template
+ instantiations and specializations.
+
+2014-03-31 Patrick Palka <patrick@parcs.ath.cx>
+
+ PR c++/44859
+ * typeck.c (maybe_warn_about_returning_address_of_local): Unwrap
+ COMPONENT_REFs and ARRAY_REFs sooner.
+
+2014-03-29 Adam Butcher <adam@jessamine.co.uk>
+
+ PR c++/60626
+ * parser.c (cp_parser_init_declarator): Handle erroneous generic type
+ usage in non-functions with pushed scope.
+
+2014-03-28 Adam Butcher <adam@jessamine.co.uk>
+
+ PR c++/60573
+ * name-lookup.h (cp_binding_level): New transient field defining_class_p
+ to indicate whether a scope is in the process of defining a class.
+ * semantics.c (begin_class_definition): Set defining_class_p.
+ * name-lookup.c (leave_scope): Reset defining_class_p.
+ * parser.c (synthesize_implicit_template_parm): Use cp_binding_level::
+ defining_class_p rather than TYPE_BEING_DEFINED as the predicate for
+ unwinding to class-defining scope to handle the erroneous definition of
+ a generic function of an arbitrarily nested class within an enclosing
+ class.
+
+2014-03-26 Fabien Chêne <fabien@gcc.gnu.org>
+
+ PR c++/52369
+ * method.c (walk_field_subobs): Improve the diagnostic
+ locations for both REFERENCE_TYPEs and non-static const members.
+ * init.c (diagnose_uninitialized_cst_or_ref_member): Use %q#D
+ instead of %qD to be consistent with the c++11 diagnostic.
+
+2014-03-25 Jason Merrill <jason@redhat.com>
+
+ PR c++/60566
+ PR c++/58678
+ * class.c (build_vtbl_initializer): Handle abstract dtors here.
+ * search.c (get_pure_virtuals): Not here.
+
+ PR c++/60375
+ * parser.c (cp_parser_lambda_expression): Don't parse the body of
+ a lambda in unevaluated context.
+
+ PR c++/60628
+ * decl.c (create_array_type_for_decl): Complain about array of auto.
+
+2014-03-25 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/60331
+ * semantics.c (potential_constant_expression_1): Handle
+ DECL_EXPR.
+
+2014-03-24 Adam Butcher <adam@jessamine.co.uk>
+
+ PR c++/60627
+ * parser.c (cp_parser_parameter_declaration_clause): Prevent 'auto' from
+ introducing an implicit function template parameter within an explicit
+ instantiation.
+
+2014-03-22 Jason Merrill <jason@redhat.com>
+
+ PR c++/60574
+ * decl.c (grokdeclarator): Change permerror about 'virtual auto'
+ to error.
+
+2014-03-21 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/60384
+ * name-lookup.c (push_class_level_binding_1): Check identifier_p
+ on the name argument.
+
+2014-03-20 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/60572
+ * init.c (build_zero_init_1): Ignore fields with error_mark_node
+ type.
+
+2014-03-19 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51474
+ * call.c (build_new_method_call_1): Handle pure virtuals called by
+ NSDMIs too.
+
+2014-03-17 Adam Butcher <adam@jessamine.co.uk>
+
+ PR c++/60390
+ * parser.c (cp_parser_member_declaration): Don't allow
+ finish_fully_implicit_template to consider friend declarations to be
+ class member templates.
+ (synthesize_implicit_template_parm): Handling winding back through class
+ scope to the class being defined in order to inject a template argument
+ list.
+
+ PR c++/60391
+ * parser.c (cp_parser_skip_to_end_of_block_or_statement): Unwind generic
+ function scope as per cp_parser_skip_to_end_of_statement.
+
+2014-03-17 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/59571
+ * typeck2.c (check_narrowing): Use fold_non_dependent_expr_sfinae.
+
+2014-03-14 Jason Merrill <jason@redhat.com>
+
+ PR c++/60532
+ PR c++/58678
+ * search.c (get_pure_virtuals): Handle abstract dtor here.
+ (dfs_get_pure_virtuals): Not here.
+
+ PR c++/58678
+ * search.c (dfs_get_pure_virtuals): Treat the destructor of an
+ abstract class as pure.
+
+2014-03-13 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/60383
+ * pt.c (maybe_process_partial_specialization): Check return value
+ of check_specialization_namespace.
+
+2014-03-13 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/60254
+ * semantics.c (finish_static_assert): Call cxx_constant_value only
+ if require_potential_rvalue_constant_expression returns true.
+
+2014-03-11 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/60389
+ * method.c (get_inherited_ctor): New.
+ * cp-tree.h (get_inherited_ctor): Declare it.
+ * semantics.c (is_valid_constexpr_fn): Use it.
+
+2014-03-10 Jason Merrill <jason@redhat.com>
+
+ PR c++/60367
+ * call.c (convert_default_arg): Remove special handling for
+ CONSTRUCTOR.
+
+ PR c++/53492
+ * parser.c (cp_parser_class_head): Also check PRIMARY_TEMPLATE_P
+ when deciding whether to call push_template_decl for a member class.
+ * pt.c (push_template_decl_real): Return after wrong levels error.
+
+2014-03-08 Adam Butcher <adam@jessamine.co.uk>
+
+ PR c++/60033
+ * pt.c (tsubst_copy): When retrieving a capture pack from a generic
+ lambda, remove the lambda's own template argument list prior to fetching
+ the specialization.
+
+ PR c++/60393
+ * parser.c (cp_parser_parameter_declaration_clause): Move generic
+ function template unwinding on error into a more general location, ...
+ (cp_parser_skip_to_end_of_statement): ... here.
+
+2014-03-07 Jason Merrill <jason@redhat.com>
+
+ * Make-lang.in (check_g++_parallelize): Split dg.exp.
+
+ * parser.c (cp_parser_type_id_1): Only allow 'auto' in C++1y if
+ we're in a trailing return type.
+
+ * typeck.c (comp_template_parms_position): 'auto' and
+ 'decltype(auto)' are different from real template parms.
+
+ * parser.c (cp_parser_using_declaration): Consume the semicolon
+ after bare parameter pack error.
+
+ * cp-tree.h (REF_PARENTHESIZED_P): New.
+ * semantics.c (force_paren_expr): Set it.
+ * pt.c (do_auto_deduction): Check it.
+ (tsubst) [COMPONENT_REF]: Copy it.
+ * typeck.c (maybe_warn_about_useless_cast): Don't strip dereference.
+
+ * decl.c (create_array_type_for_decl): Only warn about invalid
+ C++1y VLA if flag_iso or warn_vla>0.
+ (grokdeclarator): Likewise.
+ * pt.c (tsubst): Likewise.
+ * semantics.c (finish_decltype_type): Likewise.
+ * typeck.c (cxx_sizeof_or_alignof_type): Likewise.
+ (cp_build_addr_expr_1): Likewise.
+ * init.c (build_new_1): Improve diagnostics.
+
+2014-03-07 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/58609
+ * decl.c (check_initializer): Return NULL_TREE after error;
+ consistently use inform.
+
+2014-03-07 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (check_initializer): Remove dead code.
+
+2014-03-06 Marek Polacek <polacek@redhat.com>
+
+ PR c/60197
+ * typeck.c (check_return_expr): Call contains_cilk_spawn_stmt instead
+ of checking tree code.
+
+2014-03-06 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * parser.c (cp_lexer_set_source_position): New.
+ (cp_parser_mem_initializer): Use it.
+ (cp_parser_postfix_open_square_expression): Likewise.
+ (cp_parser_parenthesized_expression_list): Likewise.
+ (cp_parser_new_initializer): Likewise.
+ (cp_parser_jump_statement): Likewise.
+ (cp_parser_initializer): Likewise.
+ (cp_parser_functional_cast): Likewise.
+
+2014-03-05 Jason Merrill <jason@redhat.com>
+
+ PR c++/60409
+ * semantics.c (force_paren_expr): Only add a PAREN_EXPR to a
+ dependent expression.
+
+ PR c++/60361
+ * parser.c (cp_parser_template_id): Don't set up a CPP_TEMPLATE_ID
+ if re-parsing might succeed.
+ * semantics.c (finish_id_expression): Use of a parameter outside
+ the function body is a parse error.
+
+ * parser.c (cp_parser_mem_initializer): Set input_location
+ properly for init-list warning.
+ (cp_parser_postfix_open_square_expression): Likewise.
+ (cp_parser_parenthesized_expression_list): Likewise.
+ (cp_parser_new_initializer): Likewise.
+ (cp_parser_jump_statement): Likewise.
+ (cp_parser_initializer): Likewise.
+ (cp_parser_functional_cast): Likewise.
+
+2014-03-04 Jason Merrill <jason@redhat.com>
+
+ PR c++/60417
+ * typeck2.c (process_init_constructor_record): Set
+ CONSTRUCTOR_IS_DIRECT_INIT on {} for omitted initializers.
+
+ PR c++/60415
+ PR c++/54359
+ * parser.c (cp_parser_direct_declarator): Set declarator to
+ cp_error_declarator on invalid qualified-id.
+
+2014-03-04 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/60376
+ * parser.c (cp_parser_using_declaration): Early return when
+ cp_parser_nested_name_specifier errors out.
+
+2014-03-01 Adam Butcher <adam@jessamine.co.uk>
+
+ PR c++/60377
+ * parser.c (cp_parser_parameter_declaration_clause): Unwind generic
+ function scope on parse error in function parameter list.
+
+2014-03-01 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * method.c (implicitly_declare_fn): Remove redundant
+ DECL_TEMPLATE_RESULT and STRIP_TEMPLATE uses.
+ * semantics.c (is_instantiation_of_constexpr): Likewise.
+ * error.c (dump_function_decl): Likewise.
+
+2014-03-01 Jason Merrill <jason@redhat.com>
+
+ PR c++/60379
+ * semantics.c (begin_maybe_infinite_loop): Use
+ fold_non_dependent_expr_sfinae.
+
+2014-02-28 Jason Merrill <jason@redhat.com>
+
+ PR c++/58845
+ * typeck.c (cp_build_binary_op): Sorry on vector&&vector.
+
+2014-02-28 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/58610
+ * cp-tree.h (DECL_DELETED_FN): Use LANG_DECL_FN_CHECK.
+ * call.c (print_z_candidate): Remove STRIP_TEMPLATE use.
+ * lambda.c (maybe_add_lambda_conv_op): Likewise.
+
+2014-02-27 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/60253
+ * call.c (convert_arg_to_ellipsis): Return error_mark_node after
+ error_at.
+
+2014-02-27 Jason Merrill <jason@redhat.com>
+
+ PR c++/60353
+ PR c++/55877
+ * decl2.c (tentative_decl_linkage): Don't mess with functions that
+ are not yet defined.
+
+2014-02-26 Jason Merrill <jason@redhat.com>
+
+ PR c++/60347
+ PR lto/53808
+ * class.c (clone_function_decl): Don't note_vague_linkage_fn.
+ * init.c (build_vtbl_address): Do it here.
+
+ PR c++/59231
+ PR c++/11586
+ PR c++/14710
+ PR c++/57132
+ * pt.c (struct warning_sentinel): New.
+ (tsubst_copy_and_build): Use it instead of
+ c_inhibit_evaluation_warnings.
+ * typeck.c (maybe_warn_about_useless_cast): Remove
+ c_inhibit_evaluation_warnings check.
+
+ PR c++/54440
+ * pt.c (get_template_parm_index): New.
+ (fixed_parameter_pack_p_1, fixed_parameter_pack_p): New.
+ (process_template_parm): Allow bare packs in template template
+ parm template parms.
+ (coerce_template_parameter_pack): Handle fixed template template
+ parm packs and fixed packs not at the end of the parm list.
+ (coerce_template_parms): Handle template parm packs not at the end
+ of the parm list.
+ (gen_elem_of_pack_expansion_instantiation): Handle a decl expansion.
+
+ PR c++/60182
+ * pt.c (unify): Ignore alias templates when deducing a template
+ template parameter.
+
+ PR c++/60345
+ Revert:
+ DR 1571
+ * call.c (reference_binding): Recurse on user-defined conversion.
+ (convert_like_real) [ck_ref_bind]: Explain cv-qual mismatch.
+
+2014-02-25 Jason Merrill <jason@redhat.com>
+
+ DR 1571
+ * call.c (reference_binding): Recurse on user-defined conversion.
+ (convert_like_real) [ck_ref_bind]: Explain cv-qual mismatch.
+
+ * call.c (print_conversion_rejection): Handle n_arg of -2.
+ (build_user_type_conversion_1): Pass it.
+
+ PR c++/55877
+ * decl2.c (no_linkage_error): Handle C++98 semantics.
+ (reset_type_linkage): Move from decl.c.
+ (reset_type_linkage_1, reset_type_linkage_2, bt_reset_linkage_1)
+ (bt_reset_linkage_2, reset_decl_linkage): New.
+ (tentative_decl_linkage): Factor out of expand_or_defer_fn_1.
+ (cp_write_global_declarations): Move condition into no_linkage_error.
+ * decl.c (grokfndecl, grokvardecl): Use no_linkage_error.
+ * semantics.c (expand_or_defer_fn_1): Factor out
+ tentative_decl_linkage.
+ * cp-tree.h: Adjust.
+
+ * decl2.c (finish_static_data_member_decl): Diagnose static data
+ member in unnamed class.
+ * class.c (finish_struct_anon_r): Avoid redundant diagnostic.
+
+ PR lto/53808
+ * class.c (clone_function_decl): Call note_vague_linkage_fn for
+ defaulted virtual dtor.
+
+ DR 1286
+ PR c++/60328
+ * pt.c (get_underlying_template): Fix equivalence calculation.
+
+2014-02-25 Adam Butcher <adam@jessamine.co.uk>
+
+ PR c++/60311
+ * parser.c (function_being_declared_is_template_p): Return false when
+ processing a template parameter list.
+ (cp_parser_parameter_declaration_clause): Don't set
+ auto_is_implicit_function_template_parm_p when processing a
+ template parameter list.
+
+ * parser.c (synthesize_implicit_template_parm): Inject new template
+ argument list appropriately when a generic member function
+ of a class template is declared out-of-line.
+
+ PR c++/60065
+ * parser.c (cp_parser_direct_declarator): Don't save and
+ restore num_template_parameter_lists around call to
+ cp_parser_parameter_declaration_list.
+ (function_being_declared_is_template_p): New predicate.
+ (cp_parser_parameter_declaration_list): Use
+ function_being_declared_is_template_p as predicate for
+ inspecting current function template parameter list length
+ rather than num_template_parameter_lists.
+
+2014-02-24 Jason Merrill <jason@redhat.com>
+
+ PR c++/60146
+ * pt.c (tsubst_omp_for_iterator): Don't let substitution of the
+ DECL_EXPR initialize a non-class iterator.
+
+ PR c++/60312
+ * parser.c (cp_parser_template_type_arg): Check for invalid 'auto'.
+
+2014-02-21 Jason Merrill <jason@redhat.com>
+
+ PR c++/58170
+ * parser.c (cp_parser_type_name): Always check dependency.
+ (cp_parser_type_specifier_seq): Call
+ cp_parser_parse_and_diagnose_invalid_type_name.
+
+ PR c++/60108
+ * semantics.c (expand_or_defer_fn_1): Check DECL_DEFAULTED_FN.
+
+ PR c++/60185
+ * parser.c (cp_parser_default_argument): Clear
+ current_class_ptr/current_class_ref like tsubst_default_argument.
+
+ PR c++/60252
+ * lambda.c (maybe_resolve_dummy): Check lambda_function rather
+ than current_binding_level.
+
+ PR c++/60186
+ * typeck2.c (massage_init_elt): Call fold_non_dependent_expr_sfinae.
+
+ PR c++/60187
+ * parser.c (cp_parser_enum_specifier): Call
+ check_for_bare_parameter_packs.
+
+ PR c++/59347
+ * pt.c (tsubst_decl) [TYPE_DECL]: Don't try to instantiate an
+ erroneous typedef.
+
+ PR c++/60241
+ * pt.c (lookup_template_class_1): Update DECL_TEMPLATE_INSTANTIATIONS
+ of the partial instantiation, not the most general template.
+ (maybe_process_partial_specialization): Reassign everything on
+ that list.
+
+ PR c++/60216
+ * pt.c (register_specialization): Copy DECL_DELETED_FN to clones.
+ (check_explicit_specialization): Don't clone.
+
+ PR c++/60219
+ * pt.c (coerce_template_parms): Bail if argument packing fails.
+
+ PR c++/60224
+ * decl.c (cp_complete_array_type, maybe_deduce_size_from_array_init):
+ Don't get confused by a CONSTRUCTOR that already has a type.
+
+ PR c++/60227
+ * call.c (build_array_conv): Don't crash on VLA.
+
+ PR c++/60248
+ * mangle.c (mangle_decl): Don't make an alias for a TYPE_DECL.
+
+ PR c++/60252
+ * lambda.c (maybe_resolve_dummy): Don't try to capture this
+ in declaration context.
+
+ DR 1591
+ PR c++/60051
+ * pt.c (unify): Only unify if deducible. Handle 0-length list.
+
+ PR c++/60250
+ * parser.c (cp_parser_direct_declarator): Don't wrap a
+ type-dependent expression in a NOP_EXPR.
+
+ PR c++/60251
+ * lambda.c (is_normal_capture_proxy): Handle VLA capture.
+
+ PR c++/60167
+ PR c++/60222
+ PR c++/58606
+ * parser.c (cp_parser_template_argument): Restore dereference.
+ * pt.c (template_parm_to_arg): Dereference non-pack expansions too.
+ (process_partial_specialization): Handle deref.
+ (unify): Likewise.
+
+2014-02-21 Adam Butcher <adam@jessamine.co.uk>
+
+ PR c++/60052
+ PR c++/60053
+ * parser.c (cp_parser_parameter_declaration_list): Correctly reset
+ implicit_template_scope upon leaving an out-of-line generic member
+ function definition.
+
+2014-02-20 Kai Tietz <ktietz@redhat.com>
+
+ PR c++/58873
+ * parser.c (cp_parser_functional_cast): Treat NULL_TREE
+ valued type argument as error_mark_node.
+
+ PR c++/58835
+ * semantics.c (finish_fname): Handle error_mark_node.
+
+2014-02-19 Jason Merrill <jason@redhat.com>
+
+ PR c++/60046
+ * pt.c (maybe_instantiate_noexcept): Don't instantiate exception
+ spec from template context.
+
+2014-02-19 Jakub Jelinek <jakub@redhat.com>
+
+ PR debug/56563
+ * cp-objcp-common.c (cp_function_decl_explicit_p): Remove
+ FUNCTION_FIRST_USER_PARMTYPE (decl) != void_list_node check.
+
+ PR c++/60267
+ * pt.c (tsubst_expr): Handle ANNOTATE_EXPR.
+
+2014-02-18 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/60225
+ * semantics.c (ensure_literal_type_for_constexpr_object): Use
+ strip_array_types.
+
+2014-02-18 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/60215
+ * semantics.c (cxx_eval_constant_expression, [COMPONENT_REF]):
+ During error recovery allow_non_constant may be false.
+
+2014-02-18 Adam Butcher <adam@jessamine.co.uk>
+
+ PR c++/60190
+ * parser.c (cp_parser_lambda_declarator_opt): Pop template parameter
+ scope whenever a template parameter list has been started, independent
+ of whether the function call operator was well-formed or not.
+
+ PR c++/60064
+ * parser.c (cp_parser_member_declaration): Pop fully implicit template
+ scope for generic friend declarations as well as for non-friends.
+
+2014-02-12 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/60047
+ * method.c (implicitly_declare_fn): A constructor of a class with
+ virtual base classes isn't constexpr (7.1.5p4).
+
+2014-02-05 Jan Hubicka <hubicka@ucw.cz
+
+ * parser.c (synthesize_implicit_template_parm): Use grow_tree_vec.
+
+2014-02-05 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/58703
+ * parser.c (cp_parser_omp_declare_reduction): Save and free
+ declarator_obstack.
+
+2014-02-03 Marc Glisse <marc.glisse@inria.fr>
+
+ PR c++/53017
+ PR c++/59211
+ * tree.c (handle_init_priority_attribute): Call default_conversion on
+ the attribute argument.
+
+2014-02-03 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/58871
+ * method.c (synthesized_method_walk): If vbases is non-null but
+ is_empty is true, likewise don't worry about the virtual bases.
+
+2014-02-01 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51219
+ * typeck2.c (process_init_constructor_record): Just skip unnamed
+ bit-fields.
+
+2014-01-31 Jason Merrill <jason@redhat.com>
+
+ PR c++/59469
+ * pt.c (mark_decl_instantiated): Call mark_needed.
+
+ PR c++/58672
+ * decl2.c (handle_tls_init): Handle null init fn.
+
+ PR c++/55800
+ * decl2.c (get_tls_init_fn): Copy DECL_EXTERNAL from the variable.
+
+2014-01-31 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/59082
+ * class.c (build_vfield_ref): Early return error_mark_node if
+ TYPE_VFIELD (type) is null.
+ (build_base_path): Check return value of build_vfield_ref.
+
+2014-01-31 Jason Merrill <jason@redhat.com>
+
+ PR c++/59646
+ * call.c (convert_like_real) [ck_aggr]: Set TARGET_EXPR_LIST_INIT_P.
+ [ck_list]: Check for error_mark_node.
+ (build_aggr_conv): Set LOOKUP_NO_NARROWING and check_narrowing.
+
+ PR c++/57043
+ * pt.c (fn_type_unification): Don't do DEDUCE_EXACT check
+ during partial ordering.
+
+2014-01-31 Marek Polacek <polacek@redhat.com>
+
+ PR c/59963
+ * typeck.c (build_function_call_vec): Add dummy arg_loc parameter.
+
+2014-01-30 Jason Merrill <jason@redhat.com>
+
+ PR c++/57899
+ * cp-tree.h (struct saved_scope): Add x_local_specializations.
+ (local_specializations): New macro.
+ * pt.c (local_specializations): Remove variable.
+
+2014-01-30 Richard Sandiford <rdsandiford@googlemail.com>
+
+ PR c++/58708
+ * parser.c (make_string_pack): Use double_int::from_buffer.
+
+2014-01-30 Marek Polacek <polacek@redhat.com>
+
+ PR c/59940
+ * typeck.c (build_ptrmemfunc1): Call convert_and_check with
+ input_location.
+ * cvt.c (cp_convert_and_check): Call warnings_for_convert_and_check
+ with input_location.
+ * call.c (build_conditional_expr_1): Call unsafe_conversion_p with
+ loc parameter.
+
+2014-01-30 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/58843
+ * typeck.c (lookup_destructor): Check dtor_type for error_mark_node.
+
+2014-01-30 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/58649
+ * pt.c (lookup_template_class_1): Check start_enum return value
+ for error_mark_node.
+
+2014-01-30 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (duplicate_decls, typename_hash, typename_compare):
+ Use TYPE_IDENTIFIER.
+ * error.c (dump_type): Likewise.
+ * mangle.c (dump_substitution_candidates): Likewise.
+
+2014-01-30 Jason Merrill <jason@redhat.com>
+
+ PR c++/59633
+ * decl2.c (attributes_naming_typedef_ok): New.
+ * cp-tree.h: Declare it.
+ * decl.c (grokdeclarator): Check it.
+ * tree.c (no_linkage_check): Handle VECTOR_TYPE.
+
+2014-01-29 Jason Merrill <jason@redhat.com>
+
+ PR c++/59707
+ * call.c (add_builtin_candidate): Catch dependent types.
+
+ PR c++/59989
+ * pt.c (expand_template_argument_pack): Correct
+ non_default_args_count calculation.
+
+ PR c++/58466
+ * pt.c (unify_pack_expansion): Call expand_template_argument_pack.
+
+ PR c++/59956
+ * friend.c (do_friend): Pass the TEMPLATE_DECL to add_friend if we
+ have a friend template in a class template.
+ * pt.c (tsubst_friend_function): Look through it.
+ (push_template_decl_real): A friend member template is
+ primary.
+
+2014-01-29 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/58846
+ * decl.c (get_dso_handle_node): Don't crash if dso_handle_node
+ == error_mark_node.
+
+2014-01-29 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/58674
+ * pt.c (instantiate_template_1): Check for error_mark_node the second
+ argument too.
+
+2014-01-29 Jason Merrill <jason@redhat.com>
+
+ PR c++/59916
+ * optimize.c (maybe_thunk_body): Build a RETURN_EXPR for
+ cdtor_returns_this case.
+
+ PR c++/59315
+ * decl.c (cxx_maybe_build_cleanup): Call mark_used.
+
+2014-01-29 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/58702
+ * semantics.c (finish_omp_reduction_clause): Check type for
+ error_mark_node.
+
+2014-01-28 Jason Merrill <jason@redhat.com>
+
+ PR c++/59791
+ * pt.c (tsubst_decl) [VAR_DECL]: Allow in unevaluated context.
+ (tsubst_copy): Use it if lookup fails.
+
+ PR c++/59818
+ * pt.c (tsubst_function_type): Make sure we keep the same function
+ quals.
+
+ PR c++/58701
+ * semantics.c (build_anon_member_initialization): Stop walking
+ when we run out of COMPONENT_REFs.
+
+ PR c++/58632
+ * decl.c (lookup_and_check_tag): Ignore template parameters if
+ scope == ts_current.
+ * pt.c (check_template_shadow): Don't complain about the injected
+ class name.
+
+ * decl.c (duplicate_decls): Tweak.
+
+ PR c++/53756
+ * mangle.c (write_unqualified_name): Handle operator auto.
+
+2014-01-27 Jason Merrill <jason@redhat.com>
+
+ PR c++/59823
+ Core DR 1138
+ * call.c (reference_binding): Pass LOOKUP_NO_TEMP_BIND for
+ list-initialization. A conversion to rvalue ref that involves
+ an lvalue-rvalue conversion is bad.
+ (convert_like_real): Give helpful error message.
+
+ PR c++/54652
+ * decl.c (duplicate_decls): Always use oldtype for TYPE_DECL.
+
+ PR c++/58504
+ * pt.c (tsubst_copy_and_build) [TRAIT_EXPR]: Use tsubst for
+ types.
+
+ PR c++/58606
+ * pt.c (template_parm_to_arg): Call convert_from_reference.
+ (tsubst_template_arg): Don't strip reference refs.
+
+ PR c++/58639
+ * call.c (build_aggr_conv): Reject value-initialization of reference.
+
+ PR c++/58812
+ PR c++/58651
+ * call.c (convert_like_real): Give helpful error about excess braces
+ for ck_rvalue of scalar type.
+
+ Core DR 1288
+ * call.c (reference_binding): Only elide braces if the single
+ element is reference-related.
+
+ PR c++/58814
+ * typeck.c (cp_build_modify_expr): Make the RHS an rvalue before
+ stabilizing.
+
+ PR c++/58837
+ * typeck.c (cp_truthvalue_conversion): Use explicit comparison for
+ FUNCTION_DECL.
+
+ PR c++/59097
+ * decl.c (compute_array_index_type): Don't call
+ maybe_constant_value for a non-integral expression.
+
+2014-01-24 Balaji V. Iyer <balaji.v.iyer@intel.com>
+
+ * call.c (magic_varargs_p): Replaced flag_enable_cilkplus with
+ flag_cilkplus.
+ * cp-gimplify.c (cp_genericize): Likewise.
+ * decl.c (grokfndecl): Likewise.
+ * parser.c (cp_parser_postfix_expression): Likewise.
+ (cp_parser_postfix_open_square_expression): Likewise.
+ (cp_parser_direct_declarator): Likewise.
+ (is_cilkplus_vector_p): Likewise.
+ (cp_parser_omp_clause_name): Likewise.
+ (cp_parser_omp_all_clauses): Likewise.
+ * pt.c (apply_late_template_attributes): Likewise.
+ * typeck.c (cp_build_array_ref): Likewise.
+ (cp_build_compound_expr): Likewise.
+ (check_return_expr): Likewise.
+
+2014-01-24 Jason Merrill <jason@redhat.com>
+
+ PR c++/58550
+ * decl.c (grokdeclarator): Turn pedwarn about auto return type in
+ c++11 into error.
+
+ PR c++/59886
+ PR c++/59659
+ * typeck2.c (process_init_constructor_array): Don't create
+ RANGE_EXPR yet.
+
+2014-01-24 Jakub Jelinek <jakub@redhat.com>
+
+ * typeck2.c (split_nonconstant_init_1): Fix num_split_elts
+ handling for RANGE_ARRAY case.
+
+2014-01-24 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/57524
+ * name-lookup.c (push_using_directive): Use timevar_cond_start.
+
+2014-01-23 Marek Polacek <polacek@redhat.com>
+
+ PR c/59846
+ * typeck.c (cp_build_binary_op): Pass location to shorten_compare.
+
+2014-01-23 Marek Polacek <polacek@redhat.com>
+
+ PR c/58346
+ * typeck.c (pointer_diff): Give an error on arithmetic on pointer to
+ an empty aggregate.
+
+2014-01-23 Jason Merrill <jason@redhat.com>
+
+ PR c++/55189
+ * cp-tree.h (struct language_function): Add infinite_loop and
+ infinite_loops.
+ (current_function_infinite_loop): New.
+ * semantics.c (begin_maybe_infinite_loop, end_maybe_infinite_loop)
+ (break_maybe_infinite_loop): New.
+ (finish_while_stmt_cond, finish_while_stmt, begin_do_stmt)
+ (finish_do_stmt, finish_for_cond, finish_for_stmt)
+ (begin_range_for_stmt): Use them.
+ * decl.c (finish_function): Don't warn about missing return
+ if current_function_infinite_loop.
+ * pt.c (instantiate_decl): Copy current_function_infinite_loop.
+ * parser.c (cp_parser_jump_statement): Call break_maybe_infinite_loop.
+
+ * call.c (build_op_delete_call): Use make_tree_vector and
+ release_tree_vector.
+
+2014-01-23 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/58980
+ * parser.c (cp_parser_enum_specifier): Handle TYPENAME_TYPE as
+ nested_name_specifier.
+
+2014-01-23 Balaji V. Iyer <balaji.v.iyer@intel.com>
+
+ * parser.c (cp_parser_direct_declarator): When Cilk Plus is enabled
+ see if there is an attribute after function decl. If so, then
+ parse them now.
+ (cp_parser_late_return_type_opt): Handle parsing of Cilk Plus SIMD
+ enabled function late parsing.
+ (cp_parser_gnu_attribute_list): Parse all the tokens for the vector
+ attribute for a SIMD-enabled function.
+ (cp_parser_omp_all_clauses): Skip parsing to the end of pragma when
+ the function is used by SIMD-enabled function (indicated by NULL
+ pragma token). Added 3 new clauses: PRAGMA_CILK_CLAUSE_MASK,
+ PRAGMA_CILK_CLAUSE_NOMASK and PRAGMA_CILK_CLAUSE_VECTORLENGTH
+ (cp_parser_cilk_simd_vectorlength): Modified this function to handle
+ vectorlength clause in SIMD-enabled function and #pragma SIMD's
+ vectorlength clause. Added a new bool parameter to differentiate
+ between the two.
+ (cp_parser_cilk_simd_fn_vector_attrs): New function.
+ (is_cilkplus_vector_p): Likewise.
+ (cp_parser_late_parsing_elem_fn_info): Likewise.
+ (cp_parser_omp_clause_name): Added a check for "mask", "nomask"
+ and "vectorlength" clauses when Cilk Plus is enabled.
+ (cp_parser_omp_clause_linear): Added a new parameter of type bool
+ and emit a sorry message when step size is a parameter.
+ * parser.h (cp_parser::cilk_simd_fn_info): New field.
+ * decl.c (grokfndecl): Added flag_enable_cilkplus along with
+ flag_openmp.
+ * pt.c (apply_late_template_attributes): Likewise.
+
+2014-01-23 Jakub Jelinek <jakub@redhat.com>
+
+ PR middle-end/58809
+ * semantics.c (finish_omp_reduction_clause): Reject
+ BIT_AND_EXPR, BIT_IOR_EXPR and BIT_XOR_EXPR on COMPLEX_TYPEs.
+
+2014-01-22 Ville Voutilainen <ville.voutilainen@gmail.com>
+
+ PR c++/59482
+ * parser.c (cp_parser_class_head): Push the class before parsing
+ the base-clause, pop after it.
+
+2014-01-20 Eric Botcazou <ebotcazou@adacore.com>
+
+ * decl2.c (cpp_check): Revert prototype change.
+
+2014-01-17 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/59270
+ PR c++/58811
+ * init.c (build_value_init_noctor): Don't pass error_mark_node to
+ build_value_init.
+
+2014-01-17 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/59269
+ * init.c (build_value_init_noctor): Assert !TYPE_HAS_COMPLEX_DFLT
+ only when errorcount == 0.
+
+2014-01-17 Marek Polacek <polacek@redhat.com>
+
+ PR c++/59838
+ * cvt.c (ocp_convert): Don't segfault on non-existing
+ ENUM_UNDERLYING_TYPE.
+
+2014-01-16 Jason Merrill <jason@redhat.com>
+
+ PR c++/59821
+ * tree.c (bot_manip): Update the location of builtin_LINE and
+ builtin_FILE calls.
+
+2014-01-14 Jason Merrill <jason@redhat.com>
+
+ PR c++/59659
+ * typeck2.c (massage_init_elt): New.
+ (process_init_constructor_record)
+ (process_init_constructor_union): Use it.
+ (process_init_constructor_array): Use it. Use RANGE_EXPR.
+ (split_nonconstant_init_1): Handle it.
+ * semantics.c (cxx_eval_vec_init_1): Use force_rvalue.
+
+2014-01-09 Balaji V. Iyer <balaji.v.iyer@intel.com>
+
+ PR c++/59631
+ * parser.c (cp_parser_postfix_expression): Added a new if-statement
+ and replaced an existing if-statement with else-if statement.
+ Changed an existing error message wording to match the one from the C
+ parser.
+
+2014-01-08 Jason Merrill <jason@redhat.com>
+
+ PR c++/59614
+ * class.c (abi_tag_data): Add tags field.
+ (check_abi_tags): Initialize it.
+ (find_abi_tags_r): Support collecting missing tags.
+ (mark_type_abi_tags): Don't look at template args.
+ (inherit_targ_abi_tags): New.
+ (check_bases_and_members): Use it.
+ * cp-tree.h (ABI_TAG_IMPLICIT): New.
+ * mangle.c (write_abi_tags): Check it.
+
+2014-01-07 Jason Merrill <jason@redhat.com>
+
+ PR c++/58856
+ * pt.c (num_innermost_template_parms): New.
+ (get_underlying_template): Use it.
+
+ PR c++/58965
+ * mangle.c (write_guarded_var_name): Handle null DECL_NAME.
+
+2014-01-07 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * semantics.c (trait_expr_value, [CPTK_IS_BASE_OF]): Implement
+ the letter of 20.11.6 about Base and Derived naming the same
+ class type modulo cv-qualifiers.
+
+2014-01-06 Adam Butcher <adam@jessamine.co.uk>
+
+ PR c++/59635
+ * lambda.c (maybe_add_lambda_conv_op): Handle marking conversion
+ function as unimplemented for generic lambdas with varargs.
+
+ PR c++/59636
+ * parser.c (cp_parser_template_parameter): Early out with
+ error_mark_node if parameter declaration was not parsed.
+
+ PR c++/59629
+ * parser.c (cp_parser_lambda_expression): Save/reset/restore
+ auto_is_implicit_function_template_parm_p around lambda body.
+
+ PR c++/59638
+ * parser.c (cp_parser_init_declarator): Undo fully implicit
+ template parameter list when declarator is not a function.
+
+2014-01-03 Marc Glisse <marc.glisse@inria.fr>
+
+ PR c++/58950
+ * cvt.c (convert_to_void): Handle VEC_PERM_EXPR and VEC_COND_EXPR.
+
+2014-01-03 Tobias Burnus <burnus@net-b.de>
+
+ PR c++/58567
+ * pt.c (tsubst_omp_for_iterator): Early return for error_mark_node.
+
+2014-01-03 Paolo Carlini <paolo.carlini@oracle.com>
+
+ Core DR 1442
+ PR c++/59165
+ * parser.c (cp_parser_perform_range_for_lookup): Don't pass true
+ as include_std to perform_koenig_lookup.
+ (cp_parser_postfix_expression): Adjust.
+ * pt.c (tsubst_copy_and_build): Likewise.
+ * semantics.c (perform_koenig_lookup): Remove bool parameter.
+ (omp_reduction_lookup): Adjust.
+ * name-lookup.c (lookup_arg_dependent_1): Remove bool parameter.
+ (lookup_arg_dependent): Likewise.
+ (lookup_function_nonclass): Adjust.
+ * name-lookup.h: Adjust declaration.
+ * cp-tree.h: Likewise.
+
+2014-01-02 Marc Glisse <marc.glisse@inria.fr>
+
+ PR c++/59087
+ * parser.c (cp_parser_userdef_numeric_literal): Mention
+ -fext-numeric-literals in the message.
+
+2014-01-02 Marc Glisse <marc.glisse@inria.fr>
+
+ PR c++/59641
+ * call.c (build_conditional_expr_1): Check the return value of
+ force_rvalue.
+
+2014-01-02 Marc Glisse <marc.glisse@inria.fr>
+
+ * call.c (convert_like_real): Check complain.
+
+2014-01-02 Marc Glisse <marc.glisse@inria.fr>
+
+ PR c++/59378
+ * typeck.c (build_x_vec_perm_expr): Handle non-dependent arguments
+ in templates.
+
+2014-01-02 Richard Sandiford <rdsandiford@googlemail.com>
+
+ Update copyright years
+
+2014-01-02 Richard Sandiford <rdsandiford@googlemail.com>
+
+ * cp-array-notation.c, cp-cilkplus.c, vtable-class-hierarchy.c: Use
+ the standard form for the copyright notice.
+
+Copyright (C) 2014 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.
diff --git a/gcc/cp/Make-lang.in b/gcc/cp/Make-lang.in
index a58819a6e32..e1f44912b42 100644
--- a/gcc/cp/Make-lang.in
+++ b/gcc/cp/Make-lang.in
@@ -1,5 +1,5 @@
# Top level -*- makefile -*- fragment for GNU C++.
-# Copyright (C) 1994-2014 Free Software Foundation, Inc.
+# Copyright (C) 1994-2015 Free Software Foundation, Inc.
#This file is part of GCC.
diff --git a/gcc/cp/NEWS b/gcc/cp/NEWS
index d5d3d2fa624..ff725e94fa1 100644
--- a/gcc/cp/NEWS
+++ b/gcc/cp/NEWS
@@ -401,7 +401,7 @@
the exception handling work.
-Copyright (C) 1997-2014 Free Software Foundation, Inc.
+Copyright (C) 1997-2015 Free Software Foundation, Inc.
Copying and distribution of this file, with or without modification,
are permitted in any medium without royalty provided the copyright
diff --git a/gcc/cp/call.c b/gcc/cp/call.c
index 86c78ab47f6..084f870cd5e 100644
--- a/gcc/cp/call.c
+++ b/gcc/cp/call.c
@@ -1,5 +1,5 @@
/* Functions related to invoking methods and overloaded functions.
- Copyright (C) 1987-2014 Free Software Foundation, Inc.
+ Copyright (C) 1987-2015 Free Software Foundation, Inc.
Contributed by Michael Tiemann (tiemann@cygnus.com) and
modified by Brendan Kehoe (brendan@cygnus.com).
diff --git a/gcc/cp/cfns.gperf b/gcc/cp/cfns.gperf
index 05ca753927e..68acd3df486 100644
--- a/gcc/cp/cfns.gperf
+++ b/gcc/cp/cfns.gperf
@@ -1,5 +1,5 @@
%{
-/* Copyright (C) 2000-2014 Free Software Foundation, Inc.
+/* Copyright (C) 2000-2015 Free Software Foundation, Inc.
This file is part of GCC.
diff --git a/gcc/cp/cfns.h b/gcc/cp/cfns.h
index c845ddf08ea..1c6665d4f5d 100644
--- a/gcc/cp/cfns.h
+++ b/gcc/cp/cfns.h
@@ -30,7 +30,7 @@
#line 1 "cfns.gperf"
-/* Copyright (C) 2000-2014 Free Software Foundation, Inc.
+/* Copyright (C) 2000-2015 Free Software Foundation, Inc.
This file is part of GCC.
diff --git a/gcc/cp/class.c b/gcc/cp/class.c
index 07bbc69806c..557d9109a62 100644
--- a/gcc/cp/class.c
+++ b/gcc/cp/class.c
@@ -1,5 +1,5 @@
/* Functions related to building classes and their related objects.
- Copyright (C) 1987-2014 Free Software Foundation, Inc.
+ Copyright (C) 1987-2015 Free Software Foundation, Inc.
Contributed by Michael Tiemann (tiemann@cygnus.com)
This file is part of GCC.
diff --git a/gcc/cp/config-lang.in b/gcc/cp/config-lang.in
index 7bdd89e57a0..357abdc292b 100644
--- a/gcc/cp/config-lang.in
+++ b/gcc/cp/config-lang.in
@@ -1,5 +1,5 @@
# Top level configure fragment for GNU C++.
-# Copyright (C) 1994-2014 Free Software Foundation, Inc.
+# Copyright (C) 1994-2015 Free Software Foundation, Inc.
#This file is part of GCC.
diff --git a/gcc/cp/constexpr.c b/gcc/cp/constexpr.c
index afbcf51fec1..ee796dfc913 100644
--- a/gcc/cp/constexpr.c
+++ b/gcc/cp/constexpr.c
@@ -2,7 +2,7 @@
constexpr functions. These routines are used both during actual parsing
and during the instantiation of template functions.
- Copyright (C) 1998-2014 Free Software Foundation, Inc.
+ Copyright (C) 1998-2015 Free Software Foundation, Inc.
This file is part of GCC.
diff --git a/gcc/cp/cp-array-notation.c b/gcc/cp/cp-array-notation.c
index 20f741aaebc..7e76010190f 100644
--- a/gcc/cp/cp-array-notation.c
+++ b/gcc/cp/cp-array-notation.c
@@ -1,7 +1,7 @@
/* This file is part of the Intel(R) Cilk(TM) Plus support
It contains routines to handle Array Notation expression
handling routines in the C++ Compiler.
- Copyright (C) 2013-2014 Free Software Foundation, Inc.
+ Copyright (C) 2013-2015 Free Software Foundation, Inc.
Contributed by Balaji V. Iyer <balaji.v.iyer@intel.com>,
Intel Corporation
diff --git a/gcc/cp/cp-cilkplus.c b/gcc/cp/cp-cilkplus.c
index 565dd402f70..f9467705e42 100644
--- a/gcc/cp/cp-cilkplus.c
+++ b/gcc/cp/cp-cilkplus.c
@@ -1,7 +1,7 @@
/* This file is part of the Intel(R) Cilk(TM) Plus support
This file contains routines to handle Cilk Plus specific
routines for the C++ Compiler.
- Copyright (C) 2013-2014 Free Software Foundation, Inc.
+ Copyright (C) 2013-2015 Free Software Foundation, Inc.
Contributed by Aldy Hernandez <aldyh@redhat.com>.
This file is part of GCC.
diff --git a/gcc/cp/cp-gimplify.c b/gcc/cp/cp-gimplify.c
index 0a3a0d46b49..a23076f6c36 100644
--- a/gcc/cp/cp-gimplify.c
+++ b/gcc/cp/cp-gimplify.c
@@ -1,6 +1,6 @@
/* C++-specific tree lowering bits; see also c-gimplify.c and tree-gimple.c.
- Copyright (C) 2002-2014 Free Software Foundation, Inc.
+ Copyright (C) 2002-2015 Free Software Foundation, Inc.
Contributed by Jason Merrill <jason@redhat.com>
This file is part of GCC.
diff --git a/gcc/cp/cp-lang.c b/gcc/cp/cp-lang.c
index 014f393ecfa..47e8400334f 100644
--- a/gcc/cp/cp-lang.c
+++ b/gcc/cp/cp-lang.c
@@ -1,5 +1,5 @@
/* Language-dependent hooks for C++.
- Copyright (C) 2001-2014 Free Software Foundation, Inc.
+ Copyright (C) 2001-2015 Free Software Foundation, Inc.
Contributed by Alexandre Oliva <aoliva@redhat.com>
This file is part of GCC.
diff --git a/gcc/cp/cp-objcp-common.c b/gcc/cp/cp-objcp-common.c
index 9457af27964..b3234227949 100644
--- a/gcc/cp/cp-objcp-common.c
+++ b/gcc/cp/cp-objcp-common.c
@@ -1,5 +1,5 @@
/* Some code common to C++ and ObjC++ front ends.
- Copyright (C) 2004-2014 Free Software Foundation, Inc.
+ Copyright (C) 2004-2015 Free Software Foundation, Inc.
Contributed by Ziemowit Laski <zlaski@apple.com>
This file is part of GCC.
diff --git a/gcc/cp/cp-objcp-common.h b/gcc/cp/cp-objcp-common.h
index c289774b0c6..8a36e7f28fc 100644
--- a/gcc/cp/cp-objcp-common.h
+++ b/gcc/cp/cp-objcp-common.h
@@ -1,5 +1,5 @@
/* Language hooks common to C++ and ObjC++ front ends.
- Copyright (C) 2004-2014 Free Software Foundation, Inc.
+ Copyright (C) 2004-2015 Free Software Foundation, Inc.
Contributed by Ziemowit Laski <zlaski@apple.com>
This file is part of GCC.
diff --git a/gcc/cp/cp-tree.def b/gcc/cp/cp-tree.def
index e6e90f76c02..6117771d7f0 100644
--- a/gcc/cp/cp-tree.def
+++ b/gcc/cp/cp-tree.def
@@ -1,7 +1,7 @@
/* This file contains the definitions and documentation for the
additional tree codes used in the GNU C++ compiler (see tree.def
for the standard codes).
- Copyright (C) 1987-2014 Free Software Foundation, Inc.
+ Copyright (C) 1987-2015 Free Software Foundation, Inc.
Hacked by Michael Tiemann (tiemann@cygnus.com)
This file is part of GCC.
diff --git a/gcc/cp/cp-tree.h b/gcc/cp/cp-tree.h
index 9487e503ae1..2afa531adda 100644
--- a/gcc/cp/cp-tree.h
+++ b/gcc/cp/cp-tree.h
@@ -1,5 +1,5 @@
/* Definitions for C++ parsing and type checking.
- Copyright (C) 1987-2014 Free Software Foundation, Inc.
+ Copyright (C) 1987-2015 Free Software Foundation, Inc.
Contributed by Michael Tiemann (tiemann@cygnus.com)
This file is part of GCC.
diff --git a/gcc/cp/cvt.c b/gcc/cp/cvt.c
index aba75ff13e2..3113de9f42e 100644
--- a/gcc/cp/cvt.c
+++ b/gcc/cp/cvt.c
@@ -1,5 +1,5 @@
/* Language-level data type conversion for GNU C++.
- Copyright (C) 1987-2014 Free Software Foundation, Inc.
+ Copyright (C) 1987-2015 Free Software Foundation, Inc.
Hacked by Michael Tiemann (tiemann@cygnus.com)
This file is part of GCC.
diff --git a/gcc/cp/cxx-pretty-print.c b/gcc/cp/cxx-pretty-print.c
index 02ce34611b3..60be71ae981 100644
--- a/gcc/cp/cxx-pretty-print.c
+++ b/gcc/cp/cxx-pretty-print.c
@@ -1,5 +1,5 @@
/* Implementation of subroutines for the GNU C++ pretty-printer.
- Copyright (C) 2003-2014 Free Software Foundation, Inc.
+ Copyright (C) 2003-2015 Free Software Foundation, Inc.
Contributed by Gabriel Dos Reis <gdr@integrable-solutions.net>
This file is part of GCC.
diff --git a/gcc/cp/cxx-pretty-print.h b/gcc/cp/cxx-pretty-print.h
index 9bdd4b61b53..16f3238b707 100644
--- a/gcc/cp/cxx-pretty-print.h
+++ b/gcc/cp/cxx-pretty-print.h
@@ -1,5 +1,5 @@
/* Interface for the GNU C++ pretty-printer.
- Copyright (C) 2003-2014 Free Software Foundation, Inc.
+ Copyright (C) 2003-2015 Free Software Foundation, Inc.
Contributed by Gabriel Dos Reis <gdr@integrable-solutions.net>
This file is part of GCC.
diff --git a/gcc/cp/decl.c b/gcc/cp/decl.c
index bbaf3d68d9e..2fea106771b 100644
--- a/gcc/cp/decl.c
+++ b/gcc/cp/decl.c
@@ -1,5 +1,5 @@
/* Process declarations and variables for C++ compiler.
- Copyright (C) 1988-2014 Free Software Foundation, Inc.
+ Copyright (C) 1988-2015 Free Software Foundation, Inc.
Contributed by Michael Tiemann (tiemann@cygnus.com)
This file is part of GCC.
diff --git a/gcc/cp/decl.h b/gcc/cp/decl.h
index bb36271bad6..3e07dbc3650 100644
--- a/gcc/cp/decl.h
+++ b/gcc/cp/decl.h
@@ -1,5 +1,5 @@
/* Variables and structures for declaration processing.
- Copyright (C) 1993-2014 Free Software Foundation, Inc.
+ Copyright (C) 1993-2015 Free Software Foundation, Inc.
This file is part of GCC.
diff --git a/gcc/cp/decl2.c b/gcc/cp/decl2.c
index 69201b0ba98..1b31bd37394 100644
--- a/gcc/cp/decl2.c
+++ b/gcc/cp/decl2.c
@@ -1,5 +1,5 @@
/* Process declarations and variables for C++ compiler.
- Copyright (C) 1988-2014 Free Software Foundation, Inc.
+ Copyright (C) 1988-2015 Free Software Foundation, Inc.
Hacked by Michael Tiemann (tiemann@cygnus.com)
This file is part of GCC.
diff --git a/gcc/cp/dump.c b/gcc/cp/dump.c
index 70b047a9072..d6dec6bb72d 100644
--- a/gcc/cp/dump.c
+++ b/gcc/cp/dump.c
@@ -1,5 +1,5 @@
/* Tree-dumping functionality for intermediate representation.
- Copyright (C) 1999-2014 Free Software Foundation, Inc.
+ Copyright (C) 1999-2015 Free Software Foundation, Inc.
Written by Mark Mitchell <mark@codesourcery.com>
This file is part of GCC.
diff --git a/gcc/cp/error.c b/gcc/cp/error.c
index ff26fb91f73..303ebdab5d9 100644
--- a/gcc/cp/error.c
+++ b/gcc/cp/error.c
@@ -1,6 +1,6 @@
/* Call-backs for C++ error reporting.
This code is non-reentrant.
- Copyright (C) 1993-2014 Free Software Foundation, Inc.
+ Copyright (C) 1993-2015 Free Software Foundation, Inc.
This file is part of GCC.
GCC is free software; you can redistribute it and/or modify
diff --git a/gcc/cp/except.c b/gcc/cp/except.c
index ead889c0658..e229f4705e4 100644
--- a/gcc/cp/except.c
+++ b/gcc/cp/except.c
@@ -1,5 +1,5 @@
/* Handle exceptional things in C++.
- Copyright (C) 1989-2014 Free Software Foundation, Inc.
+ Copyright (C) 1989-2015 Free Software Foundation, Inc.
Contributed by Michael Tiemann <tiemann@cygnus.com>
Rewritten by Mike Stump <mrs@cygnus.com>, based upon an
initial re-implementation courtesy Tad Hunt.
diff --git a/gcc/cp/expr.c b/gcc/cp/expr.c
index 99f8006fbd8..a9c08c33a46 100644
--- a/gcc/cp/expr.c
+++ b/gcc/cp/expr.c
@@ -1,6 +1,6 @@
/* Convert language-specific tree expression to rtl instructions,
for GNU compiler.
- Copyright (C) 1988-2014 Free Software Foundation, Inc.
+ Copyright (C) 1988-2015 Free Software Foundation, Inc.
This file is part of GCC.
diff --git a/gcc/cp/friend.c b/gcc/cp/friend.c
index aa66c58568f..ee879f7d602 100644
--- a/gcc/cp/friend.c
+++ b/gcc/cp/friend.c
@@ -1,5 +1,5 @@
/* Help friends in C++.
- Copyright (C) 1997-2014 Free Software Foundation, Inc.
+ Copyright (C) 1997-2015 Free Software Foundation, Inc.
This file is part of GCC.
diff --git a/gcc/cp/g++spec.c b/gcc/cp/g++spec.c
index 79117673be3..6536d7e776f 100644
--- a/gcc/cp/g++spec.c
+++ b/gcc/cp/g++spec.c
@@ -1,5 +1,5 @@
/* Specific flags and argument handling of the C++ front end.
- Copyright (C) 1996-2014 Free Software Foundation, Inc.
+ Copyright (C) 1996-2015 Free Software Foundation, Inc.
This file is part of GCC.
diff --git a/gcc/cp/init.c b/gcc/cp/init.c
index 8a7dca32b46..a5ac11c3a0f 100644
--- a/gcc/cp/init.c
+++ b/gcc/cp/init.c
@@ -1,5 +1,5 @@
/* Handle initialization things in C++.
- Copyright (C) 1987-2014 Free Software Foundation, Inc.
+ Copyright (C) 1987-2015 Free Software Foundation, Inc.
Contributed by Michael Tiemann (tiemann@cygnus.com)
This file is part of GCC.
diff --git a/gcc/cp/lambda.c b/gcc/cp/lambda.c
index 3da28e56883..1da59ac0cf3 100644
--- a/gcc/cp/lambda.c
+++ b/gcc/cp/lambda.c
@@ -3,7 +3,7 @@
building RTL. These routines are used both during actual parsing
and during the instantiation of template functions.
- Copyright (C) 1998-2014 Free Software Foundation, Inc.
+ Copyright (C) 1998-2015 Free Software Foundation, Inc.
This file is part of GCC.
diff --git a/gcc/cp/lang-specs.h b/gcc/cp/lang-specs.h
index 79c9222b37b..b0728f081db 100644
--- a/gcc/cp/lang-specs.h
+++ b/gcc/cp/lang-specs.h
@@ -1,5 +1,5 @@
/* Definitions for specs for C++.
- Copyright (C) 1995-2014 Free Software Foundation, Inc.
+ Copyright (C) 1995-2015 Free Software Foundation, Inc.
This file is part of GCC.
diff --git a/gcc/cp/lex.c b/gcc/cp/lex.c
index fd4f9241188..9246418c09c 100644
--- a/gcc/cp/lex.c
+++ b/gcc/cp/lex.c
@@ -1,5 +1,5 @@
/* Separate lexical analyzer for GNU C++.
- Copyright (C) 1987-2014 Free Software Foundation, Inc.
+ Copyright (C) 1987-2015 Free Software Foundation, Inc.
Hacked by Michael Tiemann (tiemann@cygnus.com)
This file is part of GCC.
diff --git a/gcc/cp/mangle.c b/gcc/cp/mangle.c
index 71a6e3bf6ef..5a0f79e732e 100644
--- a/gcc/cp/mangle.c
+++ b/gcc/cp/mangle.c
@@ -1,5 +1,5 @@
/* Name mangling for the 3.0 C++ ABI.
- Copyright (C) 2000-2014 Free Software Foundation, Inc.
+ Copyright (C) 2000-2015 Free Software Foundation, Inc.
Written by Alex Samuel <samuel@codesourcery.com>
This file is part of GCC.
diff --git a/gcc/cp/method.c b/gcc/cp/method.c
index 10751ed6ba6..a9f63aa5d6e 100644
--- a/gcc/cp/method.c
+++ b/gcc/cp/method.c
@@ -1,6 +1,6 @@
/* Handle the hair of processing (but not expanding) inline functions.
Also manage function and variable name overloading.
- Copyright (C) 1987-2014 Free Software Foundation, Inc.
+ Copyright (C) 1987-2015 Free Software Foundation, Inc.
Contributed by Michael Tiemann (tiemann@cygnus.com)
This file is part of GCC.
diff --git a/gcc/cp/name-lookup.c b/gcc/cp/name-lookup.c
index b982451caf6..2dfb00dde68 100644
--- a/gcc/cp/name-lookup.c
+++ b/gcc/cp/name-lookup.c
@@ -1,5 +1,5 @@
/* Definitions for C++ name lookup routines.
- Copyright (C) 2003-2014 Free Software Foundation, Inc.
+ Copyright (C) 2003-2015 Free Software Foundation, Inc.
Contributed by Gabriel Dos Reis <gdr@integrable-solutions.net>
This file is part of GCC.
diff --git a/gcc/cp/name-lookup.h b/gcc/cp/name-lookup.h
index 40e0338ca73..4d941fec746 100644
--- a/gcc/cp/name-lookup.h
+++ b/gcc/cp/name-lookup.h
@@ -1,5 +1,5 @@
/* Declarations for C++ name lookup routines.
- Copyright (C) 2003-2014 Free Software Foundation, Inc.
+ Copyright (C) 2003-2015 Free Software Foundation, Inc.
Contributed by Gabriel Dos Reis <gdr@integrable-solutions.net>
This file is part of GCC.
diff --git a/gcc/cp/operators.def b/gcc/cp/operators.def
index ee6555b60dc..6e1ff3542b7 100644
--- a/gcc/cp/operators.def
+++ b/gcc/cp/operators.def
@@ -5,7 +5,7 @@
non-overloadable operators (like the `?:' ternary operator).
Written by Mark Mitchell <mark@codesourcery.com>
- Copyright (C) 2000-2014 Free Software Foundation, Inc.
+ Copyright (C) 2000-2015 Free Software Foundation, Inc.
This file is part of GCC.
diff --git a/gcc/cp/optimize.c b/gcc/cp/optimize.c
index 62e32d21bff..0262a8420cb 100644
--- a/gcc/cp/optimize.c
+++ b/gcc/cp/optimize.c
@@ -1,5 +1,5 @@
/* Perform optimizations on tree structure.
- Copyright (C) 1998-2014 Free Software Foundation, Inc.
+ Copyright (C) 1998-2015 Free Software Foundation, Inc.
Written by Mark Michell (mark@codesourcery.com).
This file is part of GCC.
diff --git a/gcc/cp/parser.c b/gcc/cp/parser.c
index 68940aab1c9..52234de5cd4 100644
--- a/gcc/cp/parser.c
+++ b/gcc/cp/parser.c
@@ -1,5 +1,5 @@
/* -*- C++ -*- Parser.
- Copyright (C) 2000-2014 Free Software Foundation, Inc.
+ Copyright (C) 2000-2015 Free Software Foundation, Inc.
Written by Mark Mitchell <mark@codesourcery.com>.
This file is part of GCC.
diff --git a/gcc/cp/parser.h b/gcc/cp/parser.h
index 96a84534045..76e5367413a 100644
--- a/gcc/cp/parser.h
+++ b/gcc/cp/parser.h
@@ -1,5 +1,5 @@
/* Data structures and function exported by the C++ Parser.
- Copyright (C) 2010-2014 Free Software Foundation, Inc.
+ Copyright (C) 2010-2015 Free Software Foundation, Inc.
This file is part of GCC.
diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c
index 21d0d3aa4e9..15645b98c1c 100644
--- a/gcc/cp/pt.c
+++ b/gcc/cp/pt.c
@@ -1,5 +1,5 @@
/* Handle parameterized types (templates) for GNU -*- C++ -*-.
- Copyright (C) 1992-2014 Free Software Foundation, Inc.
+ Copyright (C) 1992-2015 Free Software Foundation, Inc.
Written by Ken Raeburn (raeburn@cygnus.com) while at Watchmaker Computing.
Rewritten by Jason Merrill (jason@cygnus.com).
diff --git a/gcc/cp/ptree.c b/gcc/cp/ptree.c
index e99f386acc0..47757047864 100644
--- a/gcc/cp/ptree.c
+++ b/gcc/cp/ptree.c
@@ -1,5 +1,5 @@
/* Prints out trees in human readable form.
- Copyright (C) 1992-2014 Free Software Foundation, Inc.
+ Copyright (C) 1992-2015 Free Software Foundation, Inc.
Hacked by Michael Tiemann (tiemann@cygnus.com)
This file is part of GCC.
diff --git a/gcc/cp/repo.c b/gcc/cp/repo.c
index f076f23c8f2..43454555756 100644
--- a/gcc/cp/repo.c
+++ b/gcc/cp/repo.c
@@ -1,5 +1,5 @@
/* Code to maintain a C++ template repository.
- Copyright (C) 1995-2014 Free Software Foundation, Inc.
+ Copyright (C) 1995-2015 Free Software Foundation, Inc.
Contributed by Jason Merrill (jason@cygnus.com)
This file is part of GCC.
diff --git a/gcc/cp/rtti.c b/gcc/cp/rtti.c
index 2270f3d2705..78b84a80cd8 100644
--- a/gcc/cp/rtti.c
+++ b/gcc/cp/rtti.c
@@ -1,5 +1,5 @@
/* RunTime Type Identification
- Copyright (C) 1995-2014 Free Software Foundation, Inc.
+ Copyright (C) 1995-2015 Free Software Foundation, Inc.
Mostly written by Jason Merrill (jason@cygnus.com).
This file is part of GCC.
diff --git a/gcc/cp/search.c b/gcc/cp/search.c
index 424b26cd3e1..bcf405f5d65 100644
--- a/gcc/cp/search.c
+++ b/gcc/cp/search.c
@@ -1,6 +1,6 @@
/* Breadth-first and depth-first routines for
searching multiple-inheritance lattice for GNU C++.
- Copyright (C) 1987-2014 Free Software Foundation, Inc.
+ Copyright (C) 1987-2015 Free Software Foundation, Inc.
Contributed by Michael Tiemann (tiemann@cygnus.com)
This file is part of GCC.
diff --git a/gcc/cp/semantics.c b/gcc/cp/semantics.c
index bea3b1fbe68..44d9a2e801e 100644
--- a/gcc/cp/semantics.c
+++ b/gcc/cp/semantics.c
@@ -3,7 +3,7 @@
building RTL. These routines are used both during actual parsing
and during the instantiation of template functions.
- Copyright (C) 1998-2014 Free Software Foundation, Inc.
+ Copyright (C) 1998-2015 Free Software Foundation, Inc.
Written by Mark Mitchell (mmitchell@usa.net) based on code found
formerly in parse.y and pt.c.
diff --git a/gcc/cp/tree.c b/gcc/cp/tree.c
index 6d6abe9020a..602f5d1a7f8 100644
--- a/gcc/cp/tree.c
+++ b/gcc/cp/tree.c
@@ -1,5 +1,5 @@
/* Language-dependent node constructors for parse phase of GNU compiler.
- Copyright (C) 1987-2014 Free Software Foundation, Inc.
+ Copyright (C) 1987-2015 Free Software Foundation, Inc.
Hacked by Michael Tiemann (tiemann@cygnus.com)
This file is part of GCC.
diff --git a/gcc/cp/type-utils.h b/gcc/cp/type-utils.h
index 6f115b1e798..05f2785c454 100644
--- a/gcc/cp/type-utils.h
+++ b/gcc/cp/type-utils.h
@@ -1,5 +1,5 @@
/* Utilities for querying and manipulating type trees.
- Copyright (C) 2013-2014 Free Software Foundation, Inc.
+ Copyright (C) 2013-2015 Free Software Foundation, Inc.
This file is part of GCC.
diff --git a/gcc/cp/typeck.c b/gcc/cp/typeck.c
index fc85ec34821..b4af8b0d073 100644
--- a/gcc/cp/typeck.c
+++ b/gcc/cp/typeck.c
@@ -1,5 +1,5 @@
/* Build expressions with type checking for C++ compiler.
- Copyright (C) 1987-2014 Free Software Foundation, Inc.
+ Copyright (C) 1987-2015 Free Software Foundation, Inc.
Hacked by Michael Tiemann (tiemann@cygnus.com)
This file is part of GCC.
diff --git a/gcc/cp/typeck2.c b/gcc/cp/typeck2.c
index c53a9b52923..4e3f0f35d63 100644
--- a/gcc/cp/typeck2.c
+++ b/gcc/cp/typeck2.c
@@ -1,6 +1,6 @@
/* Report error messages, build initializers, and perform
some front-end optimizations for C++ compiler.
- Copyright (C) 1987-2014 Free Software Foundation, Inc.
+ Copyright (C) 1987-2015 Free Software Foundation, Inc.
Hacked by Michael Tiemann (tiemann@cygnus.com)
This file is part of GCC.
diff --git a/gcc/cp/vtable-class-hierarchy.c b/gcc/cp/vtable-class-hierarchy.c
index 4d6de986fc5..aec2fcae51c 100644
--- a/gcc/cp/vtable-class-hierarchy.c
+++ b/gcc/cp/vtable-class-hierarchy.c
@@ -1,4 +1,4 @@
-/* Copyright (C) 2012-2014 Free Software Foundation, Inc.
+/* Copyright (C) 2012-2015 Free Software Foundation, Inc.
This file is part of GCC.