diff options
Diffstat (limited to 'gcc/cp/ChangeLog-2014')
-rw-r--r-- | gcc/cp/ChangeLog-2014 | 4041 |
1 files changed, 4041 insertions, 0 deletions
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. |