aboutsummaryrefslogtreecommitdiff
path: root/gcc/cp
diff options
context:
space:
mode:
authorRichard Biener <rguenth@gcc.gnu.org>2012-01-09 10:11:38 +0000
committerRichard Biener <rguenth@gcc.gnu.org>2012-01-09 10:11:38 +0000
commita7f45047440d019d5cbd20629af5c2d526a33b4f (patch)
treebadc3ff1c829e6f5d75752864401299ffd4d755e /gcc/cp
parentbf4db96c93ce31bbad0984724f9ab2d6695ca9ee (diff)
downloadgcc-a7f45047440d019d5cbd20629af5c2d526a33b4f.zip
gcc-a7f45047440d019d5cbd20629af5c2d526a33b4f.tar.gz
gcc-a7f45047440d019d5cbd20629af5c2d526a33b4f.tar.bz2
2012-01-09 Richard Guenther <rguenther@suse.de>
Rotate changelogs. From-SVN: r183007
Diffstat (limited to 'gcc/cp')
-rw-r--r--gcc/cp/ChangeLog5030
-rw-r--r--gcc/cp/ChangeLog-20115033
2 files changed, 5034 insertions, 5029 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index e31b386..c0e1cf4 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -107,5036 +107,8 @@
deprecated access declarations when no errors were encountered
while parsing the access declaration. Save the first token in
order to emit the warning at the right place.
-
-2011-12-31 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51397
- * semantics.c (finish_static_assert): Use %s instead of %E for
- the error message.
-
-2011-12-27 Fabien Chêne <fabien@gcc.gnu.org>
-
- PR c++/23211
- * name-lookup.c (do_class_using_decl): Use dependent_scope_p
- instead of dependent_type_p, to check that a non-dependent
- nested-name-specifier of a class-scope using declaration refers to
- a base, even if the current scope is dependent.
- * parser.c (cp_parser_using_declaration): Set
- USING_DECL_TYPENAME_P to 1 if the DECL is not null. Re-indent a
- 'else' close to the prior modification.
-
-2011-12-23 Jason Merrill <jason@redhat.com>
-
- PR c++/51507
- * search.c (at_function_scope_p): Also check cfun.
- * pt.c (tsubst_pack_expansion): Check it instead of
- cp_unevaluated_operand.
- (instantiate_template_1): Use push_to_top_level.
-
- * tree.c (dependent_name): OFFSET_REF and BASELINK
- are not dependent names.
-
-2011-12-21 Jason Merrill <jason@redhat.com>
-
- PR c++/51611
- * cp-tree.h (CONVERT_EXPR_VBASE_PATH): New.
- * class.c (build_base_path): Defer vbase conversion in an NSDMI.
- * tree.c (bot_replace): Expand it here.
- * cp-gimplify.c (cp_genericize_r): Make sure deferred conversion
- doesn't leak into GENERIC.
-
-2011-12-21 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51305
- * semantics.c (massage_constexpr_body): Reorder conditionals, make
- sure a BIND_EXPR embedded in a MUST_NOT_THROW_EXPR is handled.
-
-2011-12-20 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51621
- * tree.c (diagnose_non_constexpr_vec_init): For value initialization
- pass void_type_node, not void_zero_node, to build_vec_init_elt.
-
-2011-12-20 Dodji Seketeli <dodji@redhat.com>
-
- PR debug/49951
- * decl.c (cxx_maybe_build_cleanup): Don't set location of the call
- to the destructor.
-
-2011-12-20 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51612
- * semantics.c (is_valid_constexpr_fn): In case of constexpr
- constructors also check for virtual base classes.
-
-2011-12-19 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51328
- * pt.c (convert_template_argument): Early error out and return
- error_mark_node for invalid uses of destructors as types.
-
-2011-12-19 Jason Merrill <jason@redhat.com>
-
- PR c++/51530
- * pt.c (unify): Handle NULLPTR_TYPE.
-
- PR c++/51526
- * semantics.c (build_data_member_initialization): Handle
- delegating constructor.
- (build_constexpr_constructor_member_initializers): Likewise.
-
- PR c++/51553
- * cp-tree.h (LOOKUP_LIST_INIT_CTOR): Rename from
- LOOKUP_NO_COPY_CTOR_CONVERSION.
- (add_list_candidates): Set it earlier.
- (add_candidates): Don't check explicit on ctors when it's set.
- (add_function_candidate): Check it even when LOOKUP_ONLYCONVERTING
- is set.
-
- PR c++/51553
- * call.c (add_function_candidate): Allow conversions for the copy
- parm in list-initialization unless the argument is an init-list.
-
-2011-12-19 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/51619
- * semantics.c (cxx_eval_vec_init_1): If init is NULL for
- multidimensional array, just set eltinit to NULL_TREE.
-
- * cp-gimplify.c (gimplify_must_not_throw_expr): Use
- gimple_seq_add_stmt_without_update instead of gimplify_seq_add_stmt.
-
-2011-12-19 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/51477
- * search.c (lookup_member): Get out early on invalid base type.
-
-2011-12-19 Jason Merrill <jason@redhat.com>
-
- PR c++/51489
- * semantics.c (cxx_eval_outermost_constant_expr): Check for
- conversion from pointer to integer here.
- (cxx_eval_constant_expression) [NOP_EXPR]: Not here.
-
-2011-12-18 Paolo Carlini <paolo.carlini@oracle.com>
-
- * semantics.c (finish_compound_literal): Don't call check_narrowing
- if !(complain & tf_warning_or_error).
-
-2011-12-17 Jason Merrill <jason@redhat.com>
-
- PR c++/51588
- * parser.c (cp_parser_ptr_operator): Reject pointer to member of enum.
-
-2011-12-17 Richard Henderson <rth@redhat.com>
-
- PR bootstrap/51072
- * config-lang.in: Revert last change.
-
-2011-12-17 Jason Merrill <jason@redhat.com>
-
- PR c++/51586
- * parser.c (cp_parser_check_class_key): Handle error_mark_node.
-
- PR c++/51587
- * decl.c (start_enum): Avoid using ENUM_UNDERLYING_TYPE on a
- non-enum.
-
-2011-12-16 Jason Merrill <jason@redhat.com>
-
- PR c++/51416
- * init.c (build_value_init_noctor): Check for incomplete type.
-
-2011-12-16 Richard Henderson <rth@redhat.com>
-
- PR bootstrap/51072
- * config-lang.in (target_libs): Include target-libitm.
-
-2011-12-16 Jason Merrill <jason@redhat.com>
-
- PR c++/51461
- * decl.c (check_static_variable_definition): Check COMPLETE_TYPE_P
- before literal_type_p.
-
- PR c++/51331
- * class.c (convert_to_base_statically): Just call
- build_simple_base_path.
- (build_simple_base_path): Check field offset.
-
-2011-12-15 Jason Merrill <jason@redhat.com>
-
- PR c++/51458
- * decl.c (has_designator_problem): New.
- (reshape_init_r): Check for improper use of
- designated initializers.
-
-2011-12-15 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/51463
- * decl.c (grokdeclarator): Set DECL_INITIAL of decl
- to error_mark_node to disallow NSDMI if declspecs->storage_class
- is sc_static.
- * parser.c (cp_parser_late_parse_one_default_arg): Return early
- if default_arg is error_mark_node.
-
- PR c/51360
- * semantics.c (finish_omp_clauses): For OMP_CLAUSE_NUM_THREADS_EXPR
- and OMP_CLAUSE_SCHEDULE_CHUNK_EXPR call mark_rvalue_use.
-
-2011-12-15 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/51473
- * decl.c (check_tag_decl): Error out on auto specifier with no
- declarator.
-
-2011-12-15 Jonathan Wakely <jwakely.gcc@gmail.com>
-
- PR libstdc++/51365
- * cp-tree.h (CPTK_IS_FINAL): Add.
- * parser.c (cp_parser_translation_unit): Handle RID_IS_FINAL.
- (cp_parser_primary_expression, cp_parser_trait_expr): Likewise.
- * semantics.c (trait_expr_value, finish_trait_expr): Handle
- CPTK_IS_FINAL.
- * cxx-pretty-print.c (pp_cxx_trait_expression): Likewise.
-
-2011-12-14 Jason Merrill <jason@redhat.com>
-
- PR c++/51554
- * semantics.c (cxx_eval_indirect_ref): Fix sanity check.
-
- PR c++/51248
- * decl.c (copy_type_enum): Also update variants.
- (finish_enum): Allow variants of complete enums.
-
-2011-12-14 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/51475
- * call.c (struct conversion)<u.next>: Update comment.
- (next_conversion): New static function.
- (convert_like_real): Use it.
-
- PR c++/51476
- * pt.c (convert_nontype_argument): Don't call maybe_constant_value
- for PTRMEM_CST nodes.
-
-2011-12-13 Jason Merrill <jason@redhat.com>
-
- PR c++/51406
- PR c++/51161
- * typeck.c (build_static_cast_1): Fix cast of lvalue to
- base rvalue reference.
-
-2011-12-13 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51464
- * semantics.c (begin_lambda_type): Check begin_class_definition return
- value for error_mark_node.
- * parser.c (cp_parser_lambda_expression): Check begin_lambda_type
- return value for error_mark_node.
-
-2011-12-13 Fabien Chêne <fabien@gcc.gnu.org>
-
- PR c++/14258
- * cp-tree.h (USING_DECL_TYPENAME_P): New macro.
- * parser.c (cp_parser_nonclass_name): Handle using declarations
- that refer to a dependent type.
- (cp_parser_using_declaration): Set USING_DECL_TYPENAME_P to 1 if
- the using declaration refers to a dependent type.
-
-2011-12-12 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/51496
- * parser.c (cp_parser_omp_for_loop): When determining whether
- to use cp_parser_omp_for_incr or cp_parser_expression and when
- calling cp_parser_omp_for_incr, use real_decl instead of decl.
-
-2011-12-12 Torvald Riegel <triegel@redhat.com>
-
- * semantics.c (finish_transaction_stmt, build_transaction_expr):
- Accept new noexcept parameter and handle it.
- * cp-tree.h (finish_transaction_stmt, build_transaction_expr): Adapt
- declarations.
- * parser.c (cp_parser_exception_specification_opt): Extract
- noexcept-specification parsing to ...
- (cp_parser_noexcept_specification_opt): ...here. Allow for parsing
- non-constexpr noexcept arguments.
- (cp_parser_transaction, cp_parser_transaction_expression): Parse
- and handle noexcept-specifications.
- (cp_parser_function_transaction): Adapt to finish_transaction_stmt
- change.
- * pt.c (tsubst_expr): Adapt to new noexcept parameters when
- building transactions.
-
-2011-12-12 Torvald Riegel <triegel@redhat.com>
-
- * cp-tree.def (MUST_NOT_THROW_EXPR): Add condition parameter.
- * cp-tree.h (MUST_NOT_THROW_COND): New.
- (build_must_not_throw_expr): Declare.
- * dump.c (cp_dump_tree): Dump MUST_NOT_THROW_EXPR condition.
- * except.c (build_must_not_throw_expr): New.
- (initialize_handler_parm): Use it.
- (begin_eh_spec_block, wrap_cleanups_r): Adapt to condition.
- * pt.c (tsubst_expr): Handle MUST_NOT_THROW_EXPR.
-
-2011-12-12 Richard Guenther <rguenther@suse.de>
-
- PR lto/51262
- * tree.c (cp_free_lang_data): No longer clear anonymous names.
-
-2011-12-09 Jason Merrill <jason@redhat.com>
-
- PR c++/51151
- * call.c (perform_implicit_conversion_flags): Remove earlier kludge.
- * parser.c (cp_parser_omp_for_loop): Use cp_parser_omp_for_incr
- in templates even if decl isn't type-dependent.
-
-2011-12-09 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/51289
- * cp-tree.h (TYPE_TEMPLATE_INFO): Rewrite this accessor macro to
- better support aliased types.
- (TYPE_ALIAS_P): Don't crash on TYPE_NAME nodes that are not
- TYPE_DECL.
- * pt.c (find_parameter_packs_r): Handle types aliases.
- (push_template_decl_real): Check for bare parameter packs in the
- underlying type of an alias template.
-
-2011-12-08 Jason Merrill <jason@redhat.com>
-
- PR c++/51318
- * typeck.c (build_x_conditional_expr): Restrict glvalue games to C++11.
-
- PR c++/51459
- * pt.c (tsubst_expr) [DECL_EXPR]: Handle capture proxies properly.
- * semantics.c (insert_capture_proxy): No longer static.
- * cp-tree.h: Declare it.
-
-2011-12-07 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/51401
- * decl.c (grokdeclarator): Error for auto on non-static data members.
-
- PR c++/51429
- * typeck2.c (cxx_incomplete_type_diagnostic): Don't
- ICE if TREE_OPERAND (value, 1) is overloaded.
-
- PR c++/51229
- * decl.c (reshape_init_class): Complain if d->cur->index is
- INTEGER_CST.
- * parser.c (cp_parser_initializer_list): If cp_parser_parse_definitely
- fails, clear designator.
-
- PR c++/51369
- * init.c (build_value_init): Allow array types even when
- processing_template_decl.
-
-2011-12-07 Ed Smith-Rowland <3dw4rd@verizon.net>
-
- PR c++/51420
- * parser.c (lookup_literal_operator): Check that declaration is an
- overloaded function.
-
-2011-12-06 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/51430
- * pt.c (tsubst_decl): Don't call strip_array_domain on
- error_mark_node.
-
-2011-12-06 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51431
- * init.c (build_value_init): Check build_aggr_init_expr return
- value for error_mark_node.
-
-2011-12-06 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/51427
- * parser.c (cp_parser_check_class_key): Add note about earlier
- declaration.
-
-2011-12-05 Fabien Chêne <fabien@gcc.gnu.org>
-
- PR c++/51319
- * semantics.c (finish_id_expression): Strip using declarations
- early in the function.
-
-2011-12-05 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51399
- * init.c (perform_member_init): Early return if init is error_mark_node.
-
-2011-12-05 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51414
- * semantics.c (finish_underlying_type): Use %qT, not %qE for the
- error message.
-
-2011-12-05 Jason Merrill <jason@redhat.com>
-
- * init.c (expand_default_init): Unshare args in ctor delegation.
-
-2011-12-05 Ville Voutilainen <ville.voutilainen@gmail.com>
- Pedro Lamarão <pedro.lamarao@gmail.com>
-
- Implement C++11 delegating constructors.
- * cp-tree.h (enum cpp0x_warn_str): Add CPP0X_DELEGATING_CTORS.
- * error.c (maybe_warn_cpp0x): Adjust.
- * parser.c (cp_parser_mem_initializer_list): Use it. Diagnose
- multiple initializers if a delegating initializer is present.
- * call.c (build_special_member_call): Convert an assert into an if.
- * init.c (perform_target_ctor): New.
- (emit_mem_initializers): Use it.
- (expand_member_init, expand_default_init): Adjust.
-
-2011-12-05 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51404
- * typeck2.c (build_functional_cast): Early return error_mark_node
- for invalid uses of 'auto'.
- * parser.c (cp_parser_direct_declarator): When
- cp_parser_constant_expression returns error do not produce further
- diagnostic for the bound.
-
-2011-12-03 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51313
- * call.c (null_ptr_cst_p): STRIP_NOPS in c++11 mode too.
-
-2011-12-01 Jason Merrill <jason@redhat.com>
-
- * call.c (build_new_method_call_1): Handle aggregate initialization.
- * tree.c (stabilize_init): Handle CONSTRUCTOR.
-
-2011-12-01 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51326
- * call.c (build_user_type_conversion_1): Early return NULL if
- expr is NULL_TREE.
-
-2011-12-01 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51367
- * pt.c (unify_inconsistency): Use either %qT or %qE depending on
- whether parm is a type or non-type parameter.
-
-2011-11-30 Jason Merrill <jason@redhat.com>
-
- PR c++/51009
- * name-lookup.c (push_to_top_level): Set stmts_are_full_exprs_p.
- * decl.c (build_aggr_init_full_exprs): Just assert that it's true.
- (check_initializer): Here too.
-
-2011-11-30 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51299
- * rtti.c (ifnonnull): Use nullptr_node.
- (build_dynamic_cast_1): Call cp_truthvalue_conversion instead
- of c_common_truthvalue_conversion.
-
-2011-11-24 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51227
- * pt.c (instantiate_class_template_1): If lambda_function (type)
- is NULL_TREE do not instantiate_decl.
-
-2011-11-24 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51290
- * class.c (build_base_path): For the null pointer check use
- nullptr_node instead of integer_zero_node.
-
-2011-11-22 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/51145
- * decl.c (check_elaborated_type_specifier): Gracefully handle
- error_mark_node. Accept bound template template parameters.
- Update diagnostics for alias template specializations. Update
- comment.
- * parser.c (cp_parser_elaborated_type_specifier): Use
- check_elaborated_type_specifier for simple-template-ids as well.
-
-2011-11-22 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51265
- * semantics.c (finish_decltype_type): Handle PTRMEM_CST.
-
-2011-11-22 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/51143
- * parser.c (cp_parser_alias_declaration): Don't allow type
- definition in templates.
-
-2011-11-22 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51196
- * typeck.c (cp_build_binary_op, [case EQ_EXPR]): For targets having
- TARGET_PTRMEMFUNC_VBIT_LOCATION == ptrmemfunc_vbit_in_delta, do here
- the -Wzero-as-null-pointer-constant warning for pmf == 0.
-
-2011-11-21 Torvald Riegel <triegel@redhat.com>
-
- * pt.c (tsubst_copy_and_build): Handle TRANSACTION_EXPR.
-
-2011-11-21 Ed Smith-Rowland <3dw4rd@verizon.net>
-
- PR c++/50958
- * parser.c (lookup_literal_operator): New.
- (cp_parser_userdef_char_literal): Use it.
- (cp_parser_userdef_numeric_literal): Use it.
- (cp_parser_userdef_string_literal): Use lookup_name.
-
-2011-11-20 Jason Merrill <jason@redhat.com>
-
- * pt.c (tsubst_pack_expansion): Fix SFINAE.
-
- PR c++/48322
- * cp-tree.h (PACK_EXPANSION_EXTRA_ARGS): New.
- * cp-tree.def (EXPR_PACK_EXPANSION): Add an operand for it.
- * pt.c (tsubst_pack_expansion): Set and use it.
- (iterative_hash_template_arg): Hash it.
- (template_args_equal): Compare it.
- (comp_template_args_with_info): Handle nulls.
- * tree.c (cp_walk_subtrees): Walk it.
- * typeck.c (structural_comptypes): Compare it.
- * ptree.c (cxx_print_type): Print it.
-
- * pt.c (type_unification_real): Set input_location
- during default arg instantiation.
-
-2011-11-20 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51230
- * pt.c (unify_inconsistency): Handle non-type parameters better.
- * error.c (dump_expr): Handle TEMPLATE_TEMPLATE_PARM.
-
-2011-11-20 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/51194
- * pt.c (lookup_template_class_1): Go out early if the type of the
- template is error_mark_node.
-
-2011-11-19 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51216
- * semantics.c (potential_constant_expression_1): Handle IF_STMT,
- DO_STMT, FOR_STMT, and WHILE_STMT.
-
-2011-11-18 Fabien Chêne <fabien@gcc.gnu.org>
-
- PR c++/51188
- * search.c (lookup_field_1): Handle USING_DECLs for the storted
- case.
-
-2011-11-18 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51150
- * pt.c (tsubst_copy_and_build): Handle FIX_TRUNC_EXPR.
-
-2011-11-18 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/51191
- * pt.c (primary_template_instantiation_p): Don't forget to
- consider alias declarations.
-
-2011-11-17 Jason Merrill <jason@redhat.com>
-
- PR c++/51186
- * decl.c (grokdeclarator): Improve C++98 trailing return diagnostic.
-
- N3203
- * class.c (add_implicitly_declared_members): Update move
- conditions.
-
- PR c++/51137
- * class.c (build_base_path): Don't do calculation in templates.
-
-2011-11-15 Torvald Riegel <triegel@redhat.com>
-
- * parser.c (cp_parser_transaction_expression): Require parentheses
- when parsing transaction expressions.
-
-2011-11-14 Ed Smith-Rowland <3dw4rd@verizon.net>
-
- PR c++/51107
- * typeck.c (check_literal_operator_args): Add processing_specialization
- to check for void template fn. Test for exact arity for non-template fn.
-
-2011-11-14 Fabien Chêne <fabien@gcc.gnu.org>
-
- PR c++/6936
- PR c++/25994
- PR c++/26256
- PR c++/30195
- * search.c (lookup_field_1): Look through USING_DECL.
- (lookup_field_r): Call lookup_fnfields_slot instead of
- lookup_fnfields_1.
- * semantics.c (finish_member_declaration): Remove the check that
- prevents USING_DECLs from being verified by
- pushdecl_class_level. Call add_method for using declarations that
- designates functions if the using declaration is in a template
- class. Set DECL_IGNORED_P on class-scope using declarations.
- * typeck.c (build_class_member_access_expr): Handle USING_DECLs.
- * class.c (check_field_decls): Keep using declarations.
- (add_method): Remove two diagnostics about conflicting using
- declarations.
- * parser.c (cp_parser_nonclass_name): Handle USING_DECLs.
- * decl.c (start_enum): Call xref_tag whenever possible.
- * cp-tree.h (strip_using_decl): Declare, and reident the previous
- function.
- * name-lookup.c (strip_using_decl): New function.
- (supplement_binding_1): Call strip_using_decl on decl and
- bval. Perform most of the checks with USING_DECLs stripped. Also
- check that the target decl and the target bval does not refer to
- the same declaration. Allow pushing an enum multiple times in a
- template class. Adjustment to diagnose using redeclarations. Call
- diagnose_name_conflict.
- (push_class_level_binding): Call strip_using_decl on decl and
- bval. Perform most of the checks with USING_DECLs stripped. Return
- true if both decl and bval refer to USING_DECLs and are dependent.
- (diagnose_name_conflict): New function.
-
-2011-11-12 Jason Merrill <jason@redhat.com>
-
- PR c++/986
- * call.c (set_up_extended_ref_temp): Warn about references
- bound to non-static reference members.
- * init.c (perform_member_init): Pass in the member.
-
- PR c++/51060
- * cp-gimplify.c (cp_gimplify_expr): Leave clobbers alone.
-
-2011-11-11 Ed Smith-Rowland <3dw4rd@verizon.net>
-
- PR c++/50976
- * typeck.c (check_literal_operator_args): Reorganize test for string
- operators so size_t search depends on finding string first.
-
-2011-11-10 Jason Merrill <jason@redhat.com>
-
- PR c++/50372
- * pt.c (convert_nontype_argument_function): Allow decls with
- internal linkage in C++11.
- (convert_nontype_argument): Likewise.
-
- PR c++/50973
- * decl2.c (mark_used): Defer synthesis of virtual functions.
- * method.c (use_thunk): Make sure the target function has
- DECL_INTERFACE_KNOWN.
-
- PR c++/51079, DR 495
- * call.c (joust): Check the second conversion sequence
- before checking templates.
-
-2011-11-09 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50837
- * pt.c (tsubst_copy_and_build) [IDENTIFIER_NODE]: In C++11 mode
- pass allow_non_integral_constant_expression_p = true to
- finish_id_expression.
-
-2011-11-09 Jason Merrill <jason@redhat.com>
-
- PR c++/50972
- * pt.c (maybe_instantiate_noexcept): Check the return value of
- push_tinst_level.
-
- PR c++/51046
- * parser.c (cp_parser_range_for): check_for_bare_parameter_packs.
-
- PR c++/51029
- * class.c (build_base_path): Don't ICE in fold_non_dependent_expr.
-
- * Make-lang.in (check_g++_parallelize): Add dg-torture.exp.
- (check-c++0x): Obsolete.
-
- * pt.c (invalid_nontype_parm_type_p): Avoid printing "<type error>".
-
- * pt.c (convert_nontype_argument): Only integral arguments
- get early folding.
-
- * parser.c (cp_parser_alias_declaration): Don't do semantic
- processing if parsing failed.
-
-2011-11-09 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51045
- * init.c (build_new_1, build_vec_delete_1, build_delete):
- Use nullptr_node.
-
-2011-11-09 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/51047
- * search.c (lookup_member): Change to take also a tsubst_flags_t
- parameter.
- (lookup_field, lookup_fnfields): Adjust calls.
- * typeck.c (lookup_destructor, finish_class_member_access_expr,
- build_ptrmemfunc_access_expr): Likewise.
- * class.c (handle_using_decl, maybe_note_name_used_in_class):
- Likewise.
- * pt.c (resolve_typename_type): Likewise.
- * semantics.c (lambda_function): Likewise.
- * parser.c (cp_parser_perform_range_for_lookup,
- cp_parser_lookup_name): Likewise.
- * friend.c (make_friend_class): Likewise.
- * name-lookup.c (pushdecl_maybe_friend_1, get_class_binding,
- do_class_using_decl, lookup_qualified_name): Likewise.
- * cp-tree.h (lookup_member): Adjust declaration.
-
-2011-11-09 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/51043
- * cp-tree.h (TYPE_ALIAS_P, TYPE_TEMPLATE_INFO): Don't crash on
- NULL TYPE_NAME.
-
- PR c++/51027
- * parser.c (cp_parser_alias_declaration): Require ';' at the end
- of the declaration.
-
-2011-11-09 Dodji Seketeli <dodji@redhat.com>
-
- PR debug/51032
- * decl2.c (check_member_template): Accept alias templates and ...
- * parser.c (cp_parser_alias_declaration): ... use it here.
-
-2011-11-08 Jason Merrill <jason@redhat.com>
-
- PR c++/50835
- * typeck.c (build_x_conditional_expr): Preserve lvalue/xvalueness.
- * tree.c (lvalue_kind) [NON_DEPENDENT_EXPR]: Return clk_ordinary
- in C++98.
-
-2011-11-08 Richard Guenther <rguenther@suse.de>
-
- PR middle-end/51010
- * error.c (dump_expr): Handle SSA_NAMEs.
-
-2011-11-07 Richard Henderson <rth@redhat.com>
- Aldy Hernandez <aldyh@redhat.com>
- Torvald Riegel <triegel@redhat.com>
-
- Merged from transactional-memory.
-
- * call.c (build_new_function_call): Call tm_malloc_replacement.
- * class.c (check_bases): Compute transaction attributes for the
- class based on its base classes.
- (look_for_tm_attr_overrides, set_one_vmethod_tm_attributes,
- set_method_tm_attributes): New.
- (finish_struct_1): Call set_method_tm_attributes.
- * cp-tree.h (begin_transaction_stmt, finish_transaction_stmt,
- build_transaction_expr): Declare.
- (TRANSACTION_EXPR_IS_STMT): New.
- * decl.c (push_cp_library_fn): Set attribute to transaction_safe.
- * except.c (do_get_exception_ptr): Apply transaction_pure.
- (do_begin_catch): Mark _ITM_cxa_begin_catch transaction_pure and
- record as transactional-memory wrapper.
- (do_end_catch): Similarly for _ITM_cxa_end_catch.
- (do_allocate_exception): Similarly for _ITM_cxa_allocate_exception.
- (build_throw): Similarly for _ITM_cxa_throw. Make __cxa_rethrow pure.
- * parser.h (struct cp_parser): Add in_transaction flag.
- * parser.c (enum non_integral_constant): Add NIC_TRANSACTION.
- (cp_parser_non_integral_constant_expression): Handle NIC_TRANSACTION.
- (enum required_token): Add transaction tokens.
- (cp_parser_transaction, cp_parser_transaction_expression,
- cp_parser_function_transaction, cp_parser_transaction_cancel,
- cp_parser_txn_attribute_opt): New.
- (cp_parser_unary_expression): Handle RID_TRANSACTION*.
- (cp_parser_statement, cp_parser_function_definition_after_declarator,
- cp_parser_token_starts_function_definition_p): Same.
- (cp_parser_required_error): Handle RT_TRANSACTION*.
- * pt.c (tsubst_expr): Handle TRANSACTION_EXPR.
- * semantics.c (begin_transaction_stmt, finish_transaction_stmt,
- build_transaction_expr): New.
-
-2011-11-08 Dodji Seketeli <dodji@redhat.com>
-
- Fix context handling of alias-declaration
- * decl.c (start_decl): Update comment.
- * error.c (dump_alias_template_specialization): Dump the context
- of the specialization.
- * parser.c (cp_parser_alias_declaration): Call pop_scope on the
- pushed scope yielded by start_decl.
-
-2011-11-08 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50864
- * parser.c (cp_parser_postfix_dot_deref_expression): Reject invalid
- uses of '->' and '.' as postfix-expression in namespace scope.
-
-2011-11-07 Jason Merrill <jason@redhat.com>
-
- PR c++/50848
- * pt.c (tsubst_copy_and_build) [CALL_EXPR]: Don't crash
- if lookup finds a non-function.
-
- PR c++/50863
- * parser.c (cp_parser_initializer_list): Parse C99
- array designators tentatively.
-
- PR c++/50870
- * pt.c (tsubst_copy): Handle NAMESPACE_DECL.
- (tsubst_copy_and_build) [COMPONENT_REF]: Handle a still-dependent
- object.
-
-2011-11-07 Paolo Carlini <paolo.carlini@oracle.com>
-
- * pt.c (tsubst_copy_and_build): Fix qualified_name_lookup_error
- call in case COMPONENT_REF.
-
-2011-11-07 Jason Merrill <jason@redhat.com>
- Dodji Seketeli <dodji@redhat.com>
-
- Support C++11 alias-declaration
- PR c++/45114
- * cp-tree.h (TYPE_DECL_ALIAS_P, TYPE_ALIAS_P)
- (DECL_TYPE_TEMPLATE_P, DECL_ALIAS_TEMPLATE_P): New accessor
- macros.
- (TYPE_TEMPLATE_INFO): Get template info of an alias template
- specializations from its TYPE_DECL.
- (SET_TYPE_TEMPLATE_INFO): Set template info of alias template
- specializations into its TYPE_DECL.
- (DECL_CLASS_TEMPLATE_P): Re-write using the new
- DECL_TYPE_TEMPLATE_P.
- (enum cp_decl_spec): Add new ds_alias enumerator.
- (alias_type_or_template_p, alias_template_specialization_p):
- Declare new functions.
- * parser.c (cp_parser_alias_declaration): New static function.
- (cp_parser_check_decl_spec): Add "using" name for the `alias'
- declspec.
- (cp_parser_type_name): Update comment. Support simple-template-id
- representing alias template specializations in c++0x mode.
- (cp_parser_qualifying_entity): Update comment. Use
- cp_parser_type_name.
- (cp_parser_block_declaration): Handle alias-declaration in c++11.
- Update comment.
- (cp_parser_template_id): Handle specializations of alias
- templates.
- (cp_parser_member_declaration): Add alias-declaration production
- to comment. Support alias-declarations.
- (cp_parser_template_declaration_after_export): Handle alias
- templates in c++11.
- * decl.c (make_typename_type, make_unbound_class_template): Accept
- alias templates.
- (grokdeclarator): Set TYPE_DECL_ALIAS_P on alias
- declarations.
- * decl2.c (grokfield): Move template creation after setting up the
- TYPE_DECL of the alias, so that the TEMPLATE_DECL of the alias
- template actually carries the right type-id of the alias
- declaration.
- * pt.c (alias_type_or_template_p)
- (alias_template_specialization_p): Define new public functions.
- (maybe_process_partial_specialization): Reject partial
- specializations of alias templates.
- (primary_template_instantiation_p): Consider alias template
- instantiations.
- (push_template_decl_real): Assert that TYPE_DECLs of alias
- templates are different from those of class template. Store
- template info onto the TYPE_DECL of the alias template.
- (convert_template_argument): Strip aliases from template
- arguments.
- (lookup_template_class_1): Handle the creation of the
- specialization of an alias template.
- (tsubst_decl): Create a substituted copy of the TYPE_DECL of an
- member alias template.
- (tsubst): Handle substituting into the type of an alias template.
- Handle substituting UNBOUND_CLASS_TEMPLATE into
- BOUND_TEMPLATE_TEMPLATE_PARM.
- (do_type_instantiation): Better diagnostics when trying to
- explicitely instantiate a non-class template.
- * search.c (lookup_field_1, lookup_field_r): Support looking up
- alias templates.
- * semantics.c (finish_template_type): For instantiations of alias
- templates, return the TYPE_DECL of the actual alias and not the
- one of the aliased type.
- * error.c (dump_alias_template_specialization): New static
- function.
- (dump_type): Handle printing of alias templates and their
- specializations. templates.
- (dump_aggr_type): For specialization of alias templates, fetch
- arguments from the right place.
- (dump_decl): Print an alias-declaration like `using decl = type;'
- (dump_template_decl): Support printing of alias templates.
-
-2011-11-07 Jason Merrill <jason@redhat.com>
-
- PR c++/35688
- * decl2.c (constrain_visibility): Return void. Add tmpl parm
- which gives the constraint priority over an attribute.
- (constrain_visibility_for_template, determine_visibility): Adjust.
- * pt.c (instantiate_class_template_1): Call determine_visibility.
-
- PR c++/33255
- * decl.c (save_function_data): Clear local_typedefs.
-
- * decl.c (cp_finish_decl): Only make_tree_vector if we're calling
- check_initializer.
-
-2011-11-06 Jason Merrill <jason@redhat.com>
-
- PR c++/35688
- * decl2.c (constrain_visibility): Check decl_has_visibility_attr
- rather than DECL_VISIBILITY_SPECIFIED.
-
-2011-11-06 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/47695
- * decl2.c (mark_used): Early return false after error or sorry.
- * cp-tree.h (mark_used): Adjust declaration.
- * semantics.c (finish_id_expression): Check mark_used return value.
-
-2011-11-05 Jason Merrill <jason@redhat.com>
-
- PR c++/48370
- * decl.c (cp_finish_decl): Mostly revert previous change.
-
-2011-11-04 Jason Merrill <jason@redhat.com>
-
- PR c++/26714
- * init.c (perform_member_init): Strip TARGET_EXPR around NSDMI.
- Do temporary lifetime extension.
-
- PR c++/48370
- * decl.c (cp_finish_decl): Run cleanups in the right order.
-
-2011-11-04 Eric Botcazou <ebotcazou@adacore.com>
-
- PR c++/50608
- * semantics.c (finish_offsetof): Adjust call to fold_offsetof.
- * typeck.c (cp_build_addr_expr_1): Call fold_offsetof_1.
-
-2011-11-04 Paolo Carlini <paolo.carlini@oracle.com>
-
- * typeck.c (build_indirect_ref): Use ATTRIBUTE_UNUSED.
- * mangle.c (write_unnamed_type_name): Likewise.
-
-2011-11-04 Magnus Fromreide <magfr@lysator.liu.se>
-
- * parser.c (cp_parser_enumerator_list): Do not warn about
- trailing commas in C++0x mode.
-
-2011-11-04 Olivier Goffart <olivier@woboq.com>
- Jason Merrill <jason@redhat.com>
-
- PR c++/50965
- * class.c (check_field_decls): NSDMI makes a class non-aggregate.
-
-2011-11-04 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/48420
- * call.c (conversion_null_warnings): For 'false' to NULL pointer,
- just check that TREE_TYPE (expr) is a BOOLEAN_TYPE.
-
-2011-11-04 Ed Smith-Rowland <3dw4rd@verizon.net>
-
- PR c++/50941
- * parser.c (cp_parser_userdef_string_literal): Fix string length.
-
-2011-11-04 Jason Merrill <jason@redhat.com>
-
- PR c++/48370
- * call.c (extend_ref_init_temps, extend_ref_init_temps_1): New.
- (set_up_extended_ref_temp): Use it. Change cleanup parm to VEC.
- (initialize_reference): Just call convert_like.
- * decl.c (grok_reference_init): Just call initialize_reference.
- (build_init_list_var_init): Remove.
- (check_initializer): Change cleanup parm to VEC. Handle references
- like other types. Call perform_implicit_conversion instead
- of build_init_list_var_init. Don't use build_aggr_init for
- aggregate initialization of arrays.
- (cp_finish_decl): Change cleanup to VEC.
- * typeck2.c (store_init_value): Call extend_ref_init_temps.
- Use build_vec_init for non-constant arrays.
- * init.c (expand_aggr_init_1): Adjust.
- (build_vec_init): Avoid re-converting an initializer
- that's already digested.
- * mangle.c (mangle_ref_init_variable): Add a discriminator.
- * cp-tree.h: Adjust.
- * typeck.c (convert_for_initialization): Adjust.
- * decl2.c (maybe_emit_vtables): Adjust.
-
-2011-11-02 Jason Merrill <jason@redhat.com>
-
- PR c++/50930
- * init.c (build_aggr_init): Don't set LOOKUP_ONLYCONVERTING
- if the initializer has TARGET_EXPR_DIRECT_INIT_P.
- (expand_default_init): An initializer with TARGET_EXPR_DIRECT_INIT_P
- or TARGET_EXPR_LIST_INIT_P doesn't need more processing.
- * tree.c (bot_manip): Propagate TARGET_EXPR_IMPLICIT_P,
- TARGET_EXPR_LIST_INIT_P, TARGET_EXPR_DIRECT_INIT_P.
- * call.c (convert_like_real): Set TARGET_EXPR_DIRECT_INIT_P
- as appropriate on list-value-initialization.
-
- * parser.c (cp_parser_decl_specifier_seq): Change "C++0x" to
- "C++11" in warnings.
- (cp_lexer_get_preprocessor_token): Likewise.
- (cp_parser_binary_expression): Likewise.
-
-2011-11-02 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50810
- * typeck2.c (check_narrowing): Adjust OPT_Wnarrowing diagnostics.
- (digest_init_r): Call check_narrowing irrespective of the C++ dialect.
- * decl.c (check_initializer): Likewise.
- * semantics.c (finish_compound_literal): Likewise.
-
-2011-11-02 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50956
- * typeck.c (build_const_cast_1): Fix -Wcast-qual for false
- comp_ptr_ttypes_const.
-
-2011-11-02 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
-
- * Make-lang.in (g++spec.o): Pass SHLIB instead of SHLIB_LINK.
-
-2011-11-01 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/44277
- * cvt.c (cp_convert_to_pointer): Warn for zero as null pointer
- constant.
- * typeck.c (cp_truthvalue_conversion): Handle pointers and member
- function pointers under c_inhibit_evaluation_warnings; use
- nullptr_node for data member pointers.
- (cp_build_binary_op): Tweak, just forward to cp_convert op1,
- either a nullptr_node or an integer_zero_node.
- (build_ptrmemfunc): Use nullptr_node.
- * init.c (build_zero_init_1): Likewise.
-
-2011-11-01 Jason Merrill <jason@redhat.com>
-
- PR c++/50500
- DR 1082
- * search.c (lookup_fnfields_idx_nolazy): Split out from...
- (lookup_fnfields_1): ...here.
- (lookup_fnfields_slot_nolazy): Use it.
- * cp-tree.h: Declare it.
- * class.c (type_has_move_assign): Use it.
- (type_has_user_declared_move_assign): Likewise.
-
-2011-10-31 Jason Merrill <jason@redhat.com>
-
- PR c++/50920
- * class.c (check_field_decl): Change c++0x in diags to c++11.
- * error.c (maybe_warn_cpp0x): Likewise.
- * parser.c (cp_parser_diagnose_invalid_type_name): Likewise.
- * pt.c (check_default_tmpl_args): Likewise.
-
-2011-10-31 Diego Novillo <dnovillo@google.com>
-
- * mangle.c (get_mangled_id): Factor from ...
- (mangle_decl): ... here.
- Call get_mangled_id.
-
-2011-10-25 Gerald Pfeifer <gerald@pfeifer.com>
-
- * NEWS (GCC 2.95): Refer to GNU/Linux instead of Linux.
- (EGCS 1.0): Ditto.
-
-2011-10-29 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50901
- * call.c (build_new_op_1): Handle ABS_EXPR together with the
- other unary EXPR.
-
-2011-10-28 Paolo Carlini <paolo.carlini@oracle.com>
-
- Revert:
- 2011-10-28 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50864
- * pt.c (tsubst_copy_and_build): Fix qualified_name_lookup_error
- call in case COMPONENT_REF.
-
-2011-10-28 Paolo Carlini <paolo.carlini@oracle.com>
-
- * pt.c (unify_pack_expansion): Initialize bad_old_arg and bad_new_arg.
-
-2011-10-28 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50864
- * pt.c (tsubst_copy_and_build): Fix qualified_name_lookup_error
- call in case COMPONENT_REF.
-
-2011-10-27 Jason Merrill <jason@redhat.com>
-
- * semantics.c (cxx_eval_outermost_constant_expr): Check
- cp_has_mutable_p.
- (cxx_eval_component_reference): Check DECL_MUTABLE_P.
-
-2011-10-27 Roberto Agostino Vitillo <ravitillo@lbl.gov>
-
- PR c++/30066
- * decl2.c (determine_hidden_inline): New function.
- (determine_visibility): fvisibility-inlines-hidden affects inline
- functions.
-
-2011-10-27 Dodji Seketeli <dodji@redhat.com>
-
- * cp-tree.h (DECL_DECLARES_TYPE_P): Fix comment.
-
-2011-10-26 Jason Merrill <jason@redhat.com>
-
- * typeck.c (check_literal_operator_args): Avoid building types.
-
-2011-10-26 Ed Smith-Rowland <3dw4rd@verizon.net>
-
- Implement C++11 user-defined literals.
- * cp-objcp-common.c: (cp_tree_size) Return size of USERDEF_LITERAL tree.
- * cp-tree.h: (UDLIT_OP_*, UDLIT_OPER_P): Literal operator
- name tools. New tree code for user-defined literals.
- * cxx-pretty-print.h: (pp_cxx_userdef_literal) New.
- * cxx-pretty-print.c: (pp_cxx_userdef_literal) New.
- (pp_cxx_primary_expression, pp_cxx_expression): Use it.
- * decl.c: (cp_tree_node_structure): Return new tree code.
- (duplicate_decls): Check for raw vs. template operator conflicts.
- (grokfndecl, grokdeclarator): New checks for literal operators.
- * error.c: (dump_expr): Warn about user-defined literals
- in C++98 mode. (dump_function_name): Pretty printing.
- * mangle.c: (write_literal_operator_name): New.
- (write_unqualified_id, write_unqualified_name): Use it.
- * parser.c: (cp_parser_operator): Handle operator"".
- (cp_parser_userdef_char_literal, cp_parser_userdef_numeric_literal,
- cp_parser_userdef_string_literal): New.
- (cp_parser_primary_expression): Handle new user-defined literal tokens
- with new functions.
- * semantics.c: (potential_constant_expression_1): Add
- user-defined literals.
- * typeck.c (check_raw_literal_operator,
- check_literal_operator_args): New.
-
-2011-10-26 Paolo Carlini <paolo.carlini@oracle.com>
-
- * typeck.c (cp_build_addr_expr_1): Use BASELINK_P.
- * class.c (instantiate_type): Likewise.
- * pt.c (convert_nontype_argument_function, uses_template_parms,
- tsubst_copy, resolve_nondeduced_context, type_dependent_expression_p):
- Likewise.
- * semantics.c (finish_decltype_type): Likewise.
- * decl2.c (mark_used): Likewise.
- * name-lookup.c (arg_assoc): Likewise.
-
-2011-10-26 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50870
- * typeck.c (non_reference): Pass NULL_TREE through.
-
-2011-10-25 Jason Merrill <jason@redhat.com>
-
- PR c++/50866
- PR c++/41449
- * semantics.c (maybe_cleanup_point_expr_void): No longer static.
- * typeck2.c (split_nonconstant_init_1): Use it.
- * cp-tree.h: Declare it.
- * decl.c (wrap_cleanups_r): Stop at CLEANUP_POINT_EXPR.
-
- PR c++/49996
- * tree.c (stabilize_init): Stabilize scalar elements of a
- CONSTRUCTOR, too.
-
-2011-10-25 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50858
- * typeck.c (composite_pointer_type_r): Check return value of
- composite_pointer_type_r for error_mark_node.
-
-2011-10-25 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50861
- * pt.c (tsubst_copy_and_build): Check return value of
- tsubst_copy_and_build for error_mark_node.
-
-2011-10-23 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50841
- Revert:
- 2011-10-23 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50810
- * typeck2.c (check_narrowing): Adjust OPT_Wnarrowing diagnostics.
- (digest_init_r): Call check_narrowing irrespective of the C++ dialect.
- * decl.c (check_initializer): Likewise.
- * semantics.c (finish_compound_literal): Likewise.
-
-2011-10-23 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50810
- * typeck2.c (check_narrowing): Adjust OPT_Wnarrowing diagnostics.
- (digest_init_r): Call check_narrowing irrespective of the C++ dialect.
- * decl.c (check_initializer): Likewise.
- * semantics.c (finish_compound_literal): Likewise.
-
-2011-10-21 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/45385
- * init.c (build_vec_init): Early return error_mark_node if
- maxindex is -1.
-
-2011-10-21 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/31423
- * typeck2.c (cxx_incomplete_type_diagnostic): Improve error message
- for invalid use of member function.
-
-2011-10-21 Ville Voutilainen <ville.voutilainen@gmail.com>
-
- PR c++/50811
- * parser.c (cp_parser_class_head): Parse virt-specifiers
- regardless of whether an id is present
-
-2011-10-20 Jason Merrill <jason@redhat.com>
-
- PR c++/41449
- * typeck2.c (split_nonconstant_init_1): Handle EH cleanup of
- initialized subobjects.
-
-2011-10-19 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/13657
- * class.c (instantiate_type): Fix error message.
-
-2011-10-19 Jason Merrill <jason@redhat.com>
-
- PR c++/50793
- * tree.c (bot_manip): Propagate AGGR_INIT_ZERO_FIRST.
-
-2011-10-19 Roland Stigge <stigge@antcom.de>
-
- PR translation/49704
- * semantics.c (potential_constant_expression_1): Use "AST" instead of
- "ast" in sorry message.
-
-2011-10-19 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/38761
- PR c++/40872
- * decl.c (duplicate_decls, make_typename_type, grokdeclarator): Use
- G_() in error message strings to facilitate translation.
- * semantics.c (finish_id_expression): Likewise.
- * parser.c (cp_parser_nested_name_specifier_opt,
- cp_parser_parameter_declaration): Likewise.
-
-2011-10-18 Jason Merrill <jason@redhat.com>
-
- PR c++/50531
- * pt.c (instantiate_decl): Recognize when a function defaulted
- outside the class is already instantiated.
-
- PR c++/50742
- * decl.c (check_previous_goto_1): Handle using-decl.
-
-2011-10-18 Jason Merrill <jason@redhat.com>
-
- PR c++/50500
- DR 1082
- * class.c (type_has_user_declared_move_constructor): New.
- (type_has_user_declared_move_assign): New.
- (add_implicitly_declared_members): Add lazy copy ops
- even if there's a move.
- * method.c (lazily_declare_fn): Delete implicit copies
- if there's a move.
- (maybe_explain_implicit_delete): Explain this. Use inform rather
- than error.
- * cp-tree.h: Declare new fns.
-
-2011-10-18 Diego Novillo <dnovillo@google.com>
-
- * parser.c: Remove ENABLE_CHECKING markers around debugging
- routines.
- (cp_lexer_dump_tokens): Add arguments START_TOKEN and CURR_TOKEN.
- Make static
- When printing CURR_TOKEN surround it in [[ ]].
- Start printing at START_TOKEN.
- Update all users.
- (cp_debug_print_tree_if_set): New.
- (cp_debug_print_context): New.
- (cp_debug_print_context_stack): New.
- (cp_debug_print_flag): New.
- (cp_debug_print_unparsed_function): New.
- (cp_debug_print_unparsed_queues): New.
- (cp_debug_parser_tokens): New.
- (cp_debug_parser): New.
- (cp_lexer_start_debugging): Set cp_lexer_debug_stream to stderr.
- (cp_lexer_stop_debugging): Set cp_lexer_debug_stream to NULL.
- * parser.h (cp_lexer_dump_tokens): Remove declaration.
- (cp_debug_parser): Declare.
-
-2011-10-17 Michael Spertus <mike_spertus@symantec.com>
-
- * cp-tree.def: Add BASES as a new tree code.
- * cp-tree.h (enum cp_trait_kind): Add CPTK_BASES, CPTK_DIRECT_BASES.
- (BASES_TYPE, BASES_DIRECT): Define.
- (calculate_bases, finish_bases, calculate_direct_bases): Declare.
- * parser.c (cp_parser_trait_expr, cp_parser_template_argument_list,
- (cp_parser_simple_type_specifier, cp_parser_save_nsdmi): Use them.
- * pt.c (find_parameter_packs_r, tsubst_pack_expansion): Likewise.
- * semantics.c (calculate_bases, finish_bases, calculate_direct_bases,
- dfs_calculate_bases_pre, dfs_calculate_bases_post,
- calculate_bases_helper): Define.
-
-2011-10-17 Jason Merrill <jason@redhat.com>
-
- PR c++/50736
- * parser.c (cp_parser_lambda_introducer): Check for more
- invalid captures.
-
-2011-10-17 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/44524
- * typeck.c (build_class_member_access_expr): Provide a better error
- message for X.Y where X is a pointer to class type.
- (finish_class_member_access_expr): Likewise.
-
-2011-10-15 Tom Tromey <tromey@redhat.com>
- Dodji Seketeli <dodji@redhat.com>
-
- * error.c (cp_diagnostic_starter): Pass the relevant location to
- diagnostic_report_current_module.
- (cp_diagnostic_finalizer): Call virt_loc_aware_diagnostic_finalizer.
-
-2011-10-17 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/48489
- * typeck.c (finish_class_member_access_expr): Fix error call
- for TREE_CODE (access_path) == TREE_BINFO.
-
-2011-10-15 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50732
- * semantics.c (finish_trait_expr): Do not try to instantiate the
- the base type of an __is_base_of trait.
- (check_trait_type): Return a tree; use complete_type_or_else.
-
-2011-10-14 Jason Merrill <jason@redhat.com>
-
- PR c++/50563
- * parser.c (cp_parser_cache_group): Handle end==CPP_COMMA.
- (cp_parser_save_nsdmi): Pass it.
-
- PR c++/50707
- * method.c (walk_field_subobs): Check for NSDMI before
- complaining about uninitialized fields.
-
- * pt.c (tsubst_decl) [FIELD_DECL]: Use void_zero_node
- instead of error_mark_node as a placeholder.
-
-2011-10-14 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/38174
- * call.c (add_builtin_candidate): If two pointers have a composite
- pointer type, generate a single candidate with that type.
-
-2011-10-13 Jason Merrill <jason@redhat.com>
-
- PR c++/50614
- * cp-tree.h (VAR_TEMPL_TYPE_FIELD_OR_FUNCTION_DECL_CHECK): New.
- (DECL_TEMPLATE_INFO): Use it.
- * pt.c (tsubst_decl) [FIELD_DECL]: Set DECL_TEMPLATE_INFO
- if the decl has an NSDMI.
- * init.c (perform_member_init): Use it.
-
- PR c++/50437
- * cp-tree.h (struct tree_lambda_expr): Add closure field.
- (LAMBDA_EXPR_CLOSURE): New.
- * pt.c (tsubst_copy_and_build) [LAMBDA_EXPR]: Likewise.
- * semantics.c (build_lambda_object): Use it instead of TREE_TYPE.
- (begin_lambda_type, lambda_function, add_capture): Likewise.
- (add_default_capture, lambda_expr_this_capture): Likewise.
-
-2011-10-13 Diego Novillo <dnovillo@google.com>
-
- * cp-tree.h (struct language_function): Rename in_function_try_handler
- to x_in_function_try_handler.
- Rename in_base_initializer to x_in_base_initializer.
- Update all users.
-
-2011-10-13 Diego Novillo <dnovillo@google.com>
-
- * class.c (sorted_fields_type_new): Factor out of ...
- (finish_struct_1): ... here.
-
-2011-10-13 Jason Merrill <jason@redhat.com>
-
- PR c++/50618
- * init.c (expand_aggr_init_1): Don't zero-initialize virtual
- bases of a base subobject.
-
-2011-10-12 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50594
- * decl.c (cxx_init_decl_processing): Add
- __attribute__((externally_visible)) to operator new and
- operator delete library fn.
-
-2011-10-11 Michael Meissner <meissner@linux.vnet.ibm.com>
-
- * decl.c (duplicate_decls): Delete old interface with two parallel
- arrays to hold standard builtin declarations, and replace it with
- a function based interface that can support creating builtins on
- the fly in the future. Change all uses, and poison the old
- names. Make sure 0 is not a legitimate builtin index.
- * except.c (build_eh_type_type): Ditto.
- (choose_personality_routine): Ditto.
- * semantics.c (finish_omp_atomic): Ditto.
- (finish_omp_barrier): Ditto.
- (finish_omp_flush): Ditto.
- (finish_omp_taskwait): Ditto.
-
-2011-10-11 Jason Merrill <jason@redhat.com>
-
- PR c++/49855
- PR c++/49896
- * cp-tree.def (IMPLICIT_CONV_EXPR): New.
- * call.c (perform_implicit_conversion_flags): Build it
- instead of NOP_EXPR.
- * cp-objcp-common.c (cp_common_init_ts): It's typed.
- * cxx-pretty-print.c (pp_cxx_cast_expression): Handle it.
- (pp_cxx_expression): Likewise.
- * error.c (dump_expr): Likewise.
- * semantics.c (potential_constant_expression_1): Likewise.
- * tree.c (cp_tree_equal): Likewise.
- (cp_walk_subtrees): Likewise.
- * pt.c (iterative_hash_template_arg): Likewise.
- (for_each_template_parm_r): Likewise.
- (type_dependent_expression_p): Likewise.
- (tsubst_copy, tsubst_copy_and_build): Handle IMPLICIT_CONV_EXPR
- and CONVERT_EXPR.
- * cp-tree.h (IMPLICIT_CONV_EXPR_DIRECT_INIT): New.
-
-2011-10-11 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50611
- * pt.c (tsubst_copy_and_build): If (complain & tf_error) is false
- do not call unqualified_name_lookup_error.
-
-2011-10-10 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50660
- * call.c (conversion_null_warnings): Don't look through references.
-
-2011-10-09 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/38980
- * init.c (constant_value_1): Add bool parameter.
- (decl_constant_value_safe): Add.
- (integral_constant_value): Adjust.
- (decl_constant_value): Adjust.
- * cp-tree.h (decl_constant_value_safe): Declare.
- * typeck.c (decay_conversion): Use decl_constant_value_safe.
- * call.c (convert_like_real): Likewise.
-
-2011-10-09 Jakub Jelinek <jakub@redhat.com>
- Diego Novillo <dnovillo@google.com>
-
- * pt.c (reregister_specialization): Use htab_find instead of
- htab_find_slot with INSERT.
- (maybe_process_partial_specialization, lookup_template_class_1): Change
- slot variable type to void ** to avoid aliasing problems.
- (register_specialization): Likewise. Use slot != NULL instead of
- more expensive !optimize_specialization_lookup_p (tmpl) test.
-
-2011-10-08 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/34927
- * typeck2.c (abstract_virtuals_error_sfinae): Don't produce duplicate
- inform messages in case of cloned destructor.
-
-2011-10-06 Jason Merrill <jason@redhat.com>
-
- PR c++/39164
- * decl.c (grokfndecl): Diagnose redefinition of defaulted fn.
-
-2011-10-02 Jason Merrill <jason@redhat.com>
-
- * pt.c (tsubst_pack_expansion): Re-use ARGUMENT_PACK_SELECTs.
- Change unsubstituted_packs to bool.
-
- * parser.c (cp_parser_range_for): Don't try to deduce from {}
- in a template.
-
- PR c++/35722
- Implement N2555 (expanding pack expansion to fixed parm list)
- * pt.c (coerce_template_parms): Allow expanding a pack expansion
- to a fixed-length argument list.
- (unify_pack_expansion): Handle explicit args properly.
- (unify) [TREE_VEC]: Handle pack expansions here.
- [TYPE_ARGUMENT_PACK]: Not here.
- (tsubst_pack_expansion): Don't try to do partial substitution.
- (pack_deducible_p): New.
- (fn_type_unification): Use it.
- (find_parameter_packs_r): Take the TYPE_MAIN_VARIANT
- of a type parameter.
- (check_non_deducible_conversion): Split from type_unification_real.
- (unify_one_argument): Split from type_unification_real...
- (unify_pack_expansion): ...and here. Drop call_args_p parm.
- (type_unification_real, unify, more_specialized_fn): Adjust.
-
- * class.c (fixed_type_or_null): Handle NSDMI.
- * method.c (walk_field_subobs): Disable NSDMI noexcept checking
- for now.
-
-2011-09-30 Jason Merrill <jason@redhat.com>
-
- * cp-tree.h (TREE_NEGATED_INT): Remove.
- * semantics.c (finish_unary_op_expr): Don't set it.
-
-2011-09-30 Janis Johnson <janisjo@codesourcery.com>
-
- PR c++/44473
- * mangle.c (write_type): Handle CV qualifiers for decimal classes.
-
-2011-09-26 Andi Kleen <ak@linux.intel.com>
-
- * repo.c (finish_repo): Use HOST_WIDE_INT_PRINT_HEX_PURE.
-
-2011-09-28 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/45278
- * typeck.c (cp_build_binary_op): With -Wextra, warn for ordered
- comparison of pointer with zero.
-
-2011-09-27 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/31489
- * parser.c (cp_parser_elaborated_type_specifier): For RECORD_TYPE,
- set CLASSTYPE_DECLARED_CLASS.
-
-2011-09-27 Jakub Jelinek <jakub@redhat.com>
-
- * decl.c (duplicate_decls): If compatible stpcpy prototype
- is seen, set implicit_built_in_decls[BUILT_IN_STPCPY].
-
-2011-09-26 Jason Merrill <jason@redhat.com>
-
- PR c++/45012
- * pt.c (tsubst_copy_and_build) [CONST_DECL]: Don't pull out
- constant value if we're still in a template.
-
- PR c++/46105
- * typeck.c (structural_comptypes): Ignore cv-quals on typename scope.
-
- PR c++/50508
- * semantics.c (cxx_eval_logical_expression): Use tree_int_cst_equal
- rather than ==.
-
-2011-09-26 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/45487
- * error.c (dump_template_bindings): Separate bindings with semicolons
- instead of commas.
-
-2011-09-26 Jason Merrill <jason@redhat.com>
-
- PR c++/50512
- * call.c (compare_ics): Only consider rvaluedness_matches_p
- if the target type is the same or it too differs in rvalueness.
-
- PR c++/50523
- * call.c (implicit_conversion): Mask out inappropriate LOOKUP
- flags at the top of the function.
-
- * pt.c (tsubst_copy) [PARM_DECL]: Handle 'this' in NSDMI.
-
-2011-09-26 Paolo Carlini <paolo.carlini@oracle.com>
-
- * pt.c (convert_nontype_argument): Handle NULLPTR_TYPE.
-
-2011-09-26 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/26747
- * cp-gimplify.c (get_bc_label): Remove obsolete diagnostics.
-
-2011-09-25 Jason Merrill <jason@redhat.com>
-
- * parser.c (inject_this_parameter): Split out from
- cp_parser_late_return_type_opt.
- (cp_parser_class_specifier_1): Use it for NSDMIs.
- * tree.c (bot_replace): Replace NSDMI 'this' with real 'this'.
-
-2011-09-24 Jason Merrill <jason@redhat.com>
-
- * except.c (expr_noexcept_p): Split out from finish_noexcept_expr.
- * cp-tree.h: Declare it.
- * method.c (walk_field_subobs): Use it.
-
- * init.c (perform_member_init): Instantiate NSDMI here.
- * pt.c (tsubst_decl) [FIELD_DECL]: Not here.
-
- Handle deferred parsing of NSDMIs.
- * parser.h (cp_unparsed_functions_entry): Add nsdmis field.
- * parser.c (unparsed_nsdmis, cp_parser_save_nsdmi): New.
- (cp_parser_late_parse_one_default_arg): Split out from
- cp_parser_late_parsing_default_args.
- (cp_parser_late_parsing_nsdmi): New.
- (push_unparsed_function_queues): Set it.
- (cp_parser_parameter_declaration): Save the '=' token.
- (cp_parser_template_parameter): Likewise.
- (cp_parser_default_argument): Call cp_parser_initializer
- rather than cp_parser_initializer_clause.
- (cp_parser_class_specifier_1): Parse unparsed_nsdmis.
- (cp_parser_member_declaration): Handle nsdmis.
- * decl2.c (grokfield): Handle DEFAULT_ARG for a function.
-
- Implement C++11 non-static data member initializers.
- * cp-tree.h (enum cpp_warn_str): Add CPP0X_NSDMI.
- * error.c (maybe_warn_cpp0x): Handle it.
- * call.c (convert_like_real) [ck_user]: Don't complain about
- using an explicit constructor for direct-initialization.
- * class.c (check_field_decl): Fix ancient typo.
- (check_field_decls): NSDMIs make the default ctor non-trivial.
- * decl.c (cp_finish_decl): Record NSDMI.
- (grokdeclarator): Allow NSDMI.
- * decl2.c (grokfield): Allow NSDMI. Correct LOOKUP flags.
- * init.c (perform_member_init): Use NSDMI.
- * method.c (walk_field_subobs): Check for NSDMI.
- * parser.c (cp_parser_member_declaration): Parse { } init.
- * semantics.c (register_constexpr_fundef): Don't talk about
- a return statement in a constexpr constructor.
- (cxx_eval_call_expression): Check DECL_INITIAL instead of
- DECL_SAVED_TREE.
-
-2011-09-24 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/44267
- * class.c (build_base_path): Add a tsubst_flags_t parameter.
- (convert_to_base): Adjust call.
- * typeck.c (build_class_member_access_expr,
- get_member_function_from_ptrfunc, build_static_cast_1): Likewise.
- * init.c (dfs_initialize_vtbl_ptrs, emit_mem_initializers): Likewise.
- * method.c (do_build_copy_constructor, do_build_copy_assign): Likewise.
- * rtti.c (build_dynamic_cast_1): Likewise.
- * typeck2.c (build_scoped_ref, build_m_component_ref): Likewise.
- * call.c (build_over_call, build_special_member_call): Likewise.
- * cvt.c (cp_convert_to_pointer, convert_to_pointer_force,
- build_up_reference): Likewise.
- * cp-tree.h (build_base_path): Adjust declaration.
-
-2011-09-23 Jason Merrill <jason@redhat.com>
-
- Core 253 - allow const objects with no initializer or
- user-provided default constructor if the defaulted constructor
- initializes all the subobjects.
- PR c++/20039
- PR c++/42844
- * class.c (default_init_uninitialized_part): New.
- * cp-tree.h: Declare it.
- * decl.c (check_for_uninitialized_const_var): Use it.
- * init.c (perform_member_init): Likewise.
- (build_new_1): Likewise.
- * method.c (walk_field_subobs): Likewise.
-
-2011-09-23 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50258
- * decl.c (check_static_variable_definition): Allow in-class
- initialization of static data member of non-integral type in
- permissive mode.
-
-2011-09-22 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50491
- * semantics.c (potential_constant_expression_1): Handle USING_DECL.
-
-2011-09-22 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50371
- * pt.c (invalid_nontype_parm_type_p): Handle NULLPTR_TYPE.
-
-2011-09-22 Jonathan Wakely <jwakely.gcc@gmail.com>
- Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50344
- * friend.c (make_friend_class): cv-qualification is ok in a
- friend declaration.
-
-2011-09-21 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50454
- * decl.c (grokdeclarator): Consistently handle both __int128
- and unsigned __int128 with -pedantic; suppress diagnostic in
- system headers.
-
-2011-09-20 Jason Merrill <jason@redhat.com>
-
- * cp-tree.h (DECL_TEMPLOID_INSTANTIATION): New.
- (DECL_GENERATED_P): New.
- * class.c (finalize_literal_type_property): Use them.
- * semantics.c (is_instantiation_of_constexpr): Likewise.
- (register_constexpr_fundef): Likewise.
-
- * call.c (convert_default_arg): Avoid redundant copy.
- * tree.c (bot_manip): Copy everything.
-
-2011-09-20 Roberto Agostino Vitillo <ravitillo@lbl.gov>
-
- * call.c (build_new_method_call_1): Use non-virtual lookup
- for final virtual functions.
-
-2011-09-16 Jason Merrill <jason@redhat.com>
-
- PR c++/50424
- * call.c (set_flags_from_callee): Split out from build_call_a.
- * cp-tree.h: Declare it.
- * tree.c (bot_manip): Call it.
-
-2011-09-15 Jason Merrill <jason@redhat.com>
-
- PR c++/50365
- * parser.c (cp_parser_late_return_type_opt): Check quals parameter
- for clearing current_class_ptr, too.
-
-2011-09-14 Diego Novillo <dnovillo@google.com>
-
- * name-lookup.c (lookup_arg_dependent): Use conditional
- timevars.
- * decl.c (xref_tag): Likewise.
-
-2011-09-14 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50391
- * pt.c (regenerate_decl_from_template): Don't pass an error_mark_node
- to build_exception_variant.
-
-2011-09-13 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/48320
- * pt.c (template_parameter_pack_p): Support TEMPLATE_PARM_INDEX
- nodes. Add a comment.
- (arg_from_parm_pack_p): New static function, factorized out from
- tsubst_pack_expansion and extended to support non-type parameter
- packs represented with TEMPLATE_PARM_INDEX nodes.
- (tsubst_pack_expansion): Use arg_from_parm_pack_p.
-
-2011-09-12 Jason Merrill <jason@redhat.com>
-
- * pt.c (type_unification_real): Fix handling of DEDUCE_CONV
- with no deducible template parameters.
- * call.c (rejection_reason_code): Add rr_template_conversion.
- (print_z_candidate): Handle it.
- (template_conversion_rejection): New.
- (build_user_type_conversion_1): Use it.
-
- * call.c (merge_conversion_sequences): Set bad_p and user_conv_p
- on all of the second conversion sequence.
- (build_user_type_conversion_1): Set bad_p on the ck_user conv.
- (convert_like_real): Handle bad ck_ref_bind with user_conv_p in the
- first section. Fix loop logic.
- (initialize_reference): Call convert_like for diagnostics when
- we have a (bad) conversion.
-
- * call.c (convert_class_to_reference)
- (convert_class_to_reference_1): Remove.
- (reference_binding): Use build_user_type_conversion_1 instead.
-
- * call.c (initialize_reference): Add flags parm.
- * decl.c (grok_reference_init): Likewise.
- (check_initializer): Pass it.
- * typeck.c (convert_for_initialization): Likewise.
- * cp-tree.h: Adjust.
-
- * cp-tree.h (LOOKUP_NO_RVAL_BIND): New.
- * call.c (conditional_conversion): Use it.
- (reference_binding): Fix handling of xvalues.
-
-2011-09-09 Jason Merrill <jason@redhat.com>
-
- * call.c (implicit_conversion): Check BRACE_ENCLOSED_INITIALIZER_P
- before forcing instantiation.
-
-2011-09-08 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50324
- * typeck2.c (digest_init_r): Call complete_type_or_maybe_complain
- instead of complete_type_or_else.
-
-2011-09-08 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/33255 - Support -Wunused-local-typedefs warning
- * name-lookup.c (pushdecl_maybe_friend_1): Use the new
- record_locally_defined_typedef.
- * decl.c (finish_function): Use the new
- maybe_warn_unused_local_typedefs.
- (grokfield): Use the new record_locally_defined_typedef.
- * parser.c (lookup_name): Use the new maybe_record_typedef_use.
-
-2011-09-07 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/50309
- * decl.c (grokdeclarator): Check u.function.exception_specification
- for error_mark_node.
-
-2011-09-07 Jason Merrill <jason@redhat.com>
-
- PR c++/50298
- * parser.c (cp_parser_member_declaration): Don't require a constant
- rvalue here in C++0x.
-
- * pt.c (type_unification_real): Correct complain arg for tsubsting
- default template args.
-
- * pt.c (tsubst_aggr_type): Check TYPE_P before tsubsting.
-
-2011-09-06 Jason Merrill <jason@redhat.com>
-
- PR c++/50296
- * semantics.c (register_constexpr_fundef): Call is_valid_constexpr_fn.
- (cx_check_missing_mem_inits): Handle bases and empty trivial members.
- (validate_constexpr_fundecl): Remove.
- * decl.c (start_preparsed_function): Don't call it.
- * cp-tree.h: Don't declare it.
-
-2011-09-04 Jason Merrill <jason@redhat.com>
-
- PR c++/49267
- * call.c (reference_binding): Don't set is_lvalue for an rvalue
- reference rfrom.
-
- PR c++/49267
- PR c++/49458
- DR 1328
- * call.c (reference_binding): Set rvaluedness_matches_p properly
- for reference to function conversion ops.
- (compare_ics): Adjust.
-
- * class.c (trivial_default_constructor_is_constexpr): Rename from
- synthesized_default_constructor_is_constexpr.
- (type_has_constexpr_default_constructor): Adjust.
- (add_implicitly_declared_members): Call it instead.
- (explain_non_literal_class): Explain about non-constexpr default ctor.
- * cp-tree.h: Adjust.
- * method.c (synthesized_method_walk): Adjust.
- * semantics.c (explain_invalid_constexpr_fn): Handle defaulted
- functions, too.
-
- PR c++/50248
- Core 1358
- * init.c (perform_member_init): Don't diagnose missing inits here.
- (emit_mem_initializers): Or here.
- * method.c (process_subob_fn): Don't instantiate constexpr ctors.
- * semantics.c (cx_check_missing_mem_inits): New.
- (explain_invalid_constexpr_fn): Call it.
- (register_constexpr_fundef): Likewise. Leave
- DECL_DECLARED_CONSTEXPR_P set when the body is unsuitable.
- (cxx_eval_call_expression): Adjust diagnostics.
- (cxx_eval_constant_expression): Catch use of 'this' in a constructor.
-
-2011-08-30 Jason Merrill <jason@redhat.com>
-
- PR c++/50084
- * cp-tree.h (cp_decl_specifier_seq): Rename user_defined_type_p
- to type_definition_p.
- * parser.c (cp_parser_set_decl_spec_type): Likewise.
- * decl.c (grokdeclarator): Check it.
-
- PR c++/50089
- * semantics.c (finish_id_expression): Use
- current_nonlambda_class_type for qualified-ids.
-
- PR c++/50114
- * decl.c (poplevel): Disable for scope compatibility hack
- in C++11 mode.
-
- PR c++/50220
- * semantics.c (add_capture): Call complete_type for copy.
-
- PR c++/50234
- * semantics.c (cxx_eval_component_reference): Handle
- value-initialization for omitted initializers.
-
-2011-08-29 Jason Merrill <jason@redhat.com>
-
- PR c++/50224
- * semantics.c (finish_id_expression): Mark captured variables used.
-
-2011-08-29 Jakub Jelinek <jakub@redhat.com>
- Jason Merrill <jason@redhat.com>
-
- PR c++/50207
- * class.c (finish_struct_1): Complain if the first field is
- artificial.
-
-2011-08-29 Jason Merrill <jason@redhat.com>
-
- PR c++/50209
- Core DR 994
- * parser.c (cp_parser_default_argument): Use
- cp_parser_initializer_clause.
- (cp_parser_late_parsing_default_args): Likewise.
-
-2011-08-26 Jason Merrill <jason@redhat.com>
-
- Core DR 342
- PR c++/48582
- * pt.c (check_valid_ptrmem_cst_expr): A null member pointer value
- is valid in C++11.
- (convert_nontype_argument): Likewise. Implicitly convert nullptr
- and do constant folding.
- * mangle.c (write_template_arg_literal): Mangle null member
- pointer values as 0.
- * call.c (null_member_pointer_value_p): New.
- * cp-tree.h: Declare it.
-
-2011-08-25 Jason Merrill <jason@redhat.com>
-
- * call.c (convert_like_real): Remove redundant complain checks.
-
- PR c++/50157
- * call.c (convert_like_real): Exit early if bad and !tf_error.
-
-2011-08-23 Jason Merrill <jason@redhat.com>
-
- * typeck2.c (build_functional_cast): Don't try to avoid calling
- build_value_init.
- * pt.c (instantiate_class_template_1): Don't copy TYPE_HAS_* flags.
-
-2011-08-23 Jason Merrill <jason@redhat.com>
-
- PR c++/49045
- Core 1321
- * tree.c (dependent_name): New.
- (cp_tree_equal): Two calls with the same dependent name are
- equivalent even if the overload sets are different.
-
-2011-08-23 Jason Merrill <jason@redhat.com>
-
- * tree.c (build_target_expr): Set TREE_CONSTANT on
- literal TARGET_EXPR if the value is constant.
- * typeck2.c (build_functional_cast): Don't set it here.
-
-2011-08-23 Jason Merrill <jason@redhat.com>
-
- Core 903 (partial)
- * call.c (null_ptr_cst_p): Only 0 qualifies in C++11.
-
-2011-08-23 Jason Merrill <jason@redhat.com>
-
- Core 975
- * decl.c (cxx_init_decl_processing): Initialize
- dependent_lambda_return_type_node.
- * cp-tree.h (cp_tree_index): Add CPTI_DEPENDENT_LAMBDA_RETURN_TYPE.
- (dependent_lambda_return_type_node): Define.
- (DECLTYPE_FOR_LAMBDA_RETURN): Remove.
- * semantics.c (lambda_return_type): Handle overloaded function.
- Use dependent_lambda_return_type_node instead of
- DECLTYPE_FOR_LAMBDA_RETURN.
- (apply_lambda_return_type): Don't check dependent_type_p.
- * pt.c (tsubst_copy_and_build): Handle lambda return type deduction.
- (instantiate_class_template_1): Likewise.
- (tsubst): Don't use DECLTYPE_FOR_LAMBDA_RETURN.
- * mangle.c (write_type): Likewise.
- * typeck.c (structural_comptypes): Likewise.
- (check_return_expr): Handle dependent_lambda_return_type_node.
-
-2011-08-23 Jason Merrill <jason@redhat.com>
-
- PR c++/50024
- * semantics.c (maybe_constant_value): Don't try to fold { }.
- * pt.c (build_non_dependent_expr): Don't wrap { }.
- * init.c (build_value_init): Allow scalar value-init in templates.
-
-2011-08-23 Jason Merrill <jason@redhat.com>
-
- * semantics.c (potential_constant_expression_1): Allow 'this'.
-
-2011-08-23 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/50158
- * typeck.c (cp_build_modify_expr): Call mark_rvalue_use on rhs
- if it has side-effects and needs to be preevaluated.
-
-2011-08-23 Siddhesh Poyarekar <siddhesh.poyarekar@gmail.com>
-
- PR c++/50055
- * except.c (begin_eh_spec_block): Build EH_SPEC block on the
- same line as the function.
-
-2011-08-23 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/46862
- * class.c (finish_struct_1): If TYPE_TRANSPARENT_AGGR is set on a type
- which doesn't have any fields, clear it and diagnose.
-
-2011-08-18 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
- Marc Glisse <marc.glisse@normalesup.org>
-
- PR libstdc++-v3/1773
- * mangle.c (decl_mangling_context): Call
- targetm.cxx.decl_mangling_context.
- (write_unscoped_name): Use decl_mangling_context.
-
-2011-08-18 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/45625
- * pt.c (parameter_of_template_p): Handle comparison with DECLs of
- template parameters as created by process_template_parm.
-
-2011-08-16 Jason Merrill <jason@redhat.com>
-
- PR c++/50086
- * pt.c (unify_pack_expansion): Correct overloaded unification
- logic.
-
- * pt.c (instantiate_class_template_1): If DECL_PRESERVE_P is set
- on a member function or static data member, call mark_used.
-
- PR c++/50054
- * typeck2.c (cxx_incomplete_type_diagnostic): Handle
- init_list_type_node.
-
-2011-08-13 Jason Merrill <jason@redhat.com>
-
- PR c++/50075
- * name-lookup.c (local_bindings_p): New.
- * name-lookup.h: Declare it.
- * lex.c (unqualified_name_lookup_error): Use it.
-
- PR c++/50059
- * error.c (dump_expr): Handle MODIFY_EXPR properly.
-
- * decl.c (grok_reference_init): Handle constexpr here.
- * call.c (initialize_reference): Not here.
-
-2011-08-12 David Li <davidxl@google.com>
-
- * class.c (update_vtable_entry_for_fn): Set
- LOST_PRIMARY bit properly.
-
-2011-08-12 Jason Merrill <jason@redhat.com>
-
- PR c++/50034
- * call.c (convert_arg_to_ellipsis): force_rvalue only in
- potentially evaluated context.
-
-2011-08-12 Richard Guenther <rguenther@suse.de>
-
- * call.c (build_over_call): Instead of memcpy use an
- assignment of two MEM_REFs.
-
-2011-08-11 Romain Geissler <romain.geissler@gmail.com>
- Brian Hackett <bhackett1024@gmail.com>
-
- * decl.c (cp_finish_decl): Invoke callbacks on finish_decl event.
-
-2011-08-10 Richard Guenther <rguenther@suse.de>
-
- * call.c (build_over_call): Call memcpy unconditionally.
-
-2011-08-08 Jason Merrill <jason@redhat.com>
-
- PR c++/50020
- * semantics.c (finish_call_expr): Don't look at 'this' if we
- had an explicit object argument.
-
- PR c++/50011
- * typeck2.c (check_narrowing): Fix integer logic.
-
-2011-08-08 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
-
- * Make-lang.in (g++$(exeext)): Add $(EXTRA_GCC_LIBS).
-
-2011-08-05 Jason Merrill <jason@redhat.com>
-
- PR c++/48993
- * semantics.c (potential_constant_expression_1) [CALL_EXPR]: Sorry
- on 'this' in a constructor.
-
- PR c++/49921
- * semantics.c (finish_decltype_type): Call invalid_nonstatic_memfn_p.
-
- PR c++/49669
- * init.c (perform_member_init): Handle invalid array initializer.
-
- PR c++/49988
- * semantics.c (cxx_eval_array_reference): Handle failure to
- reduce the array operand to something we can work with.
-
-2011-08-05 Gabriel Charette <gchare@google.com>
-
- * decl.c (finish_function): Remove unecessary line 0 hack.
-
-2011-08-05 Jason Merrill <jason@redhat.com>
-
- PR c++/47453
- * typeck.c (build_x_compound_expr_from_list): Also complain
- about ({...}).
-
- PR c++/49812
- * typeck.c (cp_build_unary_op) [POSTINCREMENT_EXPR]: Strip cv-quals.
-
- PR c++/49983
- * parser.c (cp_parser_range_for): Only do auto deduction in
- template if the range is non-dependent.
-
- * init.c (perform_member_init): Always build_aggr_init
- for a class member with an explicit mem-initializer.
-
- * pt.c (unify) [TEMPLATE_TYPE_PARM]: Allow VLA for C++0x 'auto'.
-
-2011-08-04 Jakub Jelinek <jakub@redhat.com>
-
- PR middle-end/49905
- * decl.c (cxx_init_decl_processing): Add alloc_size (1) attribute
- for operator new and operator new []. Call init_attributes.
-
-2011-08-02 Jason Merrill <jason@redhat.com>
-
- PR c++/43886
- * parser.c (cp_parser_lambda_body): Clear local_variables_forbidden_p.
-
- PR c++/49577
- * typeck2.c (check_narrowing): Check unsigned mismatch.
- * semantics.c (finish_compound_literal): check_narrowing.
-
- PR c++/49593
- * pt.c (find_parameter_packs_r): Handle CONSTRUCTOR.
-
- PR c++/49803
- * init.c (sort_mem_initializers): Initialize uses_unions_p here.
- (build_field_list): Not here.
-
- PR c++/49834
- * parser.c (build_range_temp): Split out from...
- (cp_convert_range_for): ...here.
- (do_range_for_auto_deduction): New.
- (cp_parser_range_for): Use it.
-
-2011-08-02 Jakub Jelinek <jakub@redhat.com>
-
- * cp-tree.h (finish_omp_atomic): Adjust prototype.
- (cxx_omp_const_qual_no_mutable): New prototype.
- (finish_omp_taskyield): New prototype.
- * parser.c (cp_parser_omp_atomic): (cp_parser_omp_atomic): Handle
- parsing OpenMP 3.1 atomics. Adjust finish_omp_atomic caller.
- (cp_parser_omp_clause_name): Handle final and mergeable clauses.
- (cp_parser_omp_clause_final, cp_parser_omp_clause_mergeable): New
- functions.
- (cp_parser_omp_all_clauses): Handle PRAGMA_OMP_CLAUSE_FINAL
- and PRAGMA_OMP_CLAUSE_MERGEABLE.
- (OMP_TASK_CLAUSE_MASK): Allow final and mergeable clauses.
- (cp_parser_omp_taskyield): New function.
- (cp_parser_pragma): Handle PRAGMA_OMP_TASKYIELD.
- (cp_parser_omp_clause_reduction): Handle min and max.
- * pt.c (tsubst_expr) <case OMP_ATOMIC>: Handle OpenMP 3.1 atomics.
- (tsubst_omp_clauses): Handle OMP_CLAUSE_FINAL and
- OMP_CLAUSE_MERGEABLE.
- * semantics.c (finish_omp_atomic): Add OPCODE, V, LHS1 and RHS1
- arguments. Handle OpenMP 3.1 atomics. Adjust c_finish_omp_atomic
- caller.
- (finish_omp_clauses): Don't complain about const qualified
- predetermined vars and static data members in firstprivate clause.
- Handle OMP_CLAUSE_FINAL and OMP_CLAUSE_MERGEABLE. Handle MIN_EXPR
- and MAX_EXPR.
- (finish_omp_taskyield): New function.
- * cp-gimplify.c (cxx_omp_const_qual_no_mutable): New function.
- (cxx_omp_predetermined_sharing): Use it.
-
-2011-08-02 Jason Merrill <jason@redhat.com>
-
- * call.c (build_call_a): Also check at_function_scope_p.
-
-2011-08-01 Jason Merrill <jason@redhat.com>
-
- PR c++/49932
- * mangle.c (write_prefix): Handle decltype.
-
- PR c++/49924
- * semantics.c (cxx_eval_vec_init_1): Fix logic.
-
- PR c++/49813
- * semantics.c (potential_constant_expression_1): Allow any builtin.
- (morally_constexpr_builtin_function_p): Remove.
-
-2011-07-29 Jason Merrill <jason@redhat.com>
-
- PR c++/49867
- * parser.c (cp_parser_lambda_expression): Also clear in_statement
- and in_switch_statement_p.
- (cp_parser_class_specifier): Likewise.
-
-2011-07-28 Jason Merrill <jason@redhat.com>
-
- PR c++/49808
- * pt.c (tsubst) [TEMPLATE_PARM_INDEX]: Call convert_from_reference.
- (convert_nontype_argument, tsubst_template_arg): Handle its output.
-
-2011-07-28 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/49813
- * semantics.c (potential_constant_expression_1): Handle FMA_EXPR.
-
-2011-07-27 Jeffrey Yasskin <jyasskin@google.com>
-
- * pt.c (build_template_decl): Copy the function_decl's
- source location to the new template_decl.
-
-2011-07-26 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/49776
- * typeck.c (cp_build_modify_expr): Check digest_init return value
- for error_mark_node.
-
-2011-07-25 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR bootstrap/49845
- * parser.c (cp_parser_perform_range_for_lookup): Always assign *being
- and *end before returning.
-
-2011-07-25 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/49838
- * parser.c (cp_parser_perform_range_for_lookup): Early return if
- error_operand_p (range).
-
-2011-07-23 Jason Merrill <jason@redhat.com>
-
- PR c++/49823
- * parser.c (cp_parser_qualifying_entity): Handle templates.
-
-2011-07-22 Jason Merrill <jason@redhat.com>
-
- PR c++/49793
- * typeck2.c (check_narrowing): Downgrade permerror to pedwarn.
- Make conditional on -Wnarrowing.
-
-2011-07-22 Ville Voutilainen <ville.voutilainen@gmail.com>
-
- Warn about the use of final/override in non-c++0x mode, and
- add __final for non-c++0x mode.
- * cp-tree.h (cpp0x_warn_str): Add CPP0X_OVERRIDE_CONTROLS.
- * error.c (maybe_warn_cpp0x): Adjust.
- * parser.c (cp_parser_virt_specifier_seq_opt): Use it. Add
- '__final' as a non-c++0x alternative for 'final'.
-
-2011-07-22 Jason Merrill <jason@redhat.com>
- Mark Glisse <marc.glisse@normalesup.org>
-
- PR c++/30112
- * decl.c (cp_finish_decl): Apply pragma redefine_extname in
- other namespaces as well.
- * name-lookup.c (c_linkage_bindings): Define.
- (lookup_extern_c_fun_in_all_ns): Rename from
- lookup_extern_c_fun_binding_in_all_ns. Return tree.
- (pushdecl_maybe_friend_1): Adjust. Copy DECL_ASSEMBLER_NAME.
-
-2011-07-20 Jason Merrill <jason@redhat.com>
-
- * parser.c (cp_parser_initializer_list): Handle C99 .id= and [N]=
- designated initializer syntax.
- * decl.c (check_array_designated_initializer): Add index parm.
- (maybe_deduce_size_from_array_init): Pass it.
- (reshape_init_array_1): Likewise.
-
- PR c++/6709 (DR 743)
- PR c++/42603 (DR 950)
- * parser.c (token_is_decltype, cp_lexer_next_token_is_decltype): New.
- (cp_parser_nested_name_specifier_opt): Allow decltype.
- (cp_parser_qualifying_entity): Likewise.
- (cp_parser_decltype): Replace source tokens with CPP_DECLTYPE.
- (cp_parser_simple_type_specifier): Handle decltype as scope.
- (cp_parser_base_specifier): Allow decltype.
- (cp_parser_base_clause): Don't crash on null base.
- * parser.h (CPP_KEYWORD, CPP_TEMPLATE_ID): Move to c-common.h.
- (CPP_NESTED_NAME_SPECIFIER, N_CP_TTYPES): Likewise.
-
-2011-07-19 Jason Merrill <jason@redhat.com>
-
- PR c++/49785
- * pt.c (coerce_template_parms): Handle non-pack after pack.
-
-2011-07-19 Richard Guenther <rguenther@suse.de>
-
- * call.c (build_special_member_call): Use fold_build_pointer_plus.
- * class.c (build_base_path): Likewise.
- (convert_to_base_statically): Likewise.
- (dfs_accumulate_vtbl_inits): Likewise.
- * cp-gimplify.c (cxx_omp_clause_apply_fn): Likewise.
- * except.c (expand_start_catch_block): Likewise.
- * init.c (expand_virtual_init): Likewise.
- (build_new_1): Likewise.
- (build_vec_delete_1): Likewise.
- (build_vec_delete): Likewise.
- * rtti.c (build_headof): Likewise.
- (tinfo_base_init): Likewise.
- * typeck.c (get_member_function_from_ptrfunc): Likewise.
- (cp_build_addr_expr_1): Likewise.
- * typeck2.c (build_m_component_ref): Likewise.
-
-2011-07-18 Martin Jambor <mjambor@suse.cz>
-
- * parser.c (cp_parser_parameter_declaration_list): Initialize
- parenthesized_p.
-
-2011-07-16 Jason Merrill <jason@redhat.com>
-
- * pt.c (tinst_level_tick, last_template_error_tick): Replace with
- last_error_tinst_level.
- (push_tinst_level, pop_tinst_level): Adjust.
- (problematic_instantiation_changed): Adjust.
- (record_last_problematic_instantiation): Adjust.
- * error.c (cp_print_error_function): Don't print
- current_function_decl if we're in a template instantiation context.
- (print_instantiation_full_context): Always print first line.
-
-2011-07-16 Nathan Froyd <froydnj@codesourcery.com>
- Jason Merrill <jason@redhat.com>
-
- PR c++/45329
- PR c++/48934
- * cp-tree.h (fn_type_unification): Add `bool' parameter.
- * pt.c (enum template_base_result): Define.
- (unify_success, unify_unknown): Define.
- (unify_parameter_deduction_failure): Define.
- (unify_invalid, unify_cv_qual_mismatch, unify_type_mismatch): Define.
- (unify_parameter_pack_mismatch): Define.
- (unify_parameter_pack_inconsistent): Define.
- (unify_ptrmem_cst_mismatch, unify_vla_arg): Define.
- (unify_expression_unequal, unify_inconsistency): Define.
- (unify_method_type_error, unify_arity): Likewise.
- (unify_too_many_parameters, unify_too_few_parameters): Define.
- (unify_arg_conversion, unify_no_common_base): Define.
- (unify_illformed_ptrmem_cst_expr): Define.
- (unify_substitution_failure): Define.
- (unify_inconsistent_template_template_parameters): Define.
- (unify_template_deduction_failure): Define.
- (unify_template_argument_mismatch): Define.
- (unify_overload_resolution_failure): Define.
- (comp_template_args_with_info): New function, split out from...
- (comp_template_args): ...here. Call it.
- (deduction_tsubst_fntype): Add `complain' parameter'. Pass it
- to tsubst.
- (unify): Add `explain_p' parameter. Pass to all relevant calls.
- Call above status functions when appropriate.
- (resolve_overloaded_unification, try_one_overload): Likewise.
- (type_unification, type_unification_real): Likewise.
- (unify_pack_expansion): Likewise.
- (get_template_base, try_class_unification): Likewise.
- (get_bindings, more_specialized_fn): Pass false to unification
- calls.
- (get_class_bindings, do_auto_deduction): Likewise.
- (convert_nontype_argument): Likewise.
- (fn_type_unification): Likewise. Pass tf_warning_or_error if
- explain_p.
- (get_template_base): Add `explain_p' parameter and pass it to
- try_class_unification. Return an enum template_base_result.
- * class.c (resolve_address_of_overloaded_function): Pass false to
- fn_type_unification.
- * call.c (enum rejection_reason_code): Add new codes.
- (struct rejection_reason): Add template_unification field.
- Add template_instantiation field.
- (template_unification_rejection): Define.
- (template_unification_error_rejection): Define.
- (template_instantiation_rejection): Define.
- (invalid_copy_with_fn_template_rejection): Define.
- (add_template_candidate): Pass false to unify.
- Provide more rejection reasons when possible.
- (print_template_unification_rejection): Define.
- (print_arity_rejection): Define, split out from...
- (print_z_candidate): ...here. Add cases for new rejection
- reasons.
-
-2011-07-15 Jason Merrill <jason@redhat.com>
-
- * Make-lang.in (check-g++-strict-gc): New.
- (cp/except.o): Depend on gt-cp-except.h
- * except.c: Include gt-cp-except.h.
- * config-lang.in (gtfiles): Add cp/except.c.
- * decl2.c (mark_used): Adjust constexpr condition, set
- function_depth around template instantiation.
- * parser.c (cp_parser_lambda_body): Set function_depth.
- * semantics.c (maybe_add_lambda_conv_op): Likewise.
-
- PR testsuite/49741
- * Make-lang.in (check-c++0x): Use --extra_opts instead of--tool_opts.
-
-2011-07-13 Jason Merrill <jason@redhat.com>
-
- * Make-lang.in (check-c++0x): New.
-
-2011-07-13 Richard Sandiford <richard.sandiford@linaro.org>
-
- * typeck2.c (split_nonconstant_init_1): Pass the initializer directly,
- rather than a pointer to it. Return true if the whole of the value
- was initialized by the generated statements. Use
- complete_ctor_at_level_p instead of count_type_elements.
-
-2011-07-12 Diego Novillo <dnovillo@google.com>
-
- * name-lookup.h (cp_binding_level): Rename from cxx_scope.
- Update all users.
- (struct cp_binding_level): Fix indentation.
-
-2011-07-11 Jason Merrill <jason@redhat.com>
-
- PR c++/49672
- * pt.c (extract_fnparm_pack): Split out from...
- (make_fnparm_pack): ...here.
- (instantiate_decl): Handle non-pack parms after a pack.
- * semantics.c (maybe_add_lambda_conv_op): Don't in a template.
-
- * decl2.c (decl_constant_var_p): Use decl_maybe_constant_var_p.
-
- PR c++/44609
- * cp-tree.h (struct tinst_level): Add errors field.
- * pt.c (neglectable_inst_p, limit_bad_template_recurson): New.
- (push_tinst_level): Don't start another decl in that case.
- (reopen_tinst_level): Adjust errors field.
- * decl2.c (cp_write_global_declarations): Don't complain about
- undefined inline if its template was defined.
- * mangle.c (mangle_decl_string): Handle failure from push_tinst_level.
-
-2011-07-10 Jason Merrill <jason@redhat.com>
-
- PR c++/49691
- * parser.c (cp_parser_late_return_type_opt): Check quals parameter
- rather than current_class_type to determine whether to set 'this'.
- (cp_parser_direct_declarator): Pass -1 to quals if member_p is false.
- (cp_parser_init_declarator): Pass down member_p.
-
-2011-07-09 Jason Merrill <jason@redhat.com>
-
- * tree.c (build_vec_init_elt): Strip TARGET_EXPR.
-
-2011-07-08 Jason Merrill <jason@redhat.com>
-
- PR c++/45437
- * typeck.c (cp_build_modify_expr): Preevaluate RHS.
-
- * method.c (use_thunk): Use cgraph_add_to_same_comdat_group.
- * optimize.c (maybe_clone_body): Likewise.
- * semantics.c (maybe_add_lambda_conv_op): Likewise.
-
- PR c++/45603
- * decl.c (expand_static_init): Don't get confused by user
- declaration of __cxa_guard_acquire.
-
- * typeck.c (cp_apply_type_quals_to_decl): Don't check
- COMPLETE_TYPE_P either.
-
- PR c++/49673
- * typeck.c (cp_apply_type_quals_to_decl): Don't check
- TYPE_NEEDS_CONSTRUCTING.
-
-2011-07-07 Jason Merrill <jason@redhat.com>
-
- PR c++/49663
- * pt.c (push_deduction_access_scope): Preserve
- processing_template_decl across push_to_top_level.
- And revert:
- * class.c (pushclass): Accept NULL argument.
- (popclass): Deal with popping null class.
- * pt.c (push_access_scope, pop_access_scope): Use them rather than
- push_to_top_level/pop_from_top_level.
- * name-lookup.c (lookup_name_real_1): Check current_class_type.
-
-2011-07-07 Jakub Jelinek <jakub@redhat.com>
-
- PR c/49644
- * typeck.c (cp_build_binary_op): For MULT_EXPR and TRUNC_DIV_EXPR with
- one non-complex and one complex argument, call save_expr on both
- operands.
-
-2011-07-06 Jason Merrill <jason@redhat.com>
-
- PR c++/49353
- * semantics.c (expand_or_defer_fn_1): Clear DECL_EXTERNAL
- on kept inlines.
-
- PR c++/49568
- * method.c (make_thunk, use_thunk): Copy DECL_COMDAT.
-
-2011-07-05 Jason Merrill <jason@redhat.com>
-
- PR c++/48157
- * pt.c (tsubst_qualified_id): Preserve TEMPLATE_ID_EXPR in
- partial instantiation.
-
- PR c++/49598
- * semantics.c (finish_id_expression): convert_from_reference.
-
-2011-07-05 Richard Guenther <rguenther@suse.de>
-
- * decl.c (cxx_init_decl_processing): Defer building common
- tree nodes to c_common_nodes_and_builtins.
-
-2011-07-04 Jason Merrill <jason@redhat.com>
-
- DR 1207
- PR c++/49589
- * mangle.c (write_expression): Handle 'this'.
- * parser.c (cp_parser_postfix_dot_deref_expression): Allow
- incomplete *this.
- * semantics.c (potential_constant_expression_1): Check that
- DECL_CONTEXT is set on 'this'.
-
- * error.c (dump_template_bindings): Don't print typenames
- for a partial instantiation.
- (dump_function_decl): If we aren't printing function arguments,
- print template arguments as <args> rather than [with ...].
- (dump_expr): Don't print return type or template header.
- [BASELINK]: Use BASELINK_FUNCTIONS rather than get_first_fn.
- * pt.c (dependent_template_arg_p): Handle null arg.
-
- * error.c (type_to_string): Avoid redundant akas.
-
-2011-07-01 Jonathan Wakely <jwakely.gcc@gmail.com>
-
- PR c++/49605
- * init.c (build_delete): Only warn for sfk_deleting_destructor.
-
-2011-07-01 Jakub Jelinek <jakub@redhat.com>
-
- * Make-lang.in (cp/decl.o): Depend on pointer-set.h.
- (cp/class.o): Likewise.
- (cp/error.o): Likewise.
- (cp/name-lookup.o): Likewise.
- (cp/decl2.o): Likewise. Don't depend on $(POINTER_SET_H).
-
-2011-07-01 Jason Merrill <jason@redhat.com>
-
- PR c++/48261
- * pt.c (lookup_template_function): Handle non-function.
-
- PR c++/48593
- * pt.c (tsubst_qualified_id): Check PTRMEM_OK_P.
- * tree.c (build_qualified_name): Set PTRMEM_OK_P.
- * semantics.c (finish_parenthesized_expr): Clear PTRMEM_OK_P on
- SCOPE_REF, too.
- * cp-tree.h (PTRMEM_OK_P): Apply to SCOPE_REF, too.
- (QUALIFIED_NAME_IS_TEMPLATE): Switch to lang flag 1.
-
- PR c++/48883
- PR c++/49609
- * pt.c (resolve_nondeduced_context): Call mark_used.
-
- PR c++/49085
- * semantics.c (finish_offsetof): Complain about incomplete type.
-
-2011-06-30 Jason Merrill <jason@redhat.com>
-
- PR c++/49387
- * rtti.c (get_tinfo_decl): Call complete_type.
-
- PR c++/49569
- * method.c (implicitly_declare_fn): Set DECL_PARM_LEVEL and
- DECL_PARM_INDEX on rhs parm.
-
- * pt.c (iterative_hash_template_arg): Use cp_tree_operand_length.
-
- PR c++/49355
- * tree.c (stabilize_init): Handle aggregate initialization.
-
- PR c++/48481
- * name-lookup.c (struct arg_lookup): Add fn_set.
- (add_function): Check it.
- (lookup_arg_dependent_1): Initialize it.
-
-2011-06-29 Jason Merrill <jason@redhat.com>
-
- PR c++/49216
- * init.c (build_new_1): Pass {} down to build_vec_init.
- (build_vec_init): Handle it.
-
- DR 1207
- PR c++/49003
- * cp-tree.h (struct saved_scope): Add x_current_class_ptr,
- x_current_class_ref.
- (current_class_ptr, current_class_ref): Use them.
- * decl.c (build_this_parm): Handle getting the class type.
- * parser.c (cp_parser_late_return_type_opt): Set up 'this'
- for use within the trailing return type.
-
- * pt.c (tsubst_decl) [VAR_DECL]: In unevaluated operand,
- don't tsubst DECL_INITIAL unless our type use auto.
-
- PR c++/49520
- * semantics.c (constexpr_fn_retval): Handle CLEANUP_POINT_EXPR here.
- (massage_constexpr_body): Not here.
-
- PR c++/49554
- * semantics.c (lambda_proxy_type): New.
- (build_capture_proxy): Use it.
- * cp-tree.h (DECLTYPE_FOR_LAMBDA_PROXY): New.
- * pt.c (tsubst) [DECLTYPE_TYPE]: Use them.
-
- PR c++/45923
- * class.c (explain_non_literal_class): New.
- (finalize_literal_type_property): Call it.
- * cp-tree.h: Declare it.
- * semantics.c (ensure_literal_type_for_constexpr_object): Call it.
- (is_valid_constexpr_fn): Likewise.
- (massage_constexpr_body): Split out from...
- (register_constexpr_fundef): ...here.
- (is_instantiation_of_constexpr): New.
- (expand_or_defer_fn_1): Leave DECL_SAVED_TREE alone in that case.
- (explain_invalid_constexpr_fn): New.
- (cxx_eval_call_expression): Call it.
- (potential_constant_expression_1): Likewise. Avoid redundant errors.
- * method.c (process_subob_fn): Diagnose non-constexpr.
- (walk_field_subobs): Likewise.
- (synthesized_method_walk): Don't shortcut if we want diagnostics.
- (explain_implicit_non_constexpr): New.
- (defaulted_late_check): Use it.
- * call.c (build_cxx_call): Remember location.
-
- * method.c (maybe_explain_implicit_delete): Use pointer_set
- instead of htab.
-
- * class.c (finalize_literal_type_property): Update conditions.
- * method.c (defaulted_late_check): Set TYPE_HAS_CONSTEXPR_CTOR.
-
- * tree.c (build_vec_init_expr): Don't add TARGET_EXPR.
- * typeck2.c (digest_init_r): Handle VEC_INIT_EXPR.
- * semantics.c (cxx_eval_vec_init_1): Correct type.
-
- * init.c (build_value_init): Decide whether or not to zero-initialize
- based on user-providedness of default ctor, not any ctor.
- (build_value_init_noctor): Adjust assert.
-
- DR 990
- * call.c (convert_like_real) [ck_user]: Handle value-initialization.
- (build_new_method_call_1): Likewise.
- * init.c (expand_default_init): Handle direct list-initialization
- of aggregates.
-
-2011-06-27 Jakub Jelinek <jakub@redhat.com>
-
- * cp-tree.h (union lang_tree_node): Use it in chain_next expression.
-
-2011-06-26 Jason Merrill <jason@redhat.com>
-
- PR c++/49528
- * semantics.c (potential_constant_expression_1): Check
- for non-literality rather than cleanup.
- (cxx_eval_constant_expression): Likewise.
-
- PR c++/49528
- * semantics.c (potential_constant_expression_1): A TARGET_EXPR
- with a cleanup isn't constant.
- (cxx_eval_constant_expression): Likewise.
- * init.c (expand_default_init): Use maybe_constant_init.
-
-2011-06-24 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/46400
- * cp-tree.h (union lang_tree_node): Use TYPE_NEXT_VARIANT
- instead of TYPE_CHAIN for chain_next for types.
-
-2011-06-23 Gabriel Charette <gchare@google.com>
-
- * name-lookup.h (cp_binding_level): Removed unused
- member names_size. Update all users.
-
-2011-06-23 Jason Merrill <jason@redhat.com>
-
- * typeck2.c (build_functional_cast): Strip cv-quals for value init.
- * init.c (build_zero_init_1): Not here.
-
- PR c++/35255
- * pt.c (resolve_overloaded_unification): Fix DR 115 handling.
-
-2011-06-23 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/44625
- * decl2.c (build_anon_union_vars): Early return error_mark_node
- for a nested anonymous struct.
-
-2011-06-23 Jason Merrill <jason@redhat.com>
-
- PR c++/49507
- * decl2.c (mark_used): Don't call synthesize_method for
- functions defaulted outside the class.
-
- * optimize.c (maybe_clone_body): Set linkage flags before
- cgraph_same_body_alias.
-
- PR c++/49440
- * class.c (set_linkage_according_to_type): Hand off to
- determine_visibility.
-
- PR c++/49395
- * init.c (build_zero_init_1): Strip cv-quals from scalar types.
-
- PR c++/36435
- * pt.c (most_specialized_instantiation): Do check return types.
-
-2011-06-22 Jason Merrill <jason@redhat.com>
-
- PR c++/49260
- * call.c (build_call_a): Set cp_function_chain->can_throw here.
- (build_cxx_call): Not here.
-
-2011-06-21 Jason Merrill <jason@redhat.com>
-
- PR c++/49172
- * decl.c (cp_finish_decl): Adjust init_const_expr_p for refs.
- (grokdeclarator): constexpr doesn't apply const for refs.
- * parser.c (cp_parser_initializer_clause): Don't call
- maybe_constant_value here.
- * call.c (initialize_reference): Handle constexpr.
-
- PR c++/49482
- * semantics.c (maybe_add_lambda_conv_op): Call mark_exp_read for
- static fn parameters.
-
- * call.c (add_builtin_candidates): Use cv_unqualified rather than
- TYPE_MAIN_VARIANT.
- * pt.c (tsubst_arg_types): Likewise.
- * except.c (build_throw): Use cv_unqualified.
-
- PR c++/49418
- * call.c (cxx_type_promotes_to): Don't strip cv-quals.
- * semantics.c (lambda_return_type): Strip them here.
-
-2011-06-21 Andrew MacLeod <amacleod@redhat.com>
-
- * semantics.c: Add sync_ or SYNC__ to builtin names.
-
-2011-06-20 Jason Merrill <jason@redhat.com>
-
- PR c++/49216
- * init.c (build_vec_init): Don't try to use a CONSTRUCTOR when
- base is a pointer.
- * typeck2.c (process_init_constructor_array): Use {} for classes,
- too.
- * call.c (convert_like_real): Handle substitution failure.
-
- PR c++/48138
- * pt.c (canonicalize_type_argument): New.
- (convert_template_argument, unify): Use it.
-
- PR c++/47080
- * call.c (rejection_reason_code): Add rr_explicit_conversion.
- (print_z_candidate): Handle it.
- (explicit_conversion_rejection): New.
- (build_user_type_conversion_1): Reject an explicit conversion
- function that requires more than a qualification conversion.
-
- PR c++/47635
- * decl.c (grokdeclarator): Don't set ctype to an ENUMERAL_TYPE.
-
- PR c++/48138
- * tree.c (strip_typedefs): Use build_aligned_type.
-
- PR c++/49205
- * call.c (sufficient_parms_p): Allow parameter packs too.
-
- PR c++/43321
- * semantics.c (describable_type): Remove.
- * cp-tree.h: Likewise.
- * decl.c (cp_finish_decl): Don't call it.
- * init.c (build_new): Likewise.
- * parser.c (cp_parser_omp_for_loop): Likewise.
- * pt.c (tsubst_decl): Likewise.
- (do_auto_deduction): If we fail in a template, try again
- at instantiation time.
-
- PR c++/43831
- * parser.c (cp_parser_lambda_introducer): Complain about redundant
- captures.
- * semantics.c (add_capture): Likewise.
- (register_capture_members): Clear IDENTIFIER_MARKED.
-
-2011-06-17 Jason Merrill <jason@redhat.com>
-
- PR c++/49458
- * call.c (convert_class_to_reference_1): Allow binding function
- lvalue to rvalue reference.
-
- PR c++/43912
- Generate proxy VAR_DECLs for better lambda debug info.
- * cp-tree.h (FUNCTION_NEEDS_BODY_BLOCK): Add lambda operator().
- (LAMBDA_EXPR_PENDING_PROXIES): New.
- (struct tree_lambda_expr): Add pending_proxies.
- * name-lookup.c (pushdecl_maybe_friend_1): Handle capture shadowing.
- (qualify_lookup): Use is_lambda_ignored_entity.
- * parser.c (cp_parser_lambda_expression): Don't adjust field names.
- Call insert_pending_capture_proxies.
- (cp_parser_lambda_introducer): Use this_identifier.
- (cp_parser_lambda_declarator_opt): Call the object parameter
- of the op() "__closure" instead of "this".
- (cp_parser_lambda_body): Call build_capture_proxy.
- * semantics.c (build_capture_proxy, is_lambda_ignored_entity): New.
- (insert_pending_capture_proxies, insert_capture_proxy): New.
- (is_normal_capture_proxy, is_capture_proxy): New.
- (add_capture): Add __ to field names here, return capture proxy.
- (add_default_capture): Use this_identifier, adjust to expect
- add_capture to return a capture proxy.
- (outer_lambda_capture_p, thisify_lambda_field): Remove.
- (finish_id_expression, lambda_expr_this_capture): Adjust.
- (build_lambda_expr): Initialize LAMBDA_EXPR_PENDING_PROXIES.
- * pt.c (tsubst_copy_and_build): Check that LAMBDA_EXPR_PENDING_PROXIES
- is null.
-
- * name-lookup.c (pushdecl_maybe_friend_1): Do check for shadowing
- of artificial locals.
-
- * parser.c (cp_parser_lambda_expression): Clear
- LAMBDA_EXPR_THIS_CAPTURE after parsing.
- * pt.c (tsubst_copy_and_build): Make sure it isn't set.
-
- * cp-tree.h (struct tree_lambda_expr): Change common to typed.
- Move non-pointers to end of struct.
-
- * pt.c (tsubst_decl): Handle DECL_VALUE_EXPR on reference.
- * decl.c (check_initializer): Handle DECL_VALUE_EXPR_P.
-
- * semantics.c (finish_non_static_data_member): Preserve dereference
- in template.
-
-2011-06-16 Jason Merrill <jason@redhat.com>
-
- PR c++/44160
- * parser.c (cp_parser_lambda_body): Share code between
- simple and complex cases instead of using cp_parser_function_body.
-
- PR c++/45378
- * decl.c (check_initializer): Check narrowing.
-
- PR c++/49229
- * pt.c (tsubst_decl) [FUNCTION_DECL]: Handle substitution failure.
-
- PR c++/49251
- * semantics.c (finish_id_expression): Mark even dependent
- variables as used.
-
- PR c++/49420
- * error.c (dump_template_argument): Don't try to omit default
- template args from an argument pack.
-
-2011-06-15 H.J. Lu <hongjiu.lu@intel.com>
-
- PR c++/49412
- * decl.c (get_dso_handle_node): Mark __dso_handle hidden if
- assembler supports hidden visibility.
-
-2011-06-14 Jason Merrill <jason@redhat.com>
-
- PR c++/49107
- * cp-tree.h (DEFERRED_NOEXCEPT_SPEC_P): Handle overload.
- * method.c (defaulted_late_check): Only maybe_instantiate_noexcept
- if the declaration had an exception-specifier.
- (process_subob_fn): Don't maybe_instantiate_noexcept.
- * pt.c (maybe_instantiate_noexcept): Handle overload.
- * typeck2.c (nothrow_spec_p_uninst): New.
- (merge_exception_specifiers): Add 'fn' parm. Build up overload.
- * typeck.c (merge_types): Adjust.
-
- * pt.c (deduction_tsubst_fntype): Don't save input_location.
- (maybe_instantiate_noexcept): Likewise.
-
-2011-06-14 Joseph Myers <joseph@codesourcery.com>
-
- * Make-lang.in (cp/method.o): Update dependencies.
- * method.c: Include common/common-target.h.
- (use_thunk): Use targetm_common.have_named_sections.
-
-2011-06-14 Steve Ellcey <sje@cup.hp.com>
-
- * decl.c (cxx_init_decl_processing): Use ptr_mode instead of Pmode.
-
-2011-06-14 Jason Merrill <jason@redhat.com>
-
- * error.c (type_to_string): Print typedef-stripped version too.
-
- PR c++/49117
- * call.c (perform_implicit_conversion_flags): Print source type as
- well as expression.
-
- PR c++/49389
- * typeck2.c (build_m_component_ref): Preserve rvalueness.
-
- PR c++/49369
- * class.c (build_base_path): Fix cv-quals in unevaluated context.
-
- PR c++/49290
- * semantics.c (cxx_fold_indirect_ref): Local, more permissive copy
- of fold_indirect_ref_1.
- (cxx_eval_indirect_ref): Use it.
-
-2011-06-11 Jan Hubicka <jh@suse.cz>
-
- * decl2.c (cp_write_global_declarations): Process aliases; look trhough
- same body aliases.
-
-2011-06-10 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/41769
- * decl.c (grokdeclarator): Reject operator names in parameters.
-
-2011-06-10 Jan Hubicka <jh@suse.cz>
-
- * decl2.c (clear_decl_external): New functoin.
- (cp_write_global_declarations): Use it.
-
-2011-06-10 Paolo Carlini <paolo.carlini@oracle.com>
-
- * cp-tree.h (error_operand_p): Remove.
-
-2011-06-09 David Krauss <potswa@mac.com>
-
- PR c++/49118
- * typeck2.c (build_x_arrow): Push fake template context
- to produce diagnostic on acyclic endless operator-> drill-down.
- * call.c (build_new_op): Change Boolean overload status
- value to a pointer to the overload function.
- * cp-tree.h: Likewise.
- * typeck.c: Likewise.
- * parser.c: Likewise.
- * decl2.c: Likewise.
- * pt.c: Likewise.
-
-2011-06-09 Jason Merrill <jason@redhat.com>
-
- * semantics.c (maybe_constant_value): Handle overflowed input.
- (non_const_var_error): Handle non-constant DECL_INITIAL.
-
- * pt.c (build_non_dependent_expr): Use fold_non_dependent_expr_sfinae.
-
- * parser.c (cp_parser_constant_expression): Just return the
- non-constant expression.
-
- * semantics.c (finish_compound_literal): Set TREE_HAS_CONSTRUCTOR.
-
-2011-06-09 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/29003
- * decl.c (grokdeclarator): Reject operator names in typedefs.
-
-2011-06-08 Jason Merrill <jason@redhat.com>
-
- PR c++/49107
- * cp-tree.def (DEFERRED_NOEXCEPT): New.
- * cp-tree.h (struct tree_deferred_noexcept): New.
- (DEFERRED_NOEXCEPT_PATTERN, DEFERRED_NOEXCEPT_ARGS): New.
- (DEFERRED_NOEXCEPT_SPEC_P): New.
- (enum cp_tree_node_structure_enum): Add TS_CP_DEFERRED_NOEXCEPT.
- (union lang_tree_node): Add tree_deferred_noexcept.
- (maybe_instantiate_noexcept): Declare.
- * cp-objcp-common.c (cp_tree_size): Handle DEFERRED_NOEXCEPT.
- * error.c (dump_exception_spec): Likewise.
- * cxx-pretty-print.c (pp_cxx_exception_specification): Likewise.
- * ptree.c (cxx_print_xnode): Likewise.
- * tree.c (cp_tree_equal): Likewise.
- * decl.c (cp_tree_node_structure): Likewise.
- (duplicate_decls): Call maybe_instantiate_noexcept.
- * except.c (build_noexcept_spec): Handle DEFERRED_NOEXCEPT.
- (nothrow_spec_p, type_noexcept_p, type_throw_all_p): Check
- DEFERRED_NOEXCEPT_SPEC_P.
- * typeck2.c (merge_exception_specifiers): Likewise.
- * decl2.c (mark_used): Call maybe_instantiate_noexcept.
- * method.c (process_subob_fn, defaulted_late_check): Likewise.
- * pt.c (tsubst_exception_specification): Add defer_ok parm.
- Build DEFERRED_NOEXCEPT.
- (maybe_instantiate_noexcept): New.
- (tsubst, regenerate_decl_from_template, instantiate_decl): Adjust.
- * search.c (check_final_overrider): Call maybe_instantiate_noexcept.
-
- * semantics.c (potential_constant_expression_1): Handle destructor
- call.
-
-2011-06-08 Jakub Jelinek <jakub@redhat.com>
-
- * cp-tree.h (struct tinst_level): Add chain_next GTY
- markup.
-
-2011-06-08 Jason Merrill <jason@redhat.com>
-
- PR c++/49322
- * pt.c (deduction_tsubst_fntype): Don't free the tinst entry
- if a pending_template entry is pointing at it.
-
-2011-06-07 Jason Merrill <jason@redhat.com>
-
- PR c++/48969
- PR c++/44175
- * error.c (subst_to_string): New.
- (cp_printer): Use it for 'S'.
- (print_instantiation_partial_context_line): Handle subst context.
- * pt.c (push_tinst_level): Handle subst context.
- (deduction_tsubst_fntype): Don't track specific substitutions.
- Use push_tinst_level.
-
- * pt.c (deduction_tsubst_fntype): Use push_deduction_access_scope.
- (fn_type_unification): Don't call push_deduction_access_scope here.
-
-2011-06-06 Jason Merrill <jason@redhat.com>
-
- PR c++/48780
- * typeck.c (perform_integral_promotions): Don't promote scoped enums.
- * call.c (convert_arg_to_ellipsis): Promote them here in old ABI.
-
-2011-06-06 Nicola Pero <nicola.pero@meta-innovation.com>,
-
- PR obj-c++/48275
- * parser.c (cp_parser_objc_at_property_declaration): Allow setter
- and getter names to use all the allowed method names.
-
-2011-06-06 Jason Merrill <jason@redhat.com>
-
- PR c++/49298
- * semantics.c (potential_constant_expression_1): Handle FIELD_DECL.
-
- PR objc++/49221
- * decl.c (cp_finish_decl): Check DECL_FUNCTION_SCOPE_P rather than
- at_function_scope_p.
-
- PR c++/49134
- * tree.c (build_target_expr): Deal with ARM ABI tweaks.
-
-2011-06-04 Jonathan Wakely <jwakely.gcc@gmail.com>
-
- * init.c (build_delete): Warn when deleting type with non-virtual
- destructor.
-
-2011-06-03 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/49276
- * mangle.c (write_nested_name): Use CP_DECL_CONTEXT instead of
- DECL_CONTEXT.
-
-2011-06-01 Jason Merrill <jason@redhat.com>
-
- * pt.c (build_non_dependent_expr): Remove special handling of
- REFERENCE_REF_P.
-
- PR c++/44175
- * pt.c (template_args_equal): Handle one arg being NULL_TREE.
- (deduction_tsubst_fntype): Handle excessive non-infinite recursion.
-
- PR c++/49253
- * typeck2.c (build_x_arrow): Don't use build_min_nt.
-
-2010-05-31 Fabien Chêne <fabien@gcc.gnu.org>
-
- PR c++/48010
- * name-lookup.c (supplement_binding_1): If the old binding was a
- type name, also check that the DECL actually refers to the same
- type or is not a type.
-
-2011-05-31 Jason Merrill <jason@redhat.com>
-
- PR c++/44870
- * tree.c (lvalue_kind): Recurse on NON_DEPENDENT_EXPR. Handle
- ARROW_EXPR, TYPEID_EXPR, and arbitrary class-valued expressions.
- (build_min_non_dep): Preserve reference refs.
- (build_min_non_dep_call_vec): Likewise
-
-2011-05-30 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/49223
- * semantics.c (finish_omp_clauses): Call require_complete_type
- even for copyin/copyprivate clauses. Only call
- cxx_omp_create_clause_info if inner_type is COMPLETE_TYPE_P.
-
-2011-05-28 Jason Merrill <jason@redhat.com>
-
- PR c++/46124
- * parser.c (cp_parser_lambda_expression): Improve error recovery.
- (cp_parser_lambda_declarator_opt): Likewise. Return bool.
-
-2011-05-27 Jason Merrill <jason@redhat.com>
-
- PR c++/47277
- * parser.c (cp_parser_pseudo_destructor_name): Commit to parse
- after we see the ~.
-
- * mangle.c (mangle_decl_string): Make sure we don't try to mangle
- templates.
-
- PR c++/47049
- * semantics.c (maybe_add_lambda_conv_op): Fix COMDAT sharing.
- * decl.c (start_preparsed_function): Don't call comdat_linkage for
- a template.
-
- PR c++/47132
- * mangle.c (write_expression): Handle MODOP_EXPR.
-
- PR c++/47277
- * parser.c (cp_parser_unqualified_id): Don't check
- constructor_name_p for enums.
-
- PR c++/47687
- * pt.c (dependent_type_p_r): Avoid infinite recursion.
-
- PR c++/48284
- * error.c (dump_expr) [COMPONENT_REF]: Use pp_cxx_dot
- with INDIRECT_REF of REFERENCE_TYPE.
-
- PR c++/49181
- * pt.c (get_mostly_instantiated_function_type): Use push_access_scope.
-
-2011-05-27 Nathan Froyd <froydnj@codesourcery.com>
-
- * cp-tree.h (building_stmt_tree): Delete.
- * decl.c (save_function_data): Tweak initializer for x_cur_stmt_list.
- (build_aggr_init_full_exprs): Call building_stmt_list_p
- instead of building_stmt_tree.
- (initialize_local_var): Likewise.
- (finish_function): Likewise.
- * decl2.c (finish_anon_union): Likewise.
- * init.c (begin_init_stmts): Likewise.
- (finish_init_stmts): Likewise.
- (expand_aggr_init_1): Likewise.
- * name-lookup.c (do_local_using_decl): Likewise.
- (do_namespace_alias): Likewise.
- (do_using_directive): Likewise.
- (cp_emit_debug_info_for_using): Likewise.
- * semantics.c (add_stmt): Assert that stmt_list_stack is non-empty.
-
-2011-05-27 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/42056
- * typeck2.c (build_functional_cast): Complain early for invalid uses
- of 'auto' and set type to error_mark_node.
-
-2011-05-26 Jason Merrill <jason@redhat.com>
-
- PR c++/47721
- * parser.c (cp_parser_member_declaration): Allow friend T.
- * friend.c (make_friend_class): Ignore non-classes.
- * pt.c (instantiate_class_template_1): Handle TEMPLATE_TYPE_PARM.
-
- DR 1004
- * pt.c (convert_template_argument): Don't complain about using
- injected-class-name as template template argument.
-
- PR c++/47956
- * decl.c (check_static_variable_definition): Now static.
- (cp_finish_decl): Call it here.
- (grokdeclarator): Not here.
- * pt.c (instantiate_class_template_1): Or here.
- * cp-tree.h: Don't declare it.
-
-2011-05-26 Janis Johnson <janis187@us.ibm.com>
- Nathan Froyd <froydnj@codesourcery.com>
-
- PR c++/2288
- PR c++/18770
- * name-lookup.h (enum scope_kind): Add sk_cond.
- * name-lookup.c (pushdecl_maybe_friend): Get scope of shadowed local.
- Detect and report error for redeclaration from for-init or if
- or switch condition.
- (begin_scope): Handle sk_cond.
- * semantics.c (begin_if_stmt): Use sk_cond.
- (begin switch_stmt): Ditto.
-
-2011-05-26 Jason Merrill <jason@redhat.com>
-
- PR c++/48211
- * name-lookup.h (cp_class_binding): Make base a pointer.
- * name-lookup.c (new_class_binding): Adjust.
- (poplevel_class): Adjust.
-
- PR c++/48424
- * decl.c (grokparms): Function parameter packs don't need to
- go at the end.
- * pt.c (type_unification_real): But they aren't deduced otherwise.
-
-2011-05-25 Jason Merrill <jason@redhat.com>
-
- PR c++/48536
- * decl.c (build_enumerator): If incremented enumerator won't fit in
- previous integral type, find one it will fit in.
-
- PR c++/48599
- * decl.c (create_array_type_for_decl): Complain about array of auto.
-
- PR c++/44994
- PR c++/49156
- * error.c (dump_template_bindings): Set processing_template_decl
- for a partial instantiation.
-
- PR c++/45401
- * decl.c (grokdeclarator): Don't change type when adding rvalue ref
- to another reference type.
-
- PR c++/44311
- * decl.c (case_conversion): New.
- (finish_case_label): Use it.
-
- * ptree.c (cxx_print_xnode): Handle ARGUMENT_PACK_SELECT.
-
- PR c++/45698
- * pt.c (dependent_template_arg_p): See through ARGUMENT_PACK_SELECT.
-
- PR c++/46005
- * decl.c (grokdeclarator): Complain about auto typedef.
-
- PR c++/46245
- * decl.c (grokdeclarator): Complain later for auto parameter.
- * pt.c (splice_late_return_type): Handle use in a template
- type-parameter.
-
- PR c++/46696
- * typeck.c (cp_build_modify_expr): Check DECL_DEFAULTED_FN.
-
- PR c++/47184
- * parser.c (cp_parser_parameter_declaration): Recognize
- list-initialization.
- (cp_parser_direct_declarator): Check for the closing
- paren before parsing definitely.
-
- PR c++/48935
- * parser.c (cp_parser_constructor_declarator_p): Don't check
- constructor_name_p for enums.
- (cp_parser_diagnose_invalid_type_name): Correct error message.
-
- PR c++/45418
- * init.c (perform_member_init): Handle list-initialization
- of array of non-trivial class type.
-
- PR c++/45080
- * pt.c (instantiate_class_template_1): Call maybe_add_lambda_conv_op.
- * semantics.c (lambda_function): Check COMPLETE_OR_OPEN_TYPE_P.
-
- PR c++/48292
- * pt.c (tsubst_decl) [PARM_DECL]: Handle partial instantiation of
- function parameter pack.
- (tsubst_pack_expansion): Likewise.
-
- * cp-objcp-common.c (cp_common_init_ts): TYPE_ARGUMENT_PACK has
- TS_COMMON.
-
-2011-05-25 Jakub Jelinek <jakub@redhat.com>
-
- * cp-objcp-common.c (cp_common_init_ts): Mark CTOR_INITIALIZER
- as TS_TYPED.
-
- PR c++/49136
- * semantics.c (cxx_eval_bit_field_ref): Handle the
- case when BIT_FIELD_REF doesn't cover only a single field.
-
-2011-05-24 Jason Merrill <jason@redhat.com>
-
- PR c++/49042
- * pt.c (get_mostly_instantiated_function_type): Use
- push_deferring_access_checks rather than set flag_access_control.
-
-2011-05-24 Nicola Pero <nicola.pero@meta-innovation.com>,
-
- * parser.c (cp_parser_objc_class_ivars): Deal gracefully with a
- syntax error in declaring an ObjC instance variable.
-
-2011-05-24 Jason Merrill <jason@redhat.com>
-
- PR c++/48884
- * class.c (pushclass): Accept NULL argument.
- (popclass): Deal with popping null class.
- * pt.c (push_access_scope, pop_access_scope): Use them rather than
- push_to_top_level/pop_from_top_level.
- (push_deduction_access_scope, pop_defarg_context): New.
- (fn_type_unification): Use them.
- * name-lookup.c (lookup_name_real_1): Check current_class_type.
-
-2011-05-24 Paolo Carlini <paolo.carlini@oracle.com>
-
- * decl.c (grokdeclarator): Use current_class_name.
-
-2011-05-24 Joseph Myers <joseph@codesourcery.com>
-
- * Make-lang.in (GXX_OBJS): Remove prefix.o.
- (g++$(exeext)): Use libcommon-target.a.
- (CXX_C_OBJS): Remove prefix.o.
-
-2011-05-23 Jason Merrill <jason@redhat.com>
-
- * pt.c (tsubst_copy_and_build): Use current_class_name.
-
- PR c++/49102
- * call.c (convert_arg_to_ellipsis): Call force_rvalue.
-
- PR c++/49105
- * typeck.c (cp_build_c_cast): Don't strip cv-quals when
- converting to reference.
- (build_static_cast_1): Update for glvalues.
-
- PR c++/49105
- * typeck.c (build_const_cast_1): Handle rvalue references.
-
- PR c++/47263
- * decl.c (use_eh_spec_block): Do use an EH spec block for a
- lambda op().
-
- PR c++/49058
- * call.c (splice_viable): Be strict in templates.
-
- PR c++/47336
- * error.c (dump_template_bindings): Suppress access control.
-
- PR c++/47544
- * pt.c (instantiate_decl): Handle =default.
-
- PR c++/48617
- * pt.c (invalid_nontype_parm_type_p): Allow DECLTYPE_TYPE.
-
-2011-05-23 Nathan Froyd <froydnj@codesourcery.com>
-
- * call.c (build_over_call): Tweak call to check_function_arguments.
- * typeck.c (cp_build_function_call_vec): Likewise.
-
-2011-05-23 Jonathan Wakely <jwakely.gcc@gmail.com>
-
- PR c++/18016
- * init.c (perform_member_init): Check for self-initialization.
-
-2011-05-22 Jason Merrill <jason@redhat.com>
-
- PR c++/48647
- * typeck.c (composite_pointer_type_r): Return error_mark_node
- on error in SFINAE context.
-
-2011-05-20 Jason Merrill <jason@redhat.com>
-
- PR c++/48945
- * decl.c (grokdeclarator): Don't add set const function-cv-qual
- for constexpr fns to memfn_quals, just add it to the type.
- (revert_static_member_fn): Don't complain about quals.
- (check_static_quals): New.
- (grokfndecl): Call it.
- (start_preparsed_function): Don't call revert_static_member_fn.
-
- PR c++/48945
- * decl.c (revert_static_member_fn): Ignore const on constexpr fn.
-
- PR c++/48780
- * cvt.c (type_promotes_to): Don't promote scoped enums.
-
- PR c++/49066
- * decl.c (duplicate_decls): Preserve DECL_DELETED_FN.
-
- PR c++/48873
- * tree.c (stabilize_expr): Fix typo.
-
- DR 1073
- PR c++/49082
- * typeck.c (comp_except_specs): noexcept(false) is not compatible
- with throw(type-list).
- * typeck2.c (merge_exception_specifiers): noexcept(false)
- beats any more limited specification.
-
- PR c++/24163
- PR c++/29131
- * pt.c (tsubst_copy_and_build) [CALL_EXPR]: Avoid repeating
- unqualified lookup.
- * semantics.c (perform_koenig_lookup): Add complain parm.
- * cp-tree.h: Adjust.
- * parser.c (cp_parser_postfix_expression): Adjust.
- (cp_parser_perform_range_for_lookup): Adjust.
-
-2011-05-20 Jason Merrill <jason@redhat.com>
-
- * semantics.c (finish_call_expr): SET_EXPR_LOCATION.
-
-2011-05-20 Joseph Myers <joseph@codesourcery.com>
-
- * Make-lang.in (GXX_OBJS): Remove intl.o and version.o.
-
-2011-05-19 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/49043
- * decl.c (check_omp_return): Stop searching on sk_function_parms.
-
- PR c++/48869
- * method.c (get_dtor, get_copy_ctor): Add COMPLAIN argument,
- pass it down to locate_fn_flags.
- * cp-tree.h (get_dtor, get_copy_ctor): Adjust prototypes.
- * semantics.c (cxx_omp_create_clause_info): Adjust callers.
- * cp-gimplify.c: Include splay-tree.h.
- (splay_tree_compare_decl_uid, omp_var_to_track,
- omp_cxx_notice_variable): New functions.
- (struct cp_genericize_omp_taskreg): New type.
- (struct cp_genericize_data): Add omp_ctx field.
- (cp_genericize_r): Attempt to determine implicitly determined
- firstprivate class type variables.
- (cp_genericize): Clear omp_ctx.
- * Make-lang.in (cp/cp-gimplify.o): Depend on $(SPLAY_TREE_H).
-
-2011-05-18 Jason Merrill <jason@redhat.com>
-
- PR c++/48948
- PR c++/49015
- * class.c (finalize_literal_type_property): Do check
- for constexpr member functions of non-literal class.
- (finish_struct): Don't call check_deferred_constexpr_decls.
- * cp-tree.h: Don't declare it.
- (DECL_DEFERRED_CONSTEXPR_CHECK): Remove.
- * decl.c (grok_special_member_properties): Don't check it
- (grokfnedcl): Don't call validate_constexpr_fundecl.
- (start_preparsed_function): Do call it.
- * pt.c (tsubst_decl): Don't call it.
- (instantiate_class_template_1): Don't call
- check_deferred_constexpr_decls.
- * semantics.c (literal_type_p): Check for any incompleteness.
- (ensure_literal_type_for_constexpr_object): Likewise.
- (is_valid_constexpr_fn): Revert deferral changes.
- (validate_constexpr_fundecl): Likewise.
- (register_constexpr_fundef): Likewise.
- (check_deferred_constexpr_decls): Remove.
-
-2011-05-16 Jason Merrill <jason@redhat.com>
-
- PR c++/48969
- * pt.c (deduction_tsubst_fntype): Use a VEC initially.
-
-2011-05-15 Paolo Carlini <paolo.carlini@oracle.com>
-
- * cxx-pretty-print.c: Update comment.
- * semantics.c (trait_expr_value, finish_trait_expr):
- Reorder the cases.
- * parser.c (cp_parser_primary_expression): Likewise.
-
-2011-05-15 Jonathan Wakely <jwakely.gcc@gmail.com>
-
- PR c++/48994
- * parser.c (cp_parser_perform_range_for_lookup): Call complete_type.
-
-2011-05-13 Ville Voutilainen <ville.voutilainen@gmail.com>
-
- Implement final on class.
- * class.c (check_bases): Diagnose derivation from a final class.
- * cp-tree.h (lang_type_class): Add is_final and adjust dummy.
- (CLASSTYPE_FINAL): New.
- * parser.c (cp_parser_class_head): Parse class-virt-specifier, set
- CLASSTYPE_FINAL.
- * pt.c (instantiate_class_template_1): Copy CLASSTYPE_FINAL.
-
-2011-05-13 Jason Merrill <jason@redhat.com>
-
- PR c++/48969
- * pt.c (deduction_tsubst_fntype): New.
- (fn_type_unification): Use it.
- (init_template_processing): Initialize hash table.
- (print_template_statistics): Print hash table stats.
-
- * call.c (build_op_call): Use timevar_cond_start/stop.
- (build_user_type_conversion): Likewise.
-
-2011-05-12 Jason Merrill <jason@redhat.com>
-
- * cp-tree.h (DECL_DEFERRED_CONSTEXPR_CHECK): New.
- * semantics.c (validate_constexpr_fundecl): Set it.
- (check_deferred_constexpr_decls): Clear it.
- (register_constexpr_fundef): Make sure it isn't set.
- * decl.c (grok_special_member_properties): Check it.
-
-2011-05-11 Jason Merrill <jason@redhat.com>
-
- PR c++/48948
- * semantics.c (validate_constexpr_fundecl): Defer checking if
- an argument type is being defined.
- (is_valid_constexpr_fn): Add defer_ok parm.
- (cxx_eval_call_expression): Adjust.
- (check_deferred_constexpr_decls): New.
- (literal_type_p): Make sure type isn't being defined.
- (ensure_literal_type_for_constexpr_object): Handle type being defined.
- * cp-tree.h: Declare check_deferred_constexpr_decls.
- * decl.c (grokfndecl): Call validate_constexpr_fundecl here.
- (start_preparsed_function, cp_finish_decl): Not here.
- * class.c (finalize_literal_type_property): Don't call
- validate_constexpr_fundecl.
- (finish_struct): Call check_deferred_constexpr_decls.
- * pt.c (tsubst_decl): Call validate_constexpr_fundecl.
- (instantiate_class_template): Call check_deferred_constexpr_decls.
-
- * semantics.c (validate_constexpr_fundecl): Check DECL_TEMPLATE_INFO
- rather than DECL_TEMPLATE_INSTANTIATION.
- (cxx_eval_call_expression): Likewise.
-
- * semantics.c (register_constexpr_fundef): Add to hash table here.
- (validate_constexpr_fundecl): Not here.
-
- * decl.c (grokdeclarator): Only set DECL_DECLARED_CONSTEXPR_P once.
-
- * pt.c (build_non_dependent_expr): Don't check null_ptr_cst_p,
- do call maybe_constant_value in C++0x mode.
- * semantics.c (cxx_eval_constant_expression): Handle TEMPLATE_DECL.
-
- PR c++/48745
- * pt.c (value_dependent_expr_p): Handle CONSTRUCTOR.
-
-2011-05-11 Nathan Froyd <froydnj@codesourcery.com>
-
- * cp-tree.h (TYPENAME_TYPE_FULLNAME, TYPEOF_TYPE_EXPR): Use
- TYPE_VALUES_RAW.
- (UNDERLYING_TYPE_TYPE, DECLTYPE_TYPE_EXPR): Likewise.
- (DECLTYPE_TYPE_ID_EXPR_OR_MEMBER_ACCESS_P): Likewise.
- (TEMPLATE_TYPE_PARM_INDEX): Likewise.
-
-2011-05-10 Jason Merrill <jason@redhat.com>
-
- PR c++/48930
- * class.c (type_build_ctor_call): New.
- * cp-tree.h: Declare it.
- * decl.c (check_initializer): Use it instead of
- TYPE_NEEDS_CONSTRUCTING.
- * init.c (build_value_init, build_value_init_noctor): Likewise.
- (perform_member_init, expand_aggr_init_1, build_new_1): Likewise.
- (build_vec_init): Likewise.
- * typeck2.c (process_init_constructor_array): Likewise.
- (process_init_constructor_record): Likewise.
-
- PR c++/48736
- * pt.c (tsubst_copy_and_build): Handle substitution of a pack
- expansion producing another expansion.
-
-2011-05-10 Ville Voutilainen <ville.voutilainen@gmail.com>
-
- Fixes for override/final.
- * class.c (check_for_override): Diagnose final on a nonvirtual
- member function, diagnose override for a virtual with no matching
- override. Don't fiddle around with DECL_VINDEX.
-
-2011-05-10 Nathan Froyd <froydnj@codesourcery.com>
-
- * cp-tree.def (EXPR_PACK_EXPANSION): Add an operand.
- * cp-objcp-common.c (cp_common_init_ts): Mark it as TS_TYPED.
- * cp-tree.h (PACK_EXPANSION_PARAMETER_PACKS): Use the new
- operand of EXPR_PACK_EXPANSION.
- (cp_tree_operand_length): Declare.
- * tree.c (cp_tree_operand_length): Define.
- (cp_tree_equal): Call it.
- * pt.c (value_dependent_expr_P): Likewise.
- * mangle.c (write_expression): Likewise.
-
-2011-05-09 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/48737
- PR c++/48744
- * decl.c (reshape_init): Take a complain parameter and do
- not call error if tf_error is not set.
- (check_initializer, reshape_init_r, reshape_init_array,
- reshape_init_array_1, reshape_init_vector, reshape_init_class):
- Adjust.
- * typeck2.c (digest_init_r): Take a complain parameter and
- pass it to convert_for_initialization.
- (digest_init, digest_init_flags, process_init_constructor_array,
- process_init_constructor_record, process_init_constructor_union,
- process_init_constructor, digest_init_r): Adjust.
- * init.c (expand_default_init, build_new_1): Likewise.
- * typeck.c (cp_build_modify_expr): Likewise.
- * decl2.c (grokfield): Likewise.
- * call.c (convert_like_real, convert_default_arg): Likewise.
- * semantics.c (finish_compound_literal): Pass complain to
- reshape_init and digest_init.
- * cp-tree.h: Adjust declarations.
-
-2011-05-07 Fabien Chêne <fabien@gcc.gnu.org>
-
- PR c++/48859
- * init.c (diagnose_uninitialized_cst_or_ref_member_1): stop the
- recursion if there is user defined constructor.
-
-2011-05-09 Jason Merrill <jason@redhat.com>
-
- PR c++/34772
- * decl.c (initialize_local_var): Use DECL_INITIAL for simple
- initialization.
-
-2011-05-08 Ville Voutilainen <ville.voutilainen@gmail.com>
-
- Implement final/override for member functions.
- * class.c (check_for_override): Check for DECL_OVERRIDE_P.
- * cp-tree.h (DECL_OVERRIDE_P, DECL_FINAL_P): New.
- (cp_virt_specifiers, enum virt_specifier): New.
- * decl.c (set_virt_specifiers): New.
- (grokdeclarator): Use them. Diagnose virt-specifiers on non-fields.
- * parser.c (make_call_declarator): add virt-specifiers parameter.
- (cp_parser_lambda_declarator_opt): Adjust.
- (cp_parser_direct_declarator): Likewise.
- (cp_parser_virt_specifier_seq_opt): New.
- * search.c (check_final_overrider): Diagnose attempts to override
- a final member function.
-
-2011-05-09 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/48574
- * class.c (fixed_type_or_null): Use type_dependent_p_push to test
- if the instance has a dependent initializer.
-
-2011-05-08 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/48816
- * cxx-pretty-print.c (pp_cxx_template_declaration): Remove
- effectively unused variable.
-
-2011-05-07 Eric Botcazou <ebotcazou@adacore.com>
-
- * name-lookup.h (global_bindings_p): Adjust prototype.
- * name-lookup.c (global_bindings_p): Return bool.
-
-2011-05-06 Jason Merrill <jason@redhat.com>
-
- * decl.c (stabilize_save_expr_r): Set *walk_subtrees as
- appropriate.
-
- PR c++/48909
- * semantics.c (cxx_eval_conditional_expression): Check
- integer_zerop instead.
- (potential_constant_expression_1): Likewise.
-
- PR c++/48911
- * semantics.c (cxx_eval_array_reference): Handle implicit
- initializers.
-
-2011-05-06 Nathan Froyd <froydnj@codesourcery.com>
-
- * cp-tree.h (type_of_this_parm, class_of_this_parm): New functions.
- * call.c (standard_conversion): Call class_of_this_parm.
- * cxx-pretty-print.c (pp_cxx_implicit_parameter_type): Likewise.
- (pp_cxx_direct_abstract_declarator): Likewise.
- * decl2.c (change_return_type): Likewise.
- (cp_reconstruct_complex_type): Likewise.
- * error.c (dump_type_suffix, dump_function_decl): Likewise.
- * mangle.c (write_function_type): Likewise.
- * pt.c (unify): Likewise.
- * typeck.c (merge_types, type_memfn_quals): Likewise.
- * decl.c (build_this_parm): Call type_of_this_parm.
-
-2011-05-06 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/48838
- * cp-tree.h (non_static_member_function_p): Declare new function.
- * tree.c (non_static_member_function_p): Define it.
- * semantics.c (finish_call_expr): Use it.
-
-2011-05-05 Nathan Froyd <froydnj@codesourcery.com>
-
- * decl.c (finish_case_label): Omit the loc argument to
- build_case_label.
-
-2011-05-05 Jason Merrill <jason@redhat.com>
-
- * cp-tree.h (REFERENCE_REF_P): Just check the type.
- * cvt.c (convert_from_reference): Adjust.
- * pt.c (build_non_dependent_expr): Adjust.
- * semantics.c (finish_offsetof): Adjust.
- * tree.c (lvalue_kind): Use it.
-
- PR c++/48873
- * tree.c (stabilize_expr): Don't make gratuitous copies of classes.
-
-2011-05-05 Eric Botcazou <ebotcazou@adacore.com>
-
- * decl.c (start_preparsed_function): Do not set
- dont_save_pending_sizes_p.
-
-2011-05-05 Joseph Myers <joseph@codesourcery.com>
-
- * parser.c (cp_parser_objc_method_definition_list): Update call to
- objc_start_method_definition.
-
-2011-05-04 Jason Merrill <jason@redhat.com>
-
- PR c++/48749
- * class.c (resolves_to_fixed_type_p): Don't look closely
- in templates.
-
-2011-05-03 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/28501
- * call.c (add_builtin_candidate): Handle REALPART_EXPR and
- IMAGPART_EXPR.
-
-2011-05-02 Lawrence Crowl <crowl@google.com>
-
- * decl.c: (push_local_name): Change TV_NAME_LOOKUP to start/stop.
- (poplevel): Refactor POP_TIMEVAR_AND_RETURN to plain code.
- Change TV_NAME_LOOKUP to start/stop.
- (define_label): Refactor timevar calls out to a wrapper function.
- Change TV_NAME_LOOKUP to start/stop.
- (xref_tag): Likewise.
- (lookup_label): Refactor timevar calls out to a wrapper function.
- Change TV_NAME_LOOKUP to start_cond/stop_cond.
-
- * pt.c: (instantiate_class_template): Add a wrapper to push/pop new
- TV_TEMPLATE_INST.
- (instantiate_template): Add a wrapper to push/pop new TV_TEMPLATE_INST.
- (lookup_template_class): Refactor timevar calls out to a wrapper
- function. Change use of TV_NAME_LOOKUP to TV_TEMPLATE_INST.
- (instantiate_decl): Change TV_PARSE to TV_TEMPLATE_INST.
-
- * name-lookup.c: (store_bindings): Change TV_NAME_LOOKUP to start/stop.
- (poplevel_class): Change TV_NAME_LOOKUP to start_cond/stop_cond.
- (push_namespace): Likewise.
- (pop_nested_namespace): Likewise.
- (pushdecl_namespace_level): Likewise.
- (store_class_bindings): Likewise.
- (push_to_top_level): Likewise.
- (identifier_type_value): Refactor timevar calls out to a wrapper
- function. Change TV_NAME_LOOKUP to start/stop.
- (find_binding): Likewise.
- (push_using_decl): Likewise.
- (lookup_arg_dependent): Likewise.
- (push_using_directive): Likewise.
- (qualified_lookup_using_namespace): Refactor POP_TIMEVAR_AND_RETURN
- to plain code. Change TV_NAME_LOOKUP to start/stop.
- (lookup_type_current_level): Likewise. Refactor inner return to
- break.
- (pushdecl_class_level): Refactor POP_TIMEVAR_AND_RETURN to plain
- code. Change TV_NAME_LOOKUP to start_cond/stop_cond.
- (pushdecl_top_level_1): Likewise.
- (lookup_using_namespace): Likewise.
- (pushdecl_with_scope): Refactor timevar calls out to a wrapper
- function. Change TV_NAME_LOOKUP to start_cond/stop_cond.
- (push_overloaded_decl): Likewise.
- (push_class_level_binding): Likewise.
- (namespace_binding): Likewise.
- (set_namespace_binding): Likewise.
- (supplement_binding): Likewise.
- (unqualified_namespace_lookup): Likewise.
- (lookup_name_real): Likewise.
- (lookup_type_scope): Likewise.
- (namespace_ancestor): Likewise.
- (lookup_name_innermost_nonclass_level): Likewise.
- (pushtag): Likewise.
- (pop_from_top_level): Likewise.
- (pushdecl_maybe_friend): Refactor timevar calls out to a wrapper
- function. Change TV_NAME_LOOKUP to start_cond/stop_cond. Wrap long
- lines.
- (add_using_namespace): Refactor timevar calls out to a wrapper
- function. Change TV_NAME_LOOKUP to start_cond/stop_cond. Bypass
- wrapper on call to self.
-
- * decl2.c: (cp_write_global_declarations): Add start/stop of
- new TV_PHASE_DEFERRED, TV_PHASE_CGRAPH, TV_PHASE_CHECK_DBGINFO.
- Remove push/pop calls to TV_VARCONST.
-
- * parser.c: Add include of "timevar.h".
- (cp_parser_explicit_instantiation): Add push/pop calls to
- TV_TEMPLATE_INST.
- (cp_parser_enum_specifier): Add push/pop calls to new TV_PARSE_ENUM.
- (cp_parser_class_specifier): Add wrapper to add push/pop calls to
- TV_PARSE_STRUCT.
- (cp_parser_function_definition_from_specifiers_and_declarator): Add
- push/pop calls to new TV_PARSE_FUNC or TV_PARSE_INLINE.
- (cp_parser_late_parsing_for_member): Add push/pop calls to
- new TV_PARSE_INMETH.
-
- * call.c: Add include of "timevar.h".
- (convert_class_to_reference): Wrap and add push/pop calls to
- TV_OVERLOAD.
- (build_op_call): Likewise.
- (build_conditional_expr): Likewise.
- (build_new_op): Likewise.
- (build_new_method_call): Likewise.
- (build_user_type_conversion): Reorganize to single return and add
- push/pop calls to TV_OVERLOAD.
- (perform_overload_resolution): Likewise.
-
- * Make-lang.in: Add dependence of call.o and parser.o on $(TIMEVAR_H).
-
-2011-05-02 Jason Merrill <jason@redhat.com>
-
- * tree.c (build_vec_init_expr): Take complain parm.
- (build_vec_init_elt): Likewise. Free arg vector.
- (diagnose_non_constexpr_vec_init, build_array_copy): Adjust.
- * cp-tree.h (VEC_INIT_EXPR_SLOT): Use VEC_INIT_EXPR_CHECK.
- (VEC_INIT_EXPR_INIT): Likewise.
- Adjust build_vec_init_expr declaration.
- * init.c (perform_member_init): Adjust.
-
- Revert:
- PR c++/40975
- * cp-tree.def (VEC_INIT_EXPR): Add third operand.
- * cp-tree.h (VEC_INIT_EXPR_NELTS): New.
- * cp-gimplify.c (cp_gimplify_expr) [VEC_INIT_EXPR]: Handle it.
- * tree.c (build_vec_init_expr): Handle getting pointer/nelts.
- (build_vec_init_elt): Don't expect an array type.
- (build_array_copy): Adjust.
- * init.c (perform_member_init): Adjust.
- (build_new_1): Use build_vec_init_expr.
-
- PR c++/48834
- * tree.c (build_vec_init_expr): Set TREE_SIDE_EFFECTS.
- Protect an explicit target.
-
- PR c++/48446
- * decl.c (stabilize_save_expr_r, stabilize_vla_size): New.
- (compute_array_index_type): Revert earlier 48446 changes.
- (grokdeclarator): Use stabilize_vla_size.
-
-2011-05-02 Dmitry Gorbachev <d.g.gorbachev@gmail.com>
- Eric Botcazou <ebotcazou@adacore.com>
-
- * parser.c (cp_parser_init_declarator): Set pushed_scope to NULL_TREE
- instead of inappropriate zero values.
-
-2011-05-02 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/47969
- * decl.c (compute_array_index_type): Check build_expr_type_conversion
- return value for NULL_TREE.
-
-2011-04-29 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/48606
- * init.c (perform_member_init): Check build_value_init return
- value for error_mark_node.
-
-2011-04-29 Diego Novillo <dnovillo@google.com>
- Le-Chun Wu <lcwu@google.com>
-
- * call.c (conversion_null_warnings): Also handle assignments
- when warning about NULL conversions.
-
-2011-04-29 Le-Chun Wu <lcwu@google.com>
-
- * cp-tree.h (LOOKUP_EXPLICIT_TMPL_ARGS): Define.
- * call.c (build_new_function_call): Set it for TEMPLATE_ID_EXPRs.
- (build_over_call): Use it to determine whether to emit a NULL
- warning for template function instantiations.
- (build_new_method_call): Set LOOKUP_EXPLICIT_TMPL_ARGS if
- EXPLICIT_TARGS is set.
-
-2011-04-29 Nicola Pero <nicola.pero@meta-innovation.com>,
- Mike Stump <mikestump@comcast.net>
-
- * Make-lang.in ($(srcdir)/cp/cfns.h): Enable the dependency only
- in maintainer mode. Use the --output-file option of gperf instead
- of > to prevent creating an empty cp/cfns.h when gperf is not
- available.
-
-2011-04-28 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/48798
- * semantics.c (finish_base_specifier): cv-qualified base class
- is fine, per DR 484.
-
-2011-04-28 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/48656
- * semantics.c (finish_call_expr): Don't forget BASELINK nodes when
- considering call expressions involving a member function.
-
-2011-04-28 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/48530
- * tree.c (build_cplus_new): Check build_target_expr return
- value for error_mark_node.
-
-2011-04-28 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/48771
- * semantics.c (literal_type_p): Reference types are literal types,
- per the FDIS.
- (valid_type_in_constexpr_fundecl_p): Remove.
- (is_valid_constexpr_fn): Adjust.
-
-2011-04-27 Jason Merrill <jason@redhat.com>
-
- PR libstdc++/48760
- Implement list-initialization of _Complex.
- * decl.c (reshape_init_r): Allow {real,imag} for _Complex.
- (check_initializer): Likewise.
- * call.c (build_complex_conv): New.
- (implicit_conversion): Call it.
- (convert_like_real): Handle it.
- * typeck2.c (check_narrowing): Handle it.
-
- * init.c (build_vec_delete_1): Look for sfk_deleting_destructor to
- decide whether to delete.
- (build_vec_init): Pass sfk_complete_destructor.
-
- PR c++/40975
- * cp-tree.def (VEC_INIT_EXPR): Add third operand.
- * cp-tree.h (VEC_INIT_EXPR_NELTS): New.
- * cp-gimplify.c (cp_gimplify_expr) [VEC_INIT_EXPR]: Handle it.
- * tree.c (build_vec_init_expr): Handle getting pointer/nelts.
- (build_vec_init_elt): Don't expect an array type.
- (build_array_copy): Adjust.
- * init.c (perform_member_init): Adjust.
- (build_new_1): Use build_vec_init_expr.
-
- * class.c (resolve_address_of_overloaded_function): Don't
- change OVERLOAD to TREE_LIST.
- * pt.c (print_candidates_1): Remove nonsensical assert.
-
- PR c++/48046
- * parser.c (cp_parser_diagnose_invalid_type_name): Commit
- to tentative parse sooner.
-
-2011-04-26 Jason Merrill <jason@redhat.com>
-
- PR c++/42687
- * parser.c (cp_parser_primary_expression): Set *idk to
- CP_ID_KIND_NONE for a parenthesized identifier.
-
- * ptree.c (cxx_print_type) [TYPENAME_TYPE]: Dump fullname.
- (cxx_print_identifier): Correct indentation.
-
- PR c++/48530
- * decl.c (cxx_maybe_build_cleanup): Add complain parm.
- * tree.c (force_target_expr): Add complain parm.
- (build_target_expr_with_type): Likewise.
- (get_target_expr_sfinae): Split out.
- (build_vec_init_expr, bot_manip): Adjust.
- * init.c (build_vec_delete, build_vec_delete_1): Add complain parm.
- (build_delete, build_dtor_call): Likewise.
- (perform_direct_initialization_if_possible): Adjust.
- (build_vec_init): Handle error return.
- * cvt.c (force_rvalue): Add complain parm.
- Call build_special_member_call directly.
- * decl2.c (delete_sanity): Add complain parm.
- (build_cleanup): Adjust.
- * pt.c (tsubst_copy_and_build, tsubst_expr): Adjust.
- * semantics.c (finish_stmt_expr_expr): Adjust.
- (finish_compound_literal): Adjust.
- * parser.c (cp_parser_delete_expression): Adjust.
- * typeck2.c (build_functional_cast): Adjust.
- * cp-tree.h: Adjust.
-
-2011-04-26 Martin Jambor <mjambor@suse.cz>
-
- * class.c (cp_fold_obj_type_ref): Remove.
- * cp-tree.h (cp_fold_obj_type_ref): Remove declaration.
-
-2011-04-25 Paolo Carlini <paolo.carlini@oracle.com>
-
- * cp-tree.def: Add a new UNDERLYING_TYPE tree code.
- * cp-tree.h (enum cp_trait_kind): Add CPTK_UNDERLYING_TYPE, tidy.
- (UNDERLYING_TYPE_TYPE): Add.
- * cp-objcp-common.c (cp_common_init_ts): Mark UNDERLYING_TYPE
- as TS_COMMON.
- * parser.c (cp_lexer_next_token_is_decl_specifier_keyword,
- cp_parser_simple_type_specifier): Handle UNDERLYING_TYPE.
- (cp_parser_trait_expr): Deal with RID_UNDERLYING_TYPE; tidy.
- * semantics.c (finish_underlying_type): New.
- * typeck.c (structural_comptypes): Handle UNDERLYING_TYPE.
- * error.c (dump_type, dump_type_prefix, dump_type_suffix): Likewise.
- * cxx-pretty-print.c (p_cxx_type_id): Likewise.
- * tree.c (cp_walk_subtrees): Likewise.
- * pt.c (for_each_template_parm_r, tsubst, unify,
- dependent_type_p_r): Likewise.
- * mangle.c (write_type): Sorry for __underlying_type.
-
-2011-04-25 Jason Merrill <jason@redhat.com>
-
- PR c++/48707
- * decl.c (type_dependent_init_p): New.
- (cp_finish_decl): Check it.
- * pt.c (any_type_dependent_elements_p): New.
- * cp-tree.h: Declare it.
-
-2011-04-20 Jason Merrill <jason@redhat.com>
-
- * semantics.c (finish_compound_literal): Don't put an array
- with a dtor in a static variable.
-
- * call.c (build_over_call): Handle trivial dtor.
-
- * search.c (lookup_fnfields_slot): Call complete_type.
-
- PR c++/48594
- * decl2.c (build_offset_ref_call_from_tree): Move
- non-dependency of object outside condition.
-
- PR c++/48657
- * decl.c (cp_finish_decl): Simplify template handling.
-
-2011-04-20 Jim Meyering <meyering@redhat.com>
-
- * tree.c (cxx_printable_name_internal): Remove useless if-before-free.
-
-2011-04-19 Jason Merrill <jason@redhat.com>
-
- PR c++/46304
- * typeck.c (cp_build_binary_op): Fold COMPLEX_EXPR.
-
- PR c++/45267
- * decl.c (duplicate_decls): Keep always_inline attribute
- in sync with DECL_DISREGARD_INLINE_LIMITS.
-
-2011-04-18 Jason Merrill <jason@redhat.com>
-
- PR c++/48569
- * typeck2.c (build_functional_cast): Handle VOID_TYPE.
-
- PR c++/48537
- * init.c (build_value_init): Handle UNION_TYPE the same.
-
-2011-04-18 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/48632
- * parser.c (cp_parser_omp_for_loop): Don't use cp_parser_omp_for_incr
- for type dependent pointers.
-
-2011-04-18 Jim Meyering <meyering@redhat.com>
-
- * pt.c (type_unification_real): Fix typo in comment: s/in in/in/.
-
-2011-04-17 Jan Hubicka <jh@suse.cz>
-
- * semantics.c (finish_goto_stmt): Do set UNINLINABLE flag on computed
- gotos.
-
-2011-04-17 Jason Merrill <jason@redhat.com>
-
- PR c++/48531
- * typeck2.c (build_functional_cast): Disallow array type.
-
- * tree.c (get_target_expr): Handle VEC_INIT_EXPR.
-
-2011-04-17 Jan Hubicka <jh@suse.cz>
-
- * class.c (cp_fold_obj_type_ref): Drop vtable_method.
-
-2011-04-15 Rodrigo Rivas Costa <rodrigorivascosta@gmail.com>
-
- Implement N3271
- * parser.c (cp_convert_range_for): Split into
- cp_parser_perform_range_for_lookup.
- (cp_parser_perform_range_for_lookup): New.
- (cp_parser_range_for_member_function): New.
- (cp_parser_for_init_statement): Correct error message.
- * semantics.c (finish_call_expr): Accept COMPONENT_REF.
-
-2011-04-14 Nicola Pero <nicola.pero@meta-innovation.com>
-
- * parser.c (cp_parser_objc_protocol_declaration): Updated for
- change from objc_declare_protocols() to objc_declare_protocol().
-
-2011-04-14 Nathan Froyd <froydnj@codesourcery.com>
-
- PR objc++/48479
- * typeck.c (cxx_mark_addressable) [CONST_DECL]: Mark addressable
- and return immediately.
-
-2011-04-14 Nathan Froyd <froydnj@codesourcery.com>
-
- * cp-tree.def (SWITCH_STMT): Add an extra operand.
- * cp-objcp-common.c (cp_common_init_ts): Mark it as TS_TYPED.
- * cp-tree.h (SWITCH_STMT_SCOPE): Define.
- * semantics.c (begin_switch__stmt): Pass scope to build_stmt.
- (finish_switch_stmt): Use SWITCH_STMT_SCOPE instead of TREE_CHAIN.
-
-2011-04-14 Nathan Froyd <froydnj@codesourcery.com>
-
- * cp-tree.def (IF_STMT): Add an extra operand.
- * cp-objcp-common.c (cp_common_init_ts): Mark it as TS_TYPED.
- * cp-tree.h (IF_SCOPE): Define.
- * semantics.c (begin_if_stmt): Pass scope to build_stmt.
- (finish_if_stmt): Use IF_SCOPE instead of TREE_CHAIN.
-
-2011-04-14 Nathan Froyd <froydnj@codesourcery.com>
-
- * cp-tree.def (FOR_STMT, RANGE_FOR_STMT): Add an extra operand.
- * cp-objcp-common.c (cp_common_init_ts): Mark them as TS_TYPED.
- * cp-tree.h (FOR_SCOPE, RANGE_FOR_SCOPE): Define.
- * semantics.c (begin_for_stmt): Pass an extra arg to build_stmt.
- Use FOR_SCOPE instead of TREE_CHAIN.
- (begin_range_for_stmt): Likewise, with RANGE_FOR_SCOPE.
- (finish_for_stmt): Likewise.
-
-2011-04-14 Jason Merrill <jason@redhat.com>
-
- * parser.c (cp_parser_postfix_expression): Fix flags passed to
- build_new_method_call.
- * semantics.c (finish_call_expr): Likewise.
-
- PR c++/48531
- * init.c (build_value_init_noctor): Check complain consistently.
-
- PR c++/48557
- * typeck.c (cp_build_binary_op): Don't decay void operands.
-
- PR c++/48446
- * decl.c (compute_array_index_type): Use get_temp_regvar instead
- of variable_size.
- * init.c (get_temp_regvar): No longer static.
- * cp-tree.h: Declare it.
-
-2011-04-14 Nicola Pero <nicola.pero@meta-innovation.com>
-
- * parser.c (cp_parser_objc_class_declaration): Updated for change
- in objc_declare_class().
-
-2011-04-14 Nathan Froyd <froydnj@codesourcery.com>
-
- * decl.c (poplevel): Use block_chainon.
-
-2011-04-13 Jason Merrill <jason@redhat.com>
-
- PR c++/48594
- * decl2.c (build_offset_ref_call_from_tree): Fix calling a functor
- or pointer to (non-member) function.
-
-2011-04-13 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/48570
- * semantics.c (cxx_eval_array_reference): Handle reading from
- wchar_t, char16_t and char32_t STRING_CST.
-
-2011-04-13 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/48574
- * class.c (fixed_type_or_null): We cannot determine the dynamic
- type of a reference variable if its initializer is dependent.
-
-2011-04-13 Jason Merrill <jason@redhat.com>
-
- PR c++/48581
- * pt.c (tsubst_copy_and_build) [CALL_EXPR]: Don't complain about
- unqualified lookup failing if we're still in a template.
-
-2011-04-12 Nathan Froyd <froydnj@codesourcery.com>
-
- * cp-lang.c (cp_init_ts): Call cp_common_init_ts. Move
- tree_contains_struct initialization to...
- * cp-objcp-common.c (cp_common_init_ts): ...here. Use MARK_*
- macros.
- * cp-objcp-common.h (cp_common_init_ts): Declare.
- * cp-tree.h (union lang_tree_node): Check for TS_COMMON before
- calling TREE_CHAIN.
-
-2011-04-12 Nicola Pero <nicola.pero@meta-innovation.com>
-
- * parser.c (cp_parser_objc_message_expression): Updated call
- to objc_build_message_expr.
-
-2011-04-12 Martin Jambor <mjambor@suse.cz>
-
- * class.c (cp_fold_obj_type_ref): Call cgraph_get_node instead of
- cgraph_get_create_node.
- * decl2.c (cp_write_global_declarations): Call cgraph_get_node
- instead of cgraph_get_create_node.
- * method.c (make_alias_for_thunk): Call cgraph_get_node
- instead of cgraph_get_create_node, assert it returns non-NULL.
- (use_thunk): Likewise.
- * optimize.c (maybe_clone_body): Call cgraph_same_body_alias only
- when flag_syntax_only is not set. Call cgraph_get_node instead of
- cgraph_get_create_node.
- (maybe_clone_body): Call cgraph_get_node instead of
- cgraph_get_create_node.
-
-2011-04-12 Martin Jambor <mjambor@suse.cz>
-
- * class.c (cp_fold_obj_type_ref): Call cgraph_get_create_node
- instead of cgraph_node.
- * decl2.c (cxx_callgraph_analyze_expr): Likewise.
- (cp_write_global_declarations): Likewise.
- * optimize.c (maybe_clone_body): Likewise.
- * semantics.c (maybe_add_lambda_conv_op): Likewise.
- * mangle.c (mangle_decl): Likewise.
- * method.c (make_alias_for_thunk): Likewise.
- (use_thunk): Likewise.
-
-2011-04-11 Jason Merrill <jason@redhat.com>
-
- PR c++/48535
- * decl.c (cp_complete_array_type_or_error): New.
- * semantics.c (finish_compound_literal): Use it.
- * cp-tree.h: Declare it.
-
- PR c++/48535
- * semantics.c (finish_compound_literal): Handle references.
-
- PR c++/48535
- * semantics.c (finish_compound_literal): Take complain parm.
- (build_lambda_object): Adjust.
- * cp-tree.h: Adjust.
- * call.c (convert_like_real): Adjust.
- * decl.c (check_initializer): Adjust.
- * parser.c (cp_parser_postfix_expression): Adjust.
- (cp_parser_functional_cast): Adjust.
- * pt.c (tsubst_copy_and_build): Adjust.
- * typeck2.c (process_init_constructor_record): Adjust.
-
- PR c++/48534
- * cvt.c (ocp_convert): Use build_nop to convert to underlying type
- of scoped enum.
-
- PR c++/48523
- * tree.c (maybe_dummy_object): Use build_x_indirect_ref rather
- than cp_build_indirect_ref.
-
- PR c++/48457, Core 1238
- * call.c (reference_binding): Allow rvalue reference to bind to
- function lvalue.
- * tree.c (lvalue_kind): Functions are always lvalues.
-
-2011-04-07 Jason Merrill <jason@redhat.com>
-
- PR c++/48500
- * semantics.c (potential_constant_expression_1) [CALL_EXPR]: Check
- arguments even if we don't know the function.
-
- PR c++/48481
- * tree.c (build_overload): Allow an unwrapped FUNCTION_DECL
- at the end of the chain.
- * pt.c (dependent_template_p): Use OVL_CURRENT/NEXT.
- (iterative_hash_template_arg): Likewise.
-
- PR c++/48481
- * cp-tree.h (OVL_ARG_DEPENDENT): New.
- * name-lookup.c (add_function): Set it.
- * semantics.c (finish_call_expr): Free OVERLOADs if it's set.
-
- PR c++/48481
- * call.c (build_user_type_conversion_1): Use lookup_fnfields_slot.
- Release unused vector.
-
- PR c++/48451
- * pt.c (fn_type_unification): Don't clear incomplete pack flag.
- (type_unification_real): Clear it here instead.
-
- PR c++/48468
- * except.c (build_noexcept_spec): Propagate error_mark_node.
- (finish_noexcept_expr): Likewise.
-
- PR c++/48452
- * typeck.c (build_x_compound_expr_from_list): Return error_mark_node
- in SFINAE context.
-
- PR c++/48450
- * call.c (resolve_args): Take complain.
- (build_new_function_call, build_operator_new_call): Pass it.
- (build_op_call, build_new_op, build_new_method_call): Pass it.
-
- PR c++/48450
- * typeck.c (check_for_casting_away_constness): Take complain.
- (build_static_cast_1, build_reinterpret_cast_1): Pass it.
- (build_const_cast_1): Pass it. Take full complain parm.
- (build_const_cast, cp_build_c_cast): Adjust.
-
- * tree.c (build_aggr_init_expr): Always return error_mark_node
- on abstract violation.
-
- PR c++/48450
- * tree.c (build_cplus_new, build_aggr_init_expr): Take complain.
- (bot_manip): Adjust.
- * cp-tree.h: Adjust.
- * call.c (convert_like_real, build_cxx_call): Adjust.
- (perform_direct_initialization_if_possible): Adjust.
- * cvt.c (ocp_convert): Adjust.
- * init.c (build_value_init): Adjust.
- * semantics.c (maybe_add_lambda_conv_op): Adjust.
- * typeck.c (unary_complex_lvalue, cp_build_modify_expr): Adjust.
- * typeck2.c (build_functional_cast): Adjust.
-
- * init.c (build_value_init_noctor): Handle REFERENCE_TYPE at top
- level.
- (perform_member_init): Not here.
- * typeck2.c (build_functional_cast): Limit REFERENCE_TYPE special
- case to templates.
- (abstract_virtuals_error_sfinae): Remove RESULT_DECL special case.
-
- PR c++/48449
- * typeck2.c (build_functional_cast): Check complain consistently.
- Use build_value_init and abstract_virtuals_error_sfinae.
- (abstract_virtuals_error_sfinae): Split out.
- * cp-tree.h: Declare it.
- * init.c (build_new_1): Use it.
- (build_value_init_noctor): Handle FUNCTION_TYPE.
-
- * semantics.c (finish_decltype_type): Simplify handling of unknown
- type.
-
- * semantics.c (finish_decltype_type): Add complain parm.
- * cp-tree.h: Adjust.
- * parser.c (cp_parser_decltype): Adjust.
- * pt.c (tsubst): Adjust.
-
- PR c++/48450
- * cvt.c (ocp_convert): Handle converting scoped enum to bool.
-
-2011-03-31 Jason Merrill <jason@redhat.com>
-
- PR c++/48277
- * semantics.c (finish_call_expr): Remove assert.
-
- PR c++/48280
- * method.c (defaultable_fn_check): Templates are not defaultable.
-
- * parser.c (cp_parser_init_declarator): Avoid redundant
- cp_finish_decl for member declarations.
-
-2011-03-30 Jason Merrill <jason@redhat.com>
-
- PR c++/48212
- * semantics.c (non_const_var_error): Just return if DECL_INITIAL
- is error_mark_node.
-
-2011-03-30 Jason Merrill <jason@redhat.com>
-
- PR c++/48369
- * semantics.c (potential_constant_expression_1): Handle
- UNORDERED_EXPR and ORDERED_EXPR.
-
- PR c++/48281
- * semantics.c (finish_compound_literal): Do put static/constant
- arrays in static variables.
-
- * call.c (convert_like_real) [ck_list]: Build up the
- initializer_list object directly.
- * decl.c (build_init_list_var_init): Adjust.
-
- * call.c (convert_like_real): Correct TREE_CONSTANT on CONSTRUCTOR.
- * decl.c (reshape_init_array_1): Likewise.
-
-2011-03-29 Jason Merrill <jason@redhat.com>
-
- PR c++/48265
- * pt.c (value_dependent_expression_p) [VAR_DECL]: Make sure
- the variable is constant before looking at its initializer.
-
- PR c++/48319
- * pt.c (value_dependent_expression_p): Handle TEMPLATE_ID_EXPR.
-
- PR c++/48089
- * semantics.c (potential_constant_expression_1): Change error about
- use of *this in constructor into sorry.
-
- PR c++/48296
- * decl.c (cp_finish_decl): Defer validation of constexpr member
- functions.
- * class.c (finalize_literal_type_property): Validate them here.
- * semantics.c (is_valid_constexpr_fn): Don't check completeness.
-
- * semantics.c (is_valid_constexpr_fn): Specify input location.
-
-2011-03-28 Jason Merrill <jason@redhat.com>
-
- PR c++/48313
- * pt.c (maybe_adjust_types_for_deduction): Handle T&& deduction
- from overloaded function.
-
- Core 1232
- * call.c (build_array_conv): New.
- (implicit_conversion): Use it.
-
- * call.c (reference_binding): Allow direct binding to an array
- rvalue.
-
- Core 898
- * parser.c (cp_parser_compound_statement): Add function_body parm.
- Complain about non-body compound-stmt in constexpr fn.
- (cp_parser_primary_expression, cp_parser_statement): Adjust.
- (cp_parser_implicitly_scoped_statement): Adjust.
- (cp_parser_function_body, cp_parser_try_block): Adjust.
- (cp_parser_handler, cp_parser_objc_synchronized_statement): Adjust.
- (cp_parser_objc_try_catch_finally_statement): Adjust.
-
- Core 898
- * semantics.c (constexpr_fn_retval): New. Allow using-declaration
- and using-definition.
- (register_constexpr_fundef): Call it.
-
- * except.c (build_noexcept_spec): Call cxx_constant_value after
- converting to bool.
-
-2011-03-25 Kai Tietz <ktietz@redhat.com>
-
- * lex.c (interface_strcmp): Handle dos-paths.
- (handle_pragma_implementation): Use filename_cmp instead of
- strcmp.
- (in_main_input_context): Likewise.
-
-2011-03-25 Jason Merrill <jason@redhat.com>
-
- Core 1135
- * method.c (defaulted_late_check): Check for exception spec mismatch.
- (defaultable_fn_check): Allow exception spec and virtual.
- * class.c (check_for_override): A virtual dtor is non-trivial.
-
- PR c++/48289
- * pt.c (build_non_dependent_expr): Keep dereferences outside the
- NON_DEPENDENT_EXPR.
-
-2011-03-25 Kai Tietz <ktietz@redhat.com>
-
- * decl.c (decls_match): Replace target hook
- call of comp_type_attributes by version in tree.c file.
- * search.c (check_final_overrider): Likewise.
- * typeck.c (structural_comptypes): Likewise.
-
-2011-03-21 Kai Tietz <ktietz@redhat.com>
-
- PR target/12171
- * cxx-pretty-print.c (pp_cxx_ptr_operator):
- Display allowed attributes for function pointer types.
- * error.c (dump_type_prefix): Likewise.
-
- * tree.c (cxx_attribute_table): Adjust table.
-
-2011-03-18 Jason Merrill <jason@redhat.com>
-
- PR c++/48162
- * semantics.c (finish_call_expr): Allow TARGET_EXPR for now.
-
- PR c++/48118
- * call.c (build_over_call): Don't skip ck_rvalue.
-
-2011-03-17 Jason Merrill <jason@redhat.com>
-
- PR c++/47504
- * semantics.c (cxx_eval_constant_expression) [NOP_EXPR]: Don't let
- the conversion set TREE_OVERFLOW.
-
- Core 1212
- * semantics.c (finish_decltype_type): Return T&& for xvalue.
- * typeck.c (unlowered_expr_type): Preserve cv-quals.
-
- PR c++/48166
- * decl.c (revert_static_member_fn): Strip function-cv-quals.
-
-2011-03-16 Jason Merrill <jason@redhat.com>
-
- PR c++/48089
- * semantics.c (potential_constant_expression_1): Don't allow *this
- in a constructor.
- (register_constexpr_fundef): Use potential_rvalue_constant_expression.
-
- PR c++/47301
- * decl.c (compute_array_index_type): Don't bother trying to deal
- with literal classes in ABI v1.
-
- PR c++/46336
- * decl.c (duplicate_decls): Return NULL_TREE for clashing
- C functions.
-
- PR c++/47570
- * semantics.c (cxx_eval_constant_expression) [COMPOUND_EXPR]: Don't
- use the generic binary expression handling.
-
-2011-03-16 Diego Novillo <dnovillo@google.com>
-
- * Make-lang.in (CXX_PARSER_H): New.
- (cp/parser.o): Add dependency on CXX_PARSER_H.
- Add dependency on tree-pretty-print.h
- (cp/cp-lang.o): Add dependency on CXX_PARSER_H.
- * cp-lang.c: Include parser.h.
- * parser.c: Include parser.h.
- (struct cp_token): Add bitfield purged_p.
- Update all users.
- Move to parser.h.
- (CPP_PURGED): Remove. Update all users.
- (struct cp_lexer): Change field buffer to be a VEC of cp_token.
- Remove field buffer_length.
- Update all users.
- Move to parser.h.
- (struct tree_check): Move to parser.h.
- (cp_token_position): Likewise.
- (struct cp_token_cache): Likewise.
- (CPP_KEYWORD): Likewise.
- (CPP_TEMPLATE_ID): Likewise.
- (CPP_NESTED_NAME_SPECIFIER): Likewise.
- (N_CP_TTYPES): Likewise.
- (enum cp_parser_status_kind): Likewise.
- (struct cp_parser_context): Likewise.
- (struct cp_default_arg_entry_d): Likewise.
- (struct cp_unparsed_functions_entry_d): Likewise.
- (struct cp_parser): Likewise.
- (cp_lexer_dump_tokens): New.
- (cp_lexer_debug_tokens): New.
- (cp_lexer_finished_p): New.
- (cp_lexer_alloc): Factor out of cp_lexer_new_main.
- (cp_lexer_new_main): Re-write main lexing loop to push
- tokens into the new VEC buffer.
- (cp_lexer_print_token): Improve printing of CPP_NUMBER tokens.
- Do not abort if the token type is not recognized, just print
- its code.
- * parser.h: New file.
- * config-lang.in (gtfiles): Add cp/parser.h.
-
-2011-03-16 Jason Merrill <jason@redhat.com>
-
- Core 1148
- * typeck.c (check_return_expr): Fix conditions for setting
- LOOKUP_PREFER_RVALUE.
-
- * call.c (build_over_call): Remove require_complete_type_sfinae call.
-
- PR c++/48132
- * decl.c (check_array_designated_initializer): Allow integer index.
- (reshape_init_array_1): Set index on the elements.
-
-2011-03-16 Jason Merrill <jason@redhat.com>
-
- PR c++/48113
- * typeck.c (convert_for_initialization): Use
- perform_implicit_conversion_flags.
- * call.c (standard_conversion): If LOOKUP_PREFER_RVALUE, set
- rvaluedness_matches_p on ck_rvalue.
- (convert_like_real) [ck_rvalue]: And restore it here.
-
- PR c++/48115
- * call.c (convert_arg_to_ellipsis): Handle incomplete type.
-
-2011-03-16 Jason Merrill <jason@redhat.com>
-
- * parser.c (cp_parser_abort_tentative_parse): Make sure we haven't
- committed to this tentative parse.
-
- PR c++/47999
- * semantics.c (finish_call_expr): Preserve reference semantics
- in templates.
-
- * call.c (convert_default_arg): Use LOOKUP_IMPLICIT.
-
-2011-03-16 Jakub Jelinek <jakub@redhat.com>
-
- * cp-objcp-common.c (cp_function_decl_explicit_p): Don't crash if
- DECL_LANG_SPECIFIC is NULL.
-
-2011-03-15 Jason Merrill <jason@redhat.com>
-
- Core 1074
- * pt.c (value_dependent_expression_p) [NOEXCEPT_EXPR]: Don't
- check value_dependent_expression_p on the operand.
-
- * semantics.c (push_cx_call_context): Return bool.
- (cxx_eval_call_expression): Handle excess depth.
-
- Core 1191
- * method.c (synthesized_method_walk): Cleanups don't affect the
- triviality of a constructor, but do affect deletion and exception
- specification.
-
-2011-03-15 Rodrigo Rivas Costa <rodrigorivascosta@gmail.com>
-
- * decl2.c (cp_check_const_attributes): New.
- (cplus_decl_attributes): Call cp_check_const_attributes.
-
-2011-03-15 Jason Merrill <jason@redhat.com>
-
- PR c++/34758
- * call.c (convert_default_arg): Use DECL_ORIGIN of fn. Check for
- recursion first.
- (push_defarg_context, pop_defarg_context): New.
- * parser.c (cp_parser_late_parsing_default_args): Use them.
- * cp-tree.h: Declare them.
-
-2011-03-11 Dodji Seketeli <dodji@redhat.com>
-
- * call.c (add_builtin_candidate)<case INDIRECT_REF>: The type of
- the argument of the indirection operator should not be dependent.
- Fix the comment.
-
-2011-03-11 Jason Merrill <jason@redhat.com>
-
- PR c++/47125
- * pt.c (tsubst) [TYPENAME_TYPE]: Only give errors if tf_error.
-
- PR c++/47144
- * parser.c (cp_parser_template_type_arg): Set
- type_definition_forbidden_message.
-
- PR c++/47808
- * decl.c (compute_array_index_type): Discard folding
- if it didn't produce a constant.
-
-2011-03-11 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/48035
- * init.c (build_zero_init_1): Extracted from build_zero_init.
- Add FIELD_SIZE argument, if non-NULL and field bit_position
- as not smaller than that, don't add that field's initializer.
- Pass DECL_SIZE as last argument to build_zero_init_1
- for DECL_FIELD_IS_BASE fields.
- (build_zero_init): Use build_zero_init_1.
-
-2011-03-10 Jason Merrill <jason@redhat.com>
-
- PR c++/48029
- * pt.c (iterative_hash_template_arg): Remove special case for
- ARRAY_TYPE.
-
- PR c++/47198
- * parser.c (cp_parser_single_declaration): Just return if
- cp_parser_parse_and_diagnose_invalid_type_name complained.
-
-2011-03-09 Jason Merrill <jason@redhat.com>
-
- PR c++/44629
- * pt.c (unify): An unresolved overload is a nondeduced context.
-
-2011-03-09 Martin Jambor <mjambor@suse.cz>
-
- PR tree-optimization/47714
- * method.c (use_thunk): Clear addressable flag of thunk arguments.
-
-2011-03-08 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/47705
- * pt.c (convert_nontype_argument): Only call decay_conversion on
- arrays.
-
-2011-03-08 Jason Merrill <jason@redhat.com>
-
- PR c++/47488
- * mangle.c (write_template_arg_literal) [STRING_CST]: Sorry.
-
- PR c++/47705
- * pt.c (convert_nontype_argument): Don't crash on non-pointer
- argument to pointer parameter.
-
- PR c++/45651
- * pt.c (instantiate_decl): Don't clear DECL_INTERFACE_KNOWN on
- !TREE_PUBLIC decls.
-
-2011-03-08 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/47957
- * name-lookup.c (binding_to_template_parms_of_scope_p): Only
- consider scopes of primary template definitions. Adjust comments.
-
-2011-03-07 Jason Merrill <jason@redhat.com>
-
- PR c++/48003
- * pt.c (convert_nontype_argument): Fix -fpermissive allowing
- integer overflow.
- * semantics.c (potential_constant_expression_1): Check TREE_OVERFLOW.
-
- PR c++/48015
- * init.c (constant_value_1): Always require init to be TREE_CONSTANT.
-
- PR c++/48008
- * mangle.c (write_type): Strip cv-quals from FUNCTION_TYPE here.
- (write_CV_qualifiers_for_type): Not here.
-
-2011-03-06 Joseph Myers <joseph@codesourcery.com>
-
- * lang-specs.h: Match -save-temps* instead of -save-temps.
-
-2011-03-05 Jason Merrill <jason@redhat.com>
-
- * mangle.c (write_expression): Change ABI v6 to v5.
- (write_type): Likewise.
-
-2011-03-04 Jan Hubicka <jh@suse.cz>
-
- PR lto/47497
- * optimize.c (maybe_clone_body): Update call of cgraph_same_body_alias
- and cgraph_add_thunk.
- * method.c (make_alias_for_thunk, use_thunk): Likewise.
- * mangle.c (mangle_decl): Likewise.
-
-2011-03-04 Jason Merrill <jason@redhat.com>
-
- PR c++/47971
- * pt.c (tsubst_copy_and_build) [PSEUDO_DTOR_EXPR]: Use tsubst for type.
- (tsubst_copy) [default]: Just return t if !ENABLE_CHECKING.
-
- PR c++/46220
- * search.c (check_final_overrider): Allow pointer to same incomplete
- class type with different cv-quals.
-
-2011-03-03 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/47974
- * pt.c (tsubst_template_args): Check argument t for error_mark_node.
-
-2011-03-03 Jason Merrill <jason@redhat.com>
-
- PR c++/47950
- * pt.c (tsubst_copy_and_build) [TARGET_EXPR]: Retain TREE_CONSTANT.
-
-2011-03-02 Jason Merrill <jason@redhat.com>
-
- PR c++/47950
- * parser.c (cp_parser_condition): Don't fold_non_dependent_expr here.
-
- PR c++/47774
- * tree.c (build_vec_init_elt): Split out from...
- (build_vec_init_expr): ...here.
- (diagnose_non_constexpr_vec_init): New fn.
- * semantics.c (potential_constant_expression_1): Use it.
- * cp-tree.h: Declare it.
-
-2011-03-01 Jason Merrill <jason@redhat.com>
-
- PR c++/46159
- * parser.c (cp_parser_primary_expression): Don't warn about a
- failed tentative parse.
-
- PR c++/47200
- * semantics.c (cxx_bind_parameters_in_call): Don't call
- adjust_temp_type on non-constant args.
-
- PR c++/47851
- * call.c (standard_conversion): Provide requested cv-quals on
- class rvalue conversion.
-
- PR c++/46282
- * decl2.c (grokbitfield): Handle type-dependent width.
-
-2011-02-28 Jason Merrill <jason@redhat.com>
-
- PR c++/47873
- * class.c (update_vtable_entry_for_fn): Check BINFO_LOST_PRIMARY_P
- after checking for a non-thunk.
-
-2011-02-26 Jason Merrill <jason@redhat.com>
-
- PR c++/47904
- * tree.c (cp_tree_equal): Compare DECL_PARM_LEVEL.
- * pt.c (iterative_hash_template_arg): And hash it.
-
- PR c++/47897
- * semantics.c (non_const_var_error): Split out from...
- (cxx_eval_constant_expression): ...here.
- (potential_constant_expression_1) [VAR_DECL]: Use it.
- Allow dependent variables.
-
-2011-02-24 Jason Merrill <jason@redhat.com>
-
- * parser.c (cp_parser_constant_expression): Set
- non_integral_constant_expression correctly for C++0x too.
- (cp_parser_static_assert): Allow non-constant expression.
- (cp_parser_direct_declarator): Expect non_constant_p to be set
- properly for C++0x.
- * pt.c (value_dependent_expression_p): Handle TYPEID_EXPR.
- * semantics.c (maybe_constant_value): Check type_unknown_p too.
- (potential_rvalue_constant_expression): New.
- (require_potential_rvalue_constant_expression): New.
-
-2011-02-23 Jason Merrill <jason@redhat.com>
-
- * cp-tree.h (DECL_PARM_LEVEL): New.
- (struct lang_decl_parm): Add level field.
- * name-lookup.c (function_parm_depth): New fn.
- * name-lookup.h: Declare it.
- * parser.c (cp_parser_parameter_declaration_list): Use it.
- * mangle.c (struct globals): Add parm_depth field.
- (write_bare_function_type): Adjust it.
- (write_expression): Include the level delta in PARM_DECL mangling
- for abi >= 6.
-
- * semantics.c (finish_decltype_type): Remove shortcut for decltype
- of id-expression.
- * mangle.c (write_type) [DECLTYPE_TYPE]: Strip it here for abi < 6.
-
-2011-02-23 Nathan Froyd <froydnj@codesourcery.com>
-
- PR c++/46868
- * parser.c (cp_parser_class_specifier): Require a closing brace
- to attempt error recovery.
-
-2011-02-23 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/47833
- * pt.c (struct pending_template): Add chain_next GTY option.
- * decl.c (struct named_label_use_entry): Likewise.
-
-2011-02-22 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/47242
- * semantics.c (build_lambda_object): Bail out if a field is
- error_mark_node.
-
-2011-02-22 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/47666
- * class.c (dfs_declare_virt_assop_and_dtor)
- (declare_virt_assop_and_dtor): New static functions.
- (add_implicitly_declared_members): Use
- declare_virt_assop_and_dtor.
-
-2011-02-21 Jason Merrill <jason@redhat.com>
-
- PR c++/47207
- * decl2.c (decl_constant_var_p): A constexpr var needs an
- initializer to be constant.
- * semantics.c (cxx_eval_constant_expression): Complain about
- constexpr var used in its own initializer.
- * call.c (set_up_extended_ref_temp): Set
- DECL_INITIALIZED_BY_CONSTANT_EXPRESSION_P too.
-
-2011-02-20 Jason Merrill <jason@redhat.com>
-
- PR c++/47199
- * semantics.c (cxx_eval_call_expression): Call
- cxx_eval_constant_expression in trivial shortcut.
-
- PR c++/46831
- * call.c (convert_class_to_reference): Don't try to set up a
- second conv sequence for non-viable candidates.
-
- PR c++/47703
- * error.c (location_of): Handle non-tagged types.
-
- PR c++/46472
- * method.c (process_subob_fn): Instantiate constexpr templates.
- * optimize.c (maybe_clone_body): Propagate DECL_DECLARED_CONSTEXPR_P.
-
-2011-02-20 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/46394
- * pt.c (tsubst_pack_expansion): do not use
- cp_tree_equal/same_type_p to detect an expansion of a parameter
- pack.
-
-2011-02-19 Jason Merrill <jason@redhat.com>
-
- PR c++/47503
- * semantics.c (cxx_eval_call_expression): Shortcut trivial copy.
-
-2011-02-18 Paolo Carlini <paolo.carlini@oracle.com>
-
- PR c++/47795
- * semantics.c (finish_non_static_data_member): Early return if
- object is error_mark_node.
-
-2011-02-18 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/47208
- * pt.c (do_auto_deduction): Do not mention error_mark_node in
- diagnostics.
- * semantics.c (finish_id_expression): Do not pass erroneous decl
- to decl_constant_var_p.
-
-2011-02-17 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/47783
- * cvt.c (convert_from_reference): Call mark_exp_read.
-
-2011-02-11 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/47172
- * pt.c (finish_call_expr): Consider a call expression that has a
- dependent "this" pointer as being dependent. Add comments.
- (dependent_type_p, type_dependent_expression_p): Update comments.
-
-2011-02-16 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/47326
- * pt.c (tsubst_copy)<case SIZEOF_EXPR>: Ensure that even pack
- expansion arguments are not evaluated.
-
-2011-02-16 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/47704
- * cp-tree.h (ENUM_FIXED_UNDERLYING_TYPE_P): Use TYPE_LANG_FLAG_5
- instead of TYPE_LANG_FLAG_3.
- * pt.c (lookup_template_class): Copy over
- ENUM_FIXED_UNDERLYING_TYPE_P.
-
-2011-02-15 Jason Merrill <jason@redhat.com>
-
- PR c++/46807
- * method.c (synthesized_method_walk): Always exit early for
- trivial fn in C++98 mode.
-
-2011-02-14 Jason Merrill <jason@redhat.com>
-
- PR c++/47482
- * parser.c (cp_parser_enumerator_definition): Call
- fold_non_dependent_expr.
-
-2011-02-09 Jason Merrill <jason@redhat.com>
-
- * decl.c (cp_make_fname_decl): Set DECL_THIS_STATIC at toplevel.
- * semantics.c (finish_fname): Only return the name if we're in
- a function.
-
- * decl.c (build_enumerator): Don't perform integral promotions on
- non-integral constants.
-
- * cvt.c (convert_to_void): Handle null op1.
-
- * class.c (type_has_constexpr_default_constructor): Make sure the
- caller stripped an enclosing array.
- * init.c (perform_member_init): Strip arrays before calling it.
-
- PR c++/47511
- * semantics.c (potential_constant_expression_1): Handle TEMPLATE_DECL.
-
-2011-02-03 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/47398
- * tree.c (cp_tree_equal)<TEMPLATE_PARM_INDEX>: Take the number of
- template parameters in account.
-
-2011-02-03 Nathan Froyd <froydnj@codesourcery.com>
-
- PR c++/46890
- * parser.c (cp_parser_class_specifier): Fix setting of
- want_semicolon.
-
-2011-01-31 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/47416
- * semantics.c (build_data_member_initialization): Handle
- STATEMENT_LIST always instead of just for CLEANUP_BODY.
-
-2011-01-31 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
-
- * g++spec.c (lang_specific_driver) [HAVE_LD_STATIC_DYNAMIC] Use
- LD_STATIC_OPTION, LD_DYNAMIC_OPTION.
-
-2011-01-29 Dodji Seketeli <dodji@redhat.com>
-
- PR c++/47311
- * cp-tree.h (fixup_template_parms): Declare.
- * pt.c (end_template_parm_list): Do not fixup template parms here.
- (fixup_template_parms): Remove static. Fix typo in the
- comments. Remove useless code statement.
- (fixup_template_parm): For a template template parameter, fixup
- its attributes before fixing up its type.
- * parser.c
- (cp_parser_template_declaration_after_export): After parsing
- template parameters fixup their types.
-
-2011-01-26 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/47476
- * semantics.c (potential_constant_expression_1): Handle
- TRUTH_XOR_EXPR.
-
-2011-01-26 Dave Korn <dave.korn.cygwin@gmail.com>
-
- PR c++/43601
- * semantics.c (expand_or_defer_fn_1): Handle it.
- * decl2.c (decl_needed_p): Likewise.
-
-2011-01-21 Jason Merrill <jason@redhat.com>
-
- PR c++/47041
- * semantics.c (build_constexpr_constructor_member_initializers):
- Handle trivial copy.
-
-2011-01-21 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/47388
- * semantics.c (begin_for_stmt): If -fno-for-scope, don't
- assume init must be NULL if scope is NULL.
- (begin_range_for_stmt): Likewise.
-
-2011-01-21 Jason Merrill <jason@redhat.com>
-
- PR c++/46552
- * semantics.c (cxx_eval_constant_expression): Handle OFFSET_REF.
-
- PR c++/46977
- * semantics.c (potential_constant_expression_1): Split out from
- potential_constant_expression. Add want_rval parm. Handle
- template expression forms. Don't enforce restriction on address
- of automatic variable here. Add a couple of diagnostics that
- had been missing.
- (require_potential_constant_expression): New entry point.
- (build_data_member_initialization, register_constexpr_fundef): Adjust.
- (maybe_constant_value): Check potential_constant_expression.
- * pt.c (fold_non_dependent_expr_sfinae): Likewise.
- * tree.c (build_vec_init_expr): Adjust.
-
-2011-01-19 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/47303
- * decl2.c (finish_anon_union): Only call mangle_decl if TREE_STATIC
- or DECL_EXTERNAL.
-
-2011-01-17 Jason Merrill <jason@redhat.com>
-
- PR c++/47067
- * semantics.c (base_field_constructor_elt): New fn.
- (cxx_eval_bare_aggregate): Use it.
- (build_data_member_initialization): Leave COMPONENT_REF for
- vfield inits.
-
-2011-01-14 Rodrigo Rivas Costa <rodrigorivascosta@gmail.com>
-
- * parser.c (cp_parser_range_for): Remove the "unused variable" warning
- workaround.
-
-2011-01-15 Giovanni Funchal <gafunchal@gmail.com>
- Jonathan Wakely <jwakely.gcc@gmail.com>
-
- PR c++/33558
- * decl.c (grokdeclarator): Reject mutable reference members.
-
-2011-01-14 Jason Merrill <jason@redhat.com>
-
- PR c++/47289
- * pt.c (coerce_template_parms): Fix error recovery.
-
- PR c++/46903
- * typeck2.c (check_narrowing): Only check arithmetic types.
-
- PR c++/46688
- * tree.c (build_vec_init_expr): Handle flexible array
- properly.
-
-2011-01-13 Kai Tietz <kai.tietz@onevision.com>
-
- PR c++/47213
- * cp-tree.h (CLASSTYPE_VISIBILITY): Use
- TYPE_MAIN_DECL instead of TYPE_NAME.
- (CLASSTYPE_VISIBILITY_SPECIFIED): Likewise.
- * decl2.c (determine_visibility): Add check
- of CLASS_TYPE_P for underlying_type.
-
-2011-01-12 Rodrigo Rivas Costa <rodrigorivascosta@gmail.com>
-
- * cp-tree.h (begin_for_scope): New prototype.
- (begin_for_stmt): Update prototype.
- (begin_range_for_stmt): Update prototype.
- * init.c (build_vec_init): Update call to begin_for_stmt.
- * parser.c (cp_parser_for): New.
- (cp_parser_c_for): Add three new parameters.
- (cp_parser_range_for): Likewise. Most parsing code removed.
- (cp_parser_iteration_statement): Call cp_parser_for instead of
- cp_parser_c_for and cp_parser_range_for.
- (cp_parser_for_init_statement): Add new parameter and return type.
- (cp_parser_block_declaration): Update call to
- cp_parser_simple_declaration.
- (cp_parser_simple_declaration): Add new parameter.
- Update call to cp_parser_init_declarator.
- (cp_parser_init_declarator): Add new parameter.
- * pt.c (tsubst_expr): Update call to begin_for_stmt.
- * semantics.c (begin_for_scope): New.
- (begin_for_stmt): Add two new parameters.
- (begin_range_for_stmt): Likewise.
-
-2011-01-12 Nicola Pero <nicola.pero@meta-innovation.com>
-
- * parser.c (cp_parser_objc_at_property_declaration): Improved
- error message.
-
-2011-01-11 Dodji Seketeli <dodji@redhat.com>
-
- PR debug/46955
- * cp-lang.c (get_template_innermost_arguments_folded)
- (get_template_argument_pack_elems_folded)
- (template_arg_needs_folding, fold_cplus_constants): New static
- functions.
- (LANG_HOOKS_GET_INNERMOST_GENERIC_ARGS): Set this hook to
- get_template_innermost_arguments_folded.
- (LANG_HOOKS_GET_ARGUMENT_PACK_ELEMS): Set this hook to
- get_template_argument_pack_elems_folded.
-
-2011-01-11 Jason Merrill <jason@redhat.com>
-
- PR c++/46658
- * init.c (build_new_1): Handle value-init in templates differently.
-
- PR c++/45520
- * tree.c (maybe_dummy_object): Check current_class_ref against
- context, not current_class_type.
-
-2011-01-08 Nicola Pero <nicola.pero@meta-innovation.com>
-
- PR objc/47078
- * parser.c (cp_parser_objc_typename): If the type is unknown, for
- error recovery purposes behave as if it was not specified so that
- the default type is used.
-
-2011-01-07 Jakub Jelinek <jakub@redhat.com>
-
- PR c++/47022
- * pt.c (tsubst_copy_and_build): Use tsubst instead of tsubst_copy
- for the second build_x_va_arg argument.
-
-2011-01-05 Tom Tromey <tromey@redhat.com>
-
- * typeck.c (cp_build_addr_expr_1): Update call to lvalue_error.
- (lvalue_or_else): Likewise.
-
-2011-01-01 Kai Tietz <kai.tietz@onevision.com>
-
- PR target/38662
- * tree.c (cxx_type_hash_eq):
- Allow METHOD_TYPE, too.
-
-Copyright (C) 2011 Free Software Foundation, Inc.
+Copyright (C) 2012 Free Software Foundation, Inc.
Copying and distribution of this file, with or without modification,
are permitted in any medium without royalty provided the copyright
diff --git a/gcc/cp/ChangeLog-2011 b/gcc/cp/ChangeLog-2011
new file mode 100644
index 0000000..5065989
--- /dev/null
+++ b/gcc/cp/ChangeLog-2011
@@ -0,0 +1,5033 @@
+2011-12-31 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51397
+ * semantics.c (finish_static_assert): Use %s instead of %E for
+ the error message.
+
+2011-12-27 Fabien Chêne <fabien@gcc.gnu.org>
+
+ PR c++/23211
+ * name-lookup.c (do_class_using_decl): Use dependent_scope_p
+ instead of dependent_type_p, to check that a non-dependent
+ nested-name-specifier of a class-scope using declaration refers to
+ a base, even if the current scope is dependent.
+ * parser.c (cp_parser_using_declaration): Set
+ USING_DECL_TYPENAME_P to 1 if the DECL is not null. Re-indent a
+ 'else' close to the prior modification.
+
+2011-12-23 Jason Merrill <jason@redhat.com>
+
+ PR c++/51507
+ * search.c (at_function_scope_p): Also check cfun.
+ * pt.c (tsubst_pack_expansion): Check it instead of
+ cp_unevaluated_operand.
+ (instantiate_template_1): Use push_to_top_level.
+
+ * tree.c (dependent_name): OFFSET_REF and BASELINK
+ are not dependent names.
+
+2011-12-21 Jason Merrill <jason@redhat.com>
+
+ PR c++/51611
+ * cp-tree.h (CONVERT_EXPR_VBASE_PATH): New.
+ * class.c (build_base_path): Defer vbase conversion in an NSDMI.
+ * tree.c (bot_replace): Expand it here.
+ * cp-gimplify.c (cp_genericize_r): Make sure deferred conversion
+ doesn't leak into GENERIC.
+
+2011-12-21 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51305
+ * semantics.c (massage_constexpr_body): Reorder conditionals, make
+ sure a BIND_EXPR embedded in a MUST_NOT_THROW_EXPR is handled.
+
+2011-12-20 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51621
+ * tree.c (diagnose_non_constexpr_vec_init): For value initialization
+ pass void_type_node, not void_zero_node, to build_vec_init_elt.
+
+2011-12-20 Dodji Seketeli <dodji@redhat.com>
+
+ PR debug/49951
+ * decl.c (cxx_maybe_build_cleanup): Don't set location of the call
+ to the destructor.
+
+2011-12-20 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51612
+ * semantics.c (is_valid_constexpr_fn): In case of constexpr
+ constructors also check for virtual base classes.
+
+2011-12-19 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51328
+ * pt.c (convert_template_argument): Early error out and return
+ error_mark_node for invalid uses of destructors as types.
+
+2011-12-19 Jason Merrill <jason@redhat.com>
+
+ PR c++/51530
+ * pt.c (unify): Handle NULLPTR_TYPE.
+
+ PR c++/51526
+ * semantics.c (build_data_member_initialization): Handle
+ delegating constructor.
+ (build_constexpr_constructor_member_initializers): Likewise.
+
+ PR c++/51553
+ * cp-tree.h (LOOKUP_LIST_INIT_CTOR): Rename from
+ LOOKUP_NO_COPY_CTOR_CONVERSION.
+ (add_list_candidates): Set it earlier.
+ (add_candidates): Don't check explicit on ctors when it's set.
+ (add_function_candidate): Check it even when LOOKUP_ONLYCONVERTING
+ is set.
+
+ PR c++/51553
+ * call.c (add_function_candidate): Allow conversions for the copy
+ parm in list-initialization unless the argument is an init-list.
+
+2011-12-19 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/51619
+ * semantics.c (cxx_eval_vec_init_1): If init is NULL for
+ multidimensional array, just set eltinit to NULL_TREE.
+
+ * cp-gimplify.c (gimplify_must_not_throw_expr): Use
+ gimple_seq_add_stmt_without_update instead of gimplify_seq_add_stmt.
+
+2011-12-19 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/51477
+ * search.c (lookup_member): Get out early on invalid base type.
+
+2011-12-19 Jason Merrill <jason@redhat.com>
+
+ PR c++/51489
+ * semantics.c (cxx_eval_outermost_constant_expr): Check for
+ conversion from pointer to integer here.
+ (cxx_eval_constant_expression) [NOP_EXPR]: Not here.
+
+2011-12-18 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * semantics.c (finish_compound_literal): Don't call check_narrowing
+ if !(complain & tf_warning_or_error).
+
+2011-12-17 Jason Merrill <jason@redhat.com>
+
+ PR c++/51588
+ * parser.c (cp_parser_ptr_operator): Reject pointer to member of enum.
+
+2011-12-17 Richard Henderson <rth@redhat.com>
+
+ PR bootstrap/51072
+ * config-lang.in: Revert last change.
+
+2011-12-17 Jason Merrill <jason@redhat.com>
+
+ PR c++/51586
+ * parser.c (cp_parser_check_class_key): Handle error_mark_node.
+
+ PR c++/51587
+ * decl.c (start_enum): Avoid using ENUM_UNDERLYING_TYPE on a
+ non-enum.
+
+2011-12-16 Jason Merrill <jason@redhat.com>
+
+ PR c++/51416
+ * init.c (build_value_init_noctor): Check for incomplete type.
+
+2011-12-16 Richard Henderson <rth@redhat.com>
+
+ PR bootstrap/51072
+ * config-lang.in (target_libs): Include target-libitm.
+
+2011-12-16 Jason Merrill <jason@redhat.com>
+
+ PR c++/51461
+ * decl.c (check_static_variable_definition): Check COMPLETE_TYPE_P
+ before literal_type_p.
+
+ PR c++/51331
+ * class.c (convert_to_base_statically): Just call
+ build_simple_base_path.
+ (build_simple_base_path): Check field offset.
+
+2011-12-15 Jason Merrill <jason@redhat.com>
+
+ PR c++/51458
+ * decl.c (has_designator_problem): New.
+ (reshape_init_r): Check for improper use of
+ designated initializers.
+
+2011-12-15 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/51463
+ * decl.c (grokdeclarator): Set DECL_INITIAL of decl
+ to error_mark_node to disallow NSDMI if declspecs->storage_class
+ is sc_static.
+ * parser.c (cp_parser_late_parse_one_default_arg): Return early
+ if default_arg is error_mark_node.
+
+ PR c/51360
+ * semantics.c (finish_omp_clauses): For OMP_CLAUSE_NUM_THREADS_EXPR
+ and OMP_CLAUSE_SCHEDULE_CHUNK_EXPR call mark_rvalue_use.
+
+2011-12-15 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/51473
+ * decl.c (check_tag_decl): Error out on auto specifier with no
+ declarator.
+
+2011-12-15 Jonathan Wakely <jwakely.gcc@gmail.com>
+
+ PR libstdc++/51365
+ * cp-tree.h (CPTK_IS_FINAL): Add.
+ * parser.c (cp_parser_translation_unit): Handle RID_IS_FINAL.
+ (cp_parser_primary_expression, cp_parser_trait_expr): Likewise.
+ * semantics.c (trait_expr_value, finish_trait_expr): Handle
+ CPTK_IS_FINAL.
+ * cxx-pretty-print.c (pp_cxx_trait_expression): Likewise.
+
+2011-12-14 Jason Merrill <jason@redhat.com>
+
+ PR c++/51554
+ * semantics.c (cxx_eval_indirect_ref): Fix sanity check.
+
+ PR c++/51248
+ * decl.c (copy_type_enum): Also update variants.
+ (finish_enum): Allow variants of complete enums.
+
+2011-12-14 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/51475
+ * call.c (struct conversion)<u.next>: Update comment.
+ (next_conversion): New static function.
+ (convert_like_real): Use it.
+
+ PR c++/51476
+ * pt.c (convert_nontype_argument): Don't call maybe_constant_value
+ for PTRMEM_CST nodes.
+
+2011-12-13 Jason Merrill <jason@redhat.com>
+
+ PR c++/51406
+ PR c++/51161
+ * typeck.c (build_static_cast_1): Fix cast of lvalue to
+ base rvalue reference.
+
+2011-12-13 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51464
+ * semantics.c (begin_lambda_type): Check begin_class_definition return
+ value for error_mark_node.
+ * parser.c (cp_parser_lambda_expression): Check begin_lambda_type
+ return value for error_mark_node.
+
+2011-12-13 Fabien Chêne <fabien@gcc.gnu.org>
+
+ PR c++/14258
+ * cp-tree.h (USING_DECL_TYPENAME_P): New macro.
+ * parser.c (cp_parser_nonclass_name): Handle using declarations
+ that refer to a dependent type.
+ (cp_parser_using_declaration): Set USING_DECL_TYPENAME_P to 1 if
+ the using declaration refers to a dependent type.
+
+2011-12-12 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/51496
+ * parser.c (cp_parser_omp_for_loop): When determining whether
+ to use cp_parser_omp_for_incr or cp_parser_expression and when
+ calling cp_parser_omp_for_incr, use real_decl instead of decl.
+
+2011-12-12 Torvald Riegel <triegel@redhat.com>
+
+ * semantics.c (finish_transaction_stmt, build_transaction_expr):
+ Accept new noexcept parameter and handle it.
+ * cp-tree.h (finish_transaction_stmt, build_transaction_expr): Adapt
+ declarations.
+ * parser.c (cp_parser_exception_specification_opt): Extract
+ noexcept-specification parsing to ...
+ (cp_parser_noexcept_specification_opt): ...here. Allow for parsing
+ non-constexpr noexcept arguments.
+ (cp_parser_transaction, cp_parser_transaction_expression): Parse
+ and handle noexcept-specifications.
+ (cp_parser_function_transaction): Adapt to finish_transaction_stmt
+ change.
+ * pt.c (tsubst_expr): Adapt to new noexcept parameters when
+ building transactions.
+
+2011-12-12 Torvald Riegel <triegel@redhat.com>
+
+ * cp-tree.def (MUST_NOT_THROW_EXPR): Add condition parameter.
+ * cp-tree.h (MUST_NOT_THROW_COND): New.
+ (build_must_not_throw_expr): Declare.
+ * dump.c (cp_dump_tree): Dump MUST_NOT_THROW_EXPR condition.
+ * except.c (build_must_not_throw_expr): New.
+ (initialize_handler_parm): Use it.
+ (begin_eh_spec_block, wrap_cleanups_r): Adapt to condition.
+ * pt.c (tsubst_expr): Handle MUST_NOT_THROW_EXPR.
+
+2011-12-12 Richard Guenther <rguenther@suse.de>
+
+ PR lto/51262
+ * tree.c (cp_free_lang_data): No longer clear anonymous names.
+
+2011-12-09 Jason Merrill <jason@redhat.com>
+
+ PR c++/51151
+ * call.c (perform_implicit_conversion_flags): Remove earlier kludge.
+ * parser.c (cp_parser_omp_for_loop): Use cp_parser_omp_for_incr
+ in templates even if decl isn't type-dependent.
+
+2011-12-09 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/51289
+ * cp-tree.h (TYPE_TEMPLATE_INFO): Rewrite this accessor macro to
+ better support aliased types.
+ (TYPE_ALIAS_P): Don't crash on TYPE_NAME nodes that are not
+ TYPE_DECL.
+ * pt.c (find_parameter_packs_r): Handle types aliases.
+ (push_template_decl_real): Check for bare parameter packs in the
+ underlying type of an alias template.
+
+2011-12-08 Jason Merrill <jason@redhat.com>
+
+ PR c++/51318
+ * typeck.c (build_x_conditional_expr): Restrict glvalue games to C++11.
+
+ PR c++/51459
+ * pt.c (tsubst_expr) [DECL_EXPR]: Handle capture proxies properly.
+ * semantics.c (insert_capture_proxy): No longer static.
+ * cp-tree.h: Declare it.
+
+2011-12-07 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/51401
+ * decl.c (grokdeclarator): Error for auto on non-static data members.
+
+ PR c++/51429
+ * typeck2.c (cxx_incomplete_type_diagnostic): Don't
+ ICE if TREE_OPERAND (value, 1) is overloaded.
+
+ PR c++/51229
+ * decl.c (reshape_init_class): Complain if d->cur->index is
+ INTEGER_CST.
+ * parser.c (cp_parser_initializer_list): If cp_parser_parse_definitely
+ fails, clear designator.
+
+ PR c++/51369
+ * init.c (build_value_init): Allow array types even when
+ processing_template_decl.
+
+2011-12-07 Ed Smith-Rowland <3dw4rd@verizon.net>
+
+ PR c++/51420
+ * parser.c (lookup_literal_operator): Check that declaration is an
+ overloaded function.
+
+2011-12-06 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/51430
+ * pt.c (tsubst_decl): Don't call strip_array_domain on
+ error_mark_node.
+
+2011-12-06 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51431
+ * init.c (build_value_init): Check build_aggr_init_expr return
+ value for error_mark_node.
+
+2011-12-06 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/51427
+ * parser.c (cp_parser_check_class_key): Add note about earlier
+ declaration.
+
+2011-12-05 Fabien Chêne <fabien@gcc.gnu.org>
+
+ PR c++/51319
+ * semantics.c (finish_id_expression): Strip using declarations
+ early in the function.
+
+2011-12-05 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51399
+ * init.c (perform_member_init): Early return if init is error_mark_node.
+
+2011-12-05 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51414
+ * semantics.c (finish_underlying_type): Use %qT, not %qE for the
+ error message.
+
+2011-12-05 Jason Merrill <jason@redhat.com>
+
+ * init.c (expand_default_init): Unshare args in ctor delegation.
+
+2011-12-05 Ville Voutilainen <ville.voutilainen@gmail.com>
+ Pedro Lamarão <pedro.lamarao@gmail.com>
+
+ Implement C++11 delegating constructors.
+ * cp-tree.h (enum cpp0x_warn_str): Add CPP0X_DELEGATING_CTORS.
+ * error.c (maybe_warn_cpp0x): Adjust.
+ * parser.c (cp_parser_mem_initializer_list): Use it. Diagnose
+ multiple initializers if a delegating initializer is present.
+ * call.c (build_special_member_call): Convert an assert into an if.
+ * init.c (perform_target_ctor): New.
+ (emit_mem_initializers): Use it.
+ (expand_member_init, expand_default_init): Adjust.
+
+2011-12-05 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51404
+ * typeck2.c (build_functional_cast): Early return error_mark_node
+ for invalid uses of 'auto'.
+ * parser.c (cp_parser_direct_declarator): When
+ cp_parser_constant_expression returns error do not produce further
+ diagnostic for the bound.
+
+2011-12-03 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51313
+ * call.c (null_ptr_cst_p): STRIP_NOPS in c++11 mode too.
+
+2011-12-01 Jason Merrill <jason@redhat.com>
+
+ * call.c (build_new_method_call_1): Handle aggregate initialization.
+ * tree.c (stabilize_init): Handle CONSTRUCTOR.
+
+2011-12-01 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51326
+ * call.c (build_user_type_conversion_1): Early return NULL if
+ expr is NULL_TREE.
+
+2011-12-01 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51367
+ * pt.c (unify_inconsistency): Use either %qT or %qE depending on
+ whether parm is a type or non-type parameter.
+
+2011-11-30 Jason Merrill <jason@redhat.com>
+
+ PR c++/51009
+ * name-lookup.c (push_to_top_level): Set stmts_are_full_exprs_p.
+ * decl.c (build_aggr_init_full_exprs): Just assert that it's true.
+ (check_initializer): Here too.
+
+2011-11-30 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51299
+ * rtti.c (ifnonnull): Use nullptr_node.
+ (build_dynamic_cast_1): Call cp_truthvalue_conversion instead
+ of c_common_truthvalue_conversion.
+
+2011-11-24 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51227
+ * pt.c (instantiate_class_template_1): If lambda_function (type)
+ is NULL_TREE do not instantiate_decl.
+
+2011-11-24 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51290
+ * class.c (build_base_path): For the null pointer check use
+ nullptr_node instead of integer_zero_node.
+
+2011-11-22 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/51145
+ * decl.c (check_elaborated_type_specifier): Gracefully handle
+ error_mark_node. Accept bound template template parameters.
+ Update diagnostics for alias template specializations. Update
+ comment.
+ * parser.c (cp_parser_elaborated_type_specifier): Use
+ check_elaborated_type_specifier for simple-template-ids as well.
+
+2011-11-22 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51265
+ * semantics.c (finish_decltype_type): Handle PTRMEM_CST.
+
+2011-11-22 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/51143
+ * parser.c (cp_parser_alias_declaration): Don't allow type
+ definition in templates.
+
+2011-11-22 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51196
+ * typeck.c (cp_build_binary_op, [case EQ_EXPR]): For targets having
+ TARGET_PTRMEMFUNC_VBIT_LOCATION == ptrmemfunc_vbit_in_delta, do here
+ the -Wzero-as-null-pointer-constant warning for pmf == 0.
+
+2011-11-21 Torvald Riegel <triegel@redhat.com>
+
+ * pt.c (tsubst_copy_and_build): Handle TRANSACTION_EXPR.
+
+2011-11-21 Ed Smith-Rowland <3dw4rd@verizon.net>
+
+ PR c++/50958
+ * parser.c (lookup_literal_operator): New.
+ (cp_parser_userdef_char_literal): Use it.
+ (cp_parser_userdef_numeric_literal): Use it.
+ (cp_parser_userdef_string_literal): Use lookup_name.
+
+2011-11-20 Jason Merrill <jason@redhat.com>
+
+ * pt.c (tsubst_pack_expansion): Fix SFINAE.
+
+ PR c++/48322
+ * cp-tree.h (PACK_EXPANSION_EXTRA_ARGS): New.
+ * cp-tree.def (EXPR_PACK_EXPANSION): Add an operand for it.
+ * pt.c (tsubst_pack_expansion): Set and use it.
+ (iterative_hash_template_arg): Hash it.
+ (template_args_equal): Compare it.
+ (comp_template_args_with_info): Handle nulls.
+ * tree.c (cp_walk_subtrees): Walk it.
+ * typeck.c (structural_comptypes): Compare it.
+ * ptree.c (cxx_print_type): Print it.
+
+ * pt.c (type_unification_real): Set input_location
+ during default arg instantiation.
+
+2011-11-20 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51230
+ * pt.c (unify_inconsistency): Handle non-type parameters better.
+ * error.c (dump_expr): Handle TEMPLATE_TEMPLATE_PARM.
+
+2011-11-20 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/51194
+ * pt.c (lookup_template_class_1): Go out early if the type of the
+ template is error_mark_node.
+
+2011-11-19 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51216
+ * semantics.c (potential_constant_expression_1): Handle IF_STMT,
+ DO_STMT, FOR_STMT, and WHILE_STMT.
+
+2011-11-18 Fabien Chêne <fabien@gcc.gnu.org>
+
+ PR c++/51188
+ * search.c (lookup_field_1): Handle USING_DECLs for the storted
+ case.
+
+2011-11-18 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51150
+ * pt.c (tsubst_copy_and_build): Handle FIX_TRUNC_EXPR.
+
+2011-11-18 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/51191
+ * pt.c (primary_template_instantiation_p): Don't forget to
+ consider alias declarations.
+
+2011-11-17 Jason Merrill <jason@redhat.com>
+
+ PR c++/51186
+ * decl.c (grokdeclarator): Improve C++98 trailing return diagnostic.
+
+ N3203
+ * class.c (add_implicitly_declared_members): Update move
+ conditions.
+
+ PR c++/51137
+ * class.c (build_base_path): Don't do calculation in templates.
+
+2011-11-15 Torvald Riegel <triegel@redhat.com>
+
+ * parser.c (cp_parser_transaction_expression): Require parentheses
+ when parsing transaction expressions.
+
+2011-11-14 Ed Smith-Rowland <3dw4rd@verizon.net>
+
+ PR c++/51107
+ * typeck.c (check_literal_operator_args): Add processing_specialization
+ to check for void template fn. Test for exact arity for non-template fn.
+
+2011-11-14 Fabien Chêne <fabien@gcc.gnu.org>
+
+ PR c++/6936
+ PR c++/25994
+ PR c++/26256
+ PR c++/30195
+ * search.c (lookup_field_1): Look through USING_DECL.
+ (lookup_field_r): Call lookup_fnfields_slot instead of
+ lookup_fnfields_1.
+ * semantics.c (finish_member_declaration): Remove the check that
+ prevents USING_DECLs from being verified by
+ pushdecl_class_level. Call add_method for using declarations that
+ designates functions if the using declaration is in a template
+ class. Set DECL_IGNORED_P on class-scope using declarations.
+ * typeck.c (build_class_member_access_expr): Handle USING_DECLs.
+ * class.c (check_field_decls): Keep using declarations.
+ (add_method): Remove two diagnostics about conflicting using
+ declarations.
+ * parser.c (cp_parser_nonclass_name): Handle USING_DECLs.
+ * decl.c (start_enum): Call xref_tag whenever possible.
+ * cp-tree.h (strip_using_decl): Declare, and reident the previous
+ function.
+ * name-lookup.c (strip_using_decl): New function.
+ (supplement_binding_1): Call strip_using_decl on decl and
+ bval. Perform most of the checks with USING_DECLs stripped. Also
+ check that the target decl and the target bval does not refer to
+ the same declaration. Allow pushing an enum multiple times in a
+ template class. Adjustment to diagnose using redeclarations. Call
+ diagnose_name_conflict.
+ (push_class_level_binding): Call strip_using_decl on decl and
+ bval. Perform most of the checks with USING_DECLs stripped. Return
+ true if both decl and bval refer to USING_DECLs and are dependent.
+ (diagnose_name_conflict): New function.
+
+2011-11-12 Jason Merrill <jason@redhat.com>
+
+ PR c++/986
+ * call.c (set_up_extended_ref_temp): Warn about references
+ bound to non-static reference members.
+ * init.c (perform_member_init): Pass in the member.
+
+ PR c++/51060
+ * cp-gimplify.c (cp_gimplify_expr): Leave clobbers alone.
+
+2011-11-11 Ed Smith-Rowland <3dw4rd@verizon.net>
+
+ PR c++/50976
+ * typeck.c (check_literal_operator_args): Reorganize test for string
+ operators so size_t search depends on finding string first.
+
+2011-11-10 Jason Merrill <jason@redhat.com>
+
+ PR c++/50372
+ * pt.c (convert_nontype_argument_function): Allow decls with
+ internal linkage in C++11.
+ (convert_nontype_argument): Likewise.
+
+ PR c++/50973
+ * decl2.c (mark_used): Defer synthesis of virtual functions.
+ * method.c (use_thunk): Make sure the target function has
+ DECL_INTERFACE_KNOWN.
+
+ PR c++/51079, DR 495
+ * call.c (joust): Check the second conversion sequence
+ before checking templates.
+
+2011-11-09 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50837
+ * pt.c (tsubst_copy_and_build) [IDENTIFIER_NODE]: In C++11 mode
+ pass allow_non_integral_constant_expression_p = true to
+ finish_id_expression.
+
+2011-11-09 Jason Merrill <jason@redhat.com>
+
+ PR c++/50972
+ * pt.c (maybe_instantiate_noexcept): Check the return value of
+ push_tinst_level.
+
+ PR c++/51046
+ * parser.c (cp_parser_range_for): check_for_bare_parameter_packs.
+
+ PR c++/51029
+ * class.c (build_base_path): Don't ICE in fold_non_dependent_expr.
+
+ * Make-lang.in (check_g++_parallelize): Add dg-torture.exp.
+ (check-c++0x): Obsolete.
+
+ * pt.c (invalid_nontype_parm_type_p): Avoid printing "<type error>".
+
+ * pt.c (convert_nontype_argument): Only integral arguments
+ get early folding.
+
+ * parser.c (cp_parser_alias_declaration): Don't do semantic
+ processing if parsing failed.
+
+2011-11-09 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51045
+ * init.c (build_new_1, build_vec_delete_1, build_delete):
+ Use nullptr_node.
+
+2011-11-09 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/51047
+ * search.c (lookup_member): Change to take also a tsubst_flags_t
+ parameter.
+ (lookup_field, lookup_fnfields): Adjust calls.
+ * typeck.c (lookup_destructor, finish_class_member_access_expr,
+ build_ptrmemfunc_access_expr): Likewise.
+ * class.c (handle_using_decl, maybe_note_name_used_in_class):
+ Likewise.
+ * pt.c (resolve_typename_type): Likewise.
+ * semantics.c (lambda_function): Likewise.
+ * parser.c (cp_parser_perform_range_for_lookup,
+ cp_parser_lookup_name): Likewise.
+ * friend.c (make_friend_class): Likewise.
+ * name-lookup.c (pushdecl_maybe_friend_1, get_class_binding,
+ do_class_using_decl, lookup_qualified_name): Likewise.
+ * cp-tree.h (lookup_member): Adjust declaration.
+
+2011-11-09 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/51043
+ * cp-tree.h (TYPE_ALIAS_P, TYPE_TEMPLATE_INFO): Don't crash on
+ NULL TYPE_NAME.
+
+ PR c++/51027
+ * parser.c (cp_parser_alias_declaration): Require ';' at the end
+ of the declaration.
+
+2011-11-09 Dodji Seketeli <dodji@redhat.com>
+
+ PR debug/51032
+ * decl2.c (check_member_template): Accept alias templates and ...
+ * parser.c (cp_parser_alias_declaration): ... use it here.
+
+2011-11-08 Jason Merrill <jason@redhat.com>
+
+ PR c++/50835
+ * typeck.c (build_x_conditional_expr): Preserve lvalue/xvalueness.
+ * tree.c (lvalue_kind) [NON_DEPENDENT_EXPR]: Return clk_ordinary
+ in C++98.
+
+2011-11-08 Richard Guenther <rguenther@suse.de>
+
+ PR middle-end/51010
+ * error.c (dump_expr): Handle SSA_NAMEs.
+
+2011-11-07 Richard Henderson <rth@redhat.com>
+ Aldy Hernandez <aldyh@redhat.com>
+ Torvald Riegel <triegel@redhat.com>
+
+ Merged from transactional-memory.
+
+ * call.c (build_new_function_call): Call tm_malloc_replacement.
+ * class.c (check_bases): Compute transaction attributes for the
+ class based on its base classes.
+ (look_for_tm_attr_overrides, set_one_vmethod_tm_attributes,
+ set_method_tm_attributes): New.
+ (finish_struct_1): Call set_method_tm_attributes.
+ * cp-tree.h (begin_transaction_stmt, finish_transaction_stmt,
+ build_transaction_expr): Declare.
+ (TRANSACTION_EXPR_IS_STMT): New.
+ * decl.c (push_cp_library_fn): Set attribute to transaction_safe.
+ * except.c (do_get_exception_ptr): Apply transaction_pure.
+ (do_begin_catch): Mark _ITM_cxa_begin_catch transaction_pure and
+ record as transactional-memory wrapper.
+ (do_end_catch): Similarly for _ITM_cxa_end_catch.
+ (do_allocate_exception): Similarly for _ITM_cxa_allocate_exception.
+ (build_throw): Similarly for _ITM_cxa_throw. Make __cxa_rethrow pure.
+ * parser.h (struct cp_parser): Add in_transaction flag.
+ * parser.c (enum non_integral_constant): Add NIC_TRANSACTION.
+ (cp_parser_non_integral_constant_expression): Handle NIC_TRANSACTION.
+ (enum required_token): Add transaction tokens.
+ (cp_parser_transaction, cp_parser_transaction_expression,
+ cp_parser_function_transaction, cp_parser_transaction_cancel,
+ cp_parser_txn_attribute_opt): New.
+ (cp_parser_unary_expression): Handle RID_TRANSACTION*.
+ (cp_parser_statement, cp_parser_function_definition_after_declarator,
+ cp_parser_token_starts_function_definition_p): Same.
+ (cp_parser_required_error): Handle RT_TRANSACTION*.
+ * pt.c (tsubst_expr): Handle TRANSACTION_EXPR.
+ * semantics.c (begin_transaction_stmt, finish_transaction_stmt,
+ build_transaction_expr): New.
+
+2011-11-08 Dodji Seketeli <dodji@redhat.com>
+
+ Fix context handling of alias-declaration
+ * decl.c (start_decl): Update comment.
+ * error.c (dump_alias_template_specialization): Dump the context
+ of the specialization.
+ * parser.c (cp_parser_alias_declaration): Call pop_scope on the
+ pushed scope yielded by start_decl.
+
+2011-11-08 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50864
+ * parser.c (cp_parser_postfix_dot_deref_expression): Reject invalid
+ uses of '->' and '.' as postfix-expression in namespace scope.
+
+2011-11-07 Jason Merrill <jason@redhat.com>
+
+ PR c++/50848
+ * pt.c (tsubst_copy_and_build) [CALL_EXPR]: Don't crash
+ if lookup finds a non-function.
+
+ PR c++/50863
+ * parser.c (cp_parser_initializer_list): Parse C99
+ array designators tentatively.
+
+ PR c++/50870
+ * pt.c (tsubst_copy): Handle NAMESPACE_DECL.
+ (tsubst_copy_and_build) [COMPONENT_REF]: Handle a still-dependent
+ object.
+
+2011-11-07 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * pt.c (tsubst_copy_and_build): Fix qualified_name_lookup_error
+ call in case COMPONENT_REF.
+
+2011-11-07 Jason Merrill <jason@redhat.com>
+ Dodji Seketeli <dodji@redhat.com>
+
+ Support C++11 alias-declaration
+ PR c++/45114
+ * cp-tree.h (TYPE_DECL_ALIAS_P, TYPE_ALIAS_P)
+ (DECL_TYPE_TEMPLATE_P, DECL_ALIAS_TEMPLATE_P): New accessor
+ macros.
+ (TYPE_TEMPLATE_INFO): Get template info of an alias template
+ specializations from its TYPE_DECL.
+ (SET_TYPE_TEMPLATE_INFO): Set template info of alias template
+ specializations into its TYPE_DECL.
+ (DECL_CLASS_TEMPLATE_P): Re-write using the new
+ DECL_TYPE_TEMPLATE_P.
+ (enum cp_decl_spec): Add new ds_alias enumerator.
+ (alias_type_or_template_p, alias_template_specialization_p):
+ Declare new functions.
+ * parser.c (cp_parser_alias_declaration): New static function.
+ (cp_parser_check_decl_spec): Add "using" name for the `alias'
+ declspec.
+ (cp_parser_type_name): Update comment. Support simple-template-id
+ representing alias template specializations in c++0x mode.
+ (cp_parser_qualifying_entity): Update comment. Use
+ cp_parser_type_name.
+ (cp_parser_block_declaration): Handle alias-declaration in c++11.
+ Update comment.
+ (cp_parser_template_id): Handle specializations of alias
+ templates.
+ (cp_parser_member_declaration): Add alias-declaration production
+ to comment. Support alias-declarations.
+ (cp_parser_template_declaration_after_export): Handle alias
+ templates in c++11.
+ * decl.c (make_typename_type, make_unbound_class_template): Accept
+ alias templates.
+ (grokdeclarator): Set TYPE_DECL_ALIAS_P on alias
+ declarations.
+ * decl2.c (grokfield): Move template creation after setting up the
+ TYPE_DECL of the alias, so that the TEMPLATE_DECL of the alias
+ template actually carries the right type-id of the alias
+ declaration.
+ * pt.c (alias_type_or_template_p)
+ (alias_template_specialization_p): Define new public functions.
+ (maybe_process_partial_specialization): Reject partial
+ specializations of alias templates.
+ (primary_template_instantiation_p): Consider alias template
+ instantiations.
+ (push_template_decl_real): Assert that TYPE_DECLs of alias
+ templates are different from those of class template. Store
+ template info onto the TYPE_DECL of the alias template.
+ (convert_template_argument): Strip aliases from template
+ arguments.
+ (lookup_template_class_1): Handle the creation of the
+ specialization of an alias template.
+ (tsubst_decl): Create a substituted copy of the TYPE_DECL of an
+ member alias template.
+ (tsubst): Handle substituting into the type of an alias template.
+ Handle substituting UNBOUND_CLASS_TEMPLATE into
+ BOUND_TEMPLATE_TEMPLATE_PARM.
+ (do_type_instantiation): Better diagnostics when trying to
+ explicitely instantiate a non-class template.
+ * search.c (lookup_field_1, lookup_field_r): Support looking up
+ alias templates.
+ * semantics.c (finish_template_type): For instantiations of alias
+ templates, return the TYPE_DECL of the actual alias and not the
+ one of the aliased type.
+ * error.c (dump_alias_template_specialization): New static
+ function.
+ (dump_type): Handle printing of alias templates and their
+ specializations. templates.
+ (dump_aggr_type): For specialization of alias templates, fetch
+ arguments from the right place.
+ (dump_decl): Print an alias-declaration like `using decl = type;'
+ (dump_template_decl): Support printing of alias templates.
+
+2011-11-07 Jason Merrill <jason@redhat.com>
+
+ PR c++/35688
+ * decl2.c (constrain_visibility): Return void. Add tmpl parm
+ which gives the constraint priority over an attribute.
+ (constrain_visibility_for_template, determine_visibility): Adjust.
+ * pt.c (instantiate_class_template_1): Call determine_visibility.
+
+ PR c++/33255
+ * decl.c (save_function_data): Clear local_typedefs.
+
+ * decl.c (cp_finish_decl): Only make_tree_vector if we're calling
+ check_initializer.
+
+2011-11-06 Jason Merrill <jason@redhat.com>
+
+ PR c++/35688
+ * decl2.c (constrain_visibility): Check decl_has_visibility_attr
+ rather than DECL_VISIBILITY_SPECIFIED.
+
+2011-11-06 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/47695
+ * decl2.c (mark_used): Early return false after error or sorry.
+ * cp-tree.h (mark_used): Adjust declaration.
+ * semantics.c (finish_id_expression): Check mark_used return value.
+
+2011-11-05 Jason Merrill <jason@redhat.com>
+
+ PR c++/48370
+ * decl.c (cp_finish_decl): Mostly revert previous change.
+
+2011-11-04 Jason Merrill <jason@redhat.com>
+
+ PR c++/26714
+ * init.c (perform_member_init): Strip TARGET_EXPR around NSDMI.
+ Do temporary lifetime extension.
+
+ PR c++/48370
+ * decl.c (cp_finish_decl): Run cleanups in the right order.
+
+2011-11-04 Eric Botcazou <ebotcazou@adacore.com>
+
+ PR c++/50608
+ * semantics.c (finish_offsetof): Adjust call to fold_offsetof.
+ * typeck.c (cp_build_addr_expr_1): Call fold_offsetof_1.
+
+2011-11-04 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * typeck.c (build_indirect_ref): Use ATTRIBUTE_UNUSED.
+ * mangle.c (write_unnamed_type_name): Likewise.
+
+2011-11-04 Magnus Fromreide <magfr@lysator.liu.se>
+
+ * parser.c (cp_parser_enumerator_list): Do not warn about
+ trailing commas in C++0x mode.
+
+2011-11-04 Olivier Goffart <olivier@woboq.com>
+ Jason Merrill <jason@redhat.com>
+
+ PR c++/50965
+ * class.c (check_field_decls): NSDMI makes a class non-aggregate.
+
+2011-11-04 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/48420
+ * call.c (conversion_null_warnings): For 'false' to NULL pointer,
+ just check that TREE_TYPE (expr) is a BOOLEAN_TYPE.
+
+2011-11-04 Ed Smith-Rowland <3dw4rd@verizon.net>
+
+ PR c++/50941
+ * parser.c (cp_parser_userdef_string_literal): Fix string length.
+
+2011-11-04 Jason Merrill <jason@redhat.com>
+
+ PR c++/48370
+ * call.c (extend_ref_init_temps, extend_ref_init_temps_1): New.
+ (set_up_extended_ref_temp): Use it. Change cleanup parm to VEC.
+ (initialize_reference): Just call convert_like.
+ * decl.c (grok_reference_init): Just call initialize_reference.
+ (build_init_list_var_init): Remove.
+ (check_initializer): Change cleanup parm to VEC. Handle references
+ like other types. Call perform_implicit_conversion instead
+ of build_init_list_var_init. Don't use build_aggr_init for
+ aggregate initialization of arrays.
+ (cp_finish_decl): Change cleanup to VEC.
+ * typeck2.c (store_init_value): Call extend_ref_init_temps.
+ Use build_vec_init for non-constant arrays.
+ * init.c (expand_aggr_init_1): Adjust.
+ (build_vec_init): Avoid re-converting an initializer
+ that's already digested.
+ * mangle.c (mangle_ref_init_variable): Add a discriminator.
+ * cp-tree.h: Adjust.
+ * typeck.c (convert_for_initialization): Adjust.
+ * decl2.c (maybe_emit_vtables): Adjust.
+
+2011-11-02 Jason Merrill <jason@redhat.com>
+
+ PR c++/50930
+ * init.c (build_aggr_init): Don't set LOOKUP_ONLYCONVERTING
+ if the initializer has TARGET_EXPR_DIRECT_INIT_P.
+ (expand_default_init): An initializer with TARGET_EXPR_DIRECT_INIT_P
+ or TARGET_EXPR_LIST_INIT_P doesn't need more processing.
+ * tree.c (bot_manip): Propagate TARGET_EXPR_IMPLICIT_P,
+ TARGET_EXPR_LIST_INIT_P, TARGET_EXPR_DIRECT_INIT_P.
+ * call.c (convert_like_real): Set TARGET_EXPR_DIRECT_INIT_P
+ as appropriate on list-value-initialization.
+
+ * parser.c (cp_parser_decl_specifier_seq): Change "C++0x" to
+ "C++11" in warnings.
+ (cp_lexer_get_preprocessor_token): Likewise.
+ (cp_parser_binary_expression): Likewise.
+
+2011-11-02 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50810
+ * typeck2.c (check_narrowing): Adjust OPT_Wnarrowing diagnostics.
+ (digest_init_r): Call check_narrowing irrespective of the C++ dialect.
+ * decl.c (check_initializer): Likewise.
+ * semantics.c (finish_compound_literal): Likewise.
+
+2011-11-02 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50956
+ * typeck.c (build_const_cast_1): Fix -Wcast-qual for false
+ comp_ptr_ttypes_const.
+
+2011-11-02 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
+
+ * Make-lang.in (g++spec.o): Pass SHLIB instead of SHLIB_LINK.
+
+2011-11-01 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/44277
+ * cvt.c (cp_convert_to_pointer): Warn for zero as null pointer
+ constant.
+ * typeck.c (cp_truthvalue_conversion): Handle pointers and member
+ function pointers under c_inhibit_evaluation_warnings; use
+ nullptr_node for data member pointers.
+ (cp_build_binary_op): Tweak, just forward to cp_convert op1,
+ either a nullptr_node or an integer_zero_node.
+ (build_ptrmemfunc): Use nullptr_node.
+ * init.c (build_zero_init_1): Likewise.
+
+2011-11-01 Jason Merrill <jason@redhat.com>
+
+ PR c++/50500
+ DR 1082
+ * search.c (lookup_fnfields_idx_nolazy): Split out from...
+ (lookup_fnfields_1): ...here.
+ (lookup_fnfields_slot_nolazy): Use it.
+ * cp-tree.h: Declare it.
+ * class.c (type_has_move_assign): Use it.
+ (type_has_user_declared_move_assign): Likewise.
+
+2011-10-31 Jason Merrill <jason@redhat.com>
+
+ PR c++/50920
+ * class.c (check_field_decl): Change c++0x in diags to c++11.
+ * error.c (maybe_warn_cpp0x): Likewise.
+ * parser.c (cp_parser_diagnose_invalid_type_name): Likewise.
+ * pt.c (check_default_tmpl_args): Likewise.
+
+2011-10-31 Diego Novillo <dnovillo@google.com>
+
+ * mangle.c (get_mangled_id): Factor from ...
+ (mangle_decl): ... here.
+ Call get_mangled_id.
+
+2011-10-25 Gerald Pfeifer <gerald@pfeifer.com>
+
+ * NEWS (GCC 2.95): Refer to GNU/Linux instead of Linux.
+ (EGCS 1.0): Ditto.
+
+2011-10-29 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50901
+ * call.c (build_new_op_1): Handle ABS_EXPR together with the
+ other unary EXPR.
+
+2011-10-28 Paolo Carlini <paolo.carlini@oracle.com>
+
+ Revert:
+ 2011-10-28 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50864
+ * pt.c (tsubst_copy_and_build): Fix qualified_name_lookup_error
+ call in case COMPONENT_REF.
+
+2011-10-28 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * pt.c (unify_pack_expansion): Initialize bad_old_arg and bad_new_arg.
+
+2011-10-28 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50864
+ * pt.c (tsubst_copy_and_build): Fix qualified_name_lookup_error
+ call in case COMPONENT_REF.
+
+2011-10-27 Jason Merrill <jason@redhat.com>
+
+ * semantics.c (cxx_eval_outermost_constant_expr): Check
+ cp_has_mutable_p.
+ (cxx_eval_component_reference): Check DECL_MUTABLE_P.
+
+2011-10-27 Roberto Agostino Vitillo <ravitillo@lbl.gov>
+
+ PR c++/30066
+ * decl2.c (determine_hidden_inline): New function.
+ (determine_visibility): fvisibility-inlines-hidden affects inline
+ functions.
+
+2011-10-27 Dodji Seketeli <dodji@redhat.com>
+
+ * cp-tree.h (DECL_DECLARES_TYPE_P): Fix comment.
+
+2011-10-26 Jason Merrill <jason@redhat.com>
+
+ * typeck.c (check_literal_operator_args): Avoid building types.
+
+2011-10-26 Ed Smith-Rowland <3dw4rd@verizon.net>
+
+ Implement C++11 user-defined literals.
+ * cp-objcp-common.c: (cp_tree_size) Return size of USERDEF_LITERAL tree.
+ * cp-tree.h: (UDLIT_OP_*, UDLIT_OPER_P): Literal operator
+ name tools. New tree code for user-defined literals.
+ * cxx-pretty-print.h: (pp_cxx_userdef_literal) New.
+ * cxx-pretty-print.c: (pp_cxx_userdef_literal) New.
+ (pp_cxx_primary_expression, pp_cxx_expression): Use it.
+ * decl.c: (cp_tree_node_structure): Return new tree code.
+ (duplicate_decls): Check for raw vs. template operator conflicts.
+ (grokfndecl, grokdeclarator): New checks for literal operators.
+ * error.c: (dump_expr): Warn about user-defined literals
+ in C++98 mode. (dump_function_name): Pretty printing.
+ * mangle.c: (write_literal_operator_name): New.
+ (write_unqualified_id, write_unqualified_name): Use it.
+ * parser.c: (cp_parser_operator): Handle operator"".
+ (cp_parser_userdef_char_literal, cp_parser_userdef_numeric_literal,
+ cp_parser_userdef_string_literal): New.
+ (cp_parser_primary_expression): Handle new user-defined literal tokens
+ with new functions.
+ * semantics.c: (potential_constant_expression_1): Add
+ user-defined literals.
+ * typeck.c (check_raw_literal_operator,
+ check_literal_operator_args): New.
+
+2011-10-26 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * typeck.c (cp_build_addr_expr_1): Use BASELINK_P.
+ * class.c (instantiate_type): Likewise.
+ * pt.c (convert_nontype_argument_function, uses_template_parms,
+ tsubst_copy, resolve_nondeduced_context, type_dependent_expression_p):
+ Likewise.
+ * semantics.c (finish_decltype_type): Likewise.
+ * decl2.c (mark_used): Likewise.
+ * name-lookup.c (arg_assoc): Likewise.
+
+2011-10-26 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50870
+ * typeck.c (non_reference): Pass NULL_TREE through.
+
+2011-10-25 Jason Merrill <jason@redhat.com>
+
+ PR c++/50866
+ PR c++/41449
+ * semantics.c (maybe_cleanup_point_expr_void): No longer static.
+ * typeck2.c (split_nonconstant_init_1): Use it.
+ * cp-tree.h: Declare it.
+ * decl.c (wrap_cleanups_r): Stop at CLEANUP_POINT_EXPR.
+
+ PR c++/49996
+ * tree.c (stabilize_init): Stabilize scalar elements of a
+ CONSTRUCTOR, too.
+
+2011-10-25 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50858
+ * typeck.c (composite_pointer_type_r): Check return value of
+ composite_pointer_type_r for error_mark_node.
+
+2011-10-25 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50861
+ * pt.c (tsubst_copy_and_build): Check return value of
+ tsubst_copy_and_build for error_mark_node.
+
+2011-10-23 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50841
+ Revert:
+ 2011-10-23 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50810
+ * typeck2.c (check_narrowing): Adjust OPT_Wnarrowing diagnostics.
+ (digest_init_r): Call check_narrowing irrespective of the C++ dialect.
+ * decl.c (check_initializer): Likewise.
+ * semantics.c (finish_compound_literal): Likewise.
+
+2011-10-23 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50810
+ * typeck2.c (check_narrowing): Adjust OPT_Wnarrowing diagnostics.
+ (digest_init_r): Call check_narrowing irrespective of the C++ dialect.
+ * decl.c (check_initializer): Likewise.
+ * semantics.c (finish_compound_literal): Likewise.
+
+2011-10-21 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/45385
+ * init.c (build_vec_init): Early return error_mark_node if
+ maxindex is -1.
+
+2011-10-21 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/31423
+ * typeck2.c (cxx_incomplete_type_diagnostic): Improve error message
+ for invalid use of member function.
+
+2011-10-21 Ville Voutilainen <ville.voutilainen@gmail.com>
+
+ PR c++/50811
+ * parser.c (cp_parser_class_head): Parse virt-specifiers
+ regardless of whether an id is present
+
+2011-10-20 Jason Merrill <jason@redhat.com>
+
+ PR c++/41449
+ * typeck2.c (split_nonconstant_init_1): Handle EH cleanup of
+ initialized subobjects.
+
+2011-10-19 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/13657
+ * class.c (instantiate_type): Fix error message.
+
+2011-10-19 Jason Merrill <jason@redhat.com>
+
+ PR c++/50793
+ * tree.c (bot_manip): Propagate AGGR_INIT_ZERO_FIRST.
+
+2011-10-19 Roland Stigge <stigge@antcom.de>
+
+ PR translation/49704
+ * semantics.c (potential_constant_expression_1): Use "AST" instead of
+ "ast" in sorry message.
+
+2011-10-19 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/38761
+ PR c++/40872
+ * decl.c (duplicate_decls, make_typename_type, grokdeclarator): Use
+ G_() in error message strings to facilitate translation.
+ * semantics.c (finish_id_expression): Likewise.
+ * parser.c (cp_parser_nested_name_specifier_opt,
+ cp_parser_parameter_declaration): Likewise.
+
+2011-10-18 Jason Merrill <jason@redhat.com>
+
+ PR c++/50531
+ * pt.c (instantiate_decl): Recognize when a function defaulted
+ outside the class is already instantiated.
+
+ PR c++/50742
+ * decl.c (check_previous_goto_1): Handle using-decl.
+
+2011-10-18 Jason Merrill <jason@redhat.com>
+
+ PR c++/50500
+ DR 1082
+ * class.c (type_has_user_declared_move_constructor): New.
+ (type_has_user_declared_move_assign): New.
+ (add_implicitly_declared_members): Add lazy copy ops
+ even if there's a move.
+ * method.c (lazily_declare_fn): Delete implicit copies
+ if there's a move.
+ (maybe_explain_implicit_delete): Explain this. Use inform rather
+ than error.
+ * cp-tree.h: Declare new fns.
+
+2011-10-18 Diego Novillo <dnovillo@google.com>
+
+ * parser.c: Remove ENABLE_CHECKING markers around debugging
+ routines.
+ (cp_lexer_dump_tokens): Add arguments START_TOKEN and CURR_TOKEN.
+ Make static
+ When printing CURR_TOKEN surround it in [[ ]].
+ Start printing at START_TOKEN.
+ Update all users.
+ (cp_debug_print_tree_if_set): New.
+ (cp_debug_print_context): New.
+ (cp_debug_print_context_stack): New.
+ (cp_debug_print_flag): New.
+ (cp_debug_print_unparsed_function): New.
+ (cp_debug_print_unparsed_queues): New.
+ (cp_debug_parser_tokens): New.
+ (cp_debug_parser): New.
+ (cp_lexer_start_debugging): Set cp_lexer_debug_stream to stderr.
+ (cp_lexer_stop_debugging): Set cp_lexer_debug_stream to NULL.
+ * parser.h (cp_lexer_dump_tokens): Remove declaration.
+ (cp_debug_parser): Declare.
+
+2011-10-17 Michael Spertus <mike_spertus@symantec.com>
+
+ * cp-tree.def: Add BASES as a new tree code.
+ * cp-tree.h (enum cp_trait_kind): Add CPTK_BASES, CPTK_DIRECT_BASES.
+ (BASES_TYPE, BASES_DIRECT): Define.
+ (calculate_bases, finish_bases, calculate_direct_bases): Declare.
+ * parser.c (cp_parser_trait_expr, cp_parser_template_argument_list,
+ (cp_parser_simple_type_specifier, cp_parser_save_nsdmi): Use them.
+ * pt.c (find_parameter_packs_r, tsubst_pack_expansion): Likewise.
+ * semantics.c (calculate_bases, finish_bases, calculate_direct_bases,
+ dfs_calculate_bases_pre, dfs_calculate_bases_post,
+ calculate_bases_helper): Define.
+
+2011-10-17 Jason Merrill <jason@redhat.com>
+
+ PR c++/50736
+ * parser.c (cp_parser_lambda_introducer): Check for more
+ invalid captures.
+
+2011-10-17 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/44524
+ * typeck.c (build_class_member_access_expr): Provide a better error
+ message for X.Y where X is a pointer to class type.
+ (finish_class_member_access_expr): Likewise.
+
+2011-10-15 Tom Tromey <tromey@redhat.com>
+ Dodji Seketeli <dodji@redhat.com>
+
+ * error.c (cp_diagnostic_starter): Pass the relevant location to
+ diagnostic_report_current_module.
+ (cp_diagnostic_finalizer): Call virt_loc_aware_diagnostic_finalizer.
+
+2011-10-17 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/48489
+ * typeck.c (finish_class_member_access_expr): Fix error call
+ for TREE_CODE (access_path) == TREE_BINFO.
+
+2011-10-15 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50732
+ * semantics.c (finish_trait_expr): Do not try to instantiate the
+ the base type of an __is_base_of trait.
+ (check_trait_type): Return a tree; use complete_type_or_else.
+
+2011-10-14 Jason Merrill <jason@redhat.com>
+
+ PR c++/50563
+ * parser.c (cp_parser_cache_group): Handle end==CPP_COMMA.
+ (cp_parser_save_nsdmi): Pass it.
+
+ PR c++/50707
+ * method.c (walk_field_subobs): Check for NSDMI before
+ complaining about uninitialized fields.
+
+ * pt.c (tsubst_decl) [FIELD_DECL]: Use void_zero_node
+ instead of error_mark_node as a placeholder.
+
+2011-10-14 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/38174
+ * call.c (add_builtin_candidate): If two pointers have a composite
+ pointer type, generate a single candidate with that type.
+
+2011-10-13 Jason Merrill <jason@redhat.com>
+
+ PR c++/50614
+ * cp-tree.h (VAR_TEMPL_TYPE_FIELD_OR_FUNCTION_DECL_CHECK): New.
+ (DECL_TEMPLATE_INFO): Use it.
+ * pt.c (tsubst_decl) [FIELD_DECL]: Set DECL_TEMPLATE_INFO
+ if the decl has an NSDMI.
+ * init.c (perform_member_init): Use it.
+
+ PR c++/50437
+ * cp-tree.h (struct tree_lambda_expr): Add closure field.
+ (LAMBDA_EXPR_CLOSURE): New.
+ * pt.c (tsubst_copy_and_build) [LAMBDA_EXPR]: Likewise.
+ * semantics.c (build_lambda_object): Use it instead of TREE_TYPE.
+ (begin_lambda_type, lambda_function, add_capture): Likewise.
+ (add_default_capture, lambda_expr_this_capture): Likewise.
+
+2011-10-13 Diego Novillo <dnovillo@google.com>
+
+ * cp-tree.h (struct language_function): Rename in_function_try_handler
+ to x_in_function_try_handler.
+ Rename in_base_initializer to x_in_base_initializer.
+ Update all users.
+
+2011-10-13 Diego Novillo <dnovillo@google.com>
+
+ * class.c (sorted_fields_type_new): Factor out of ...
+ (finish_struct_1): ... here.
+
+2011-10-13 Jason Merrill <jason@redhat.com>
+
+ PR c++/50618
+ * init.c (expand_aggr_init_1): Don't zero-initialize virtual
+ bases of a base subobject.
+
+2011-10-12 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50594
+ * decl.c (cxx_init_decl_processing): Add
+ __attribute__((externally_visible)) to operator new and
+ operator delete library fn.
+
+2011-10-11 Michael Meissner <meissner@linux.vnet.ibm.com>
+
+ * decl.c (duplicate_decls): Delete old interface with two parallel
+ arrays to hold standard builtin declarations, and replace it with
+ a function based interface that can support creating builtins on
+ the fly in the future. Change all uses, and poison the old
+ names. Make sure 0 is not a legitimate builtin index.
+ * except.c (build_eh_type_type): Ditto.
+ (choose_personality_routine): Ditto.
+ * semantics.c (finish_omp_atomic): Ditto.
+ (finish_omp_barrier): Ditto.
+ (finish_omp_flush): Ditto.
+ (finish_omp_taskwait): Ditto.
+
+2011-10-11 Jason Merrill <jason@redhat.com>
+
+ PR c++/49855
+ PR c++/49896
+ * cp-tree.def (IMPLICIT_CONV_EXPR): New.
+ * call.c (perform_implicit_conversion_flags): Build it
+ instead of NOP_EXPR.
+ * cp-objcp-common.c (cp_common_init_ts): It's typed.
+ * cxx-pretty-print.c (pp_cxx_cast_expression): Handle it.
+ (pp_cxx_expression): Likewise.
+ * error.c (dump_expr): Likewise.
+ * semantics.c (potential_constant_expression_1): Likewise.
+ * tree.c (cp_tree_equal): Likewise.
+ (cp_walk_subtrees): Likewise.
+ * pt.c (iterative_hash_template_arg): Likewise.
+ (for_each_template_parm_r): Likewise.
+ (type_dependent_expression_p): Likewise.
+ (tsubst_copy, tsubst_copy_and_build): Handle IMPLICIT_CONV_EXPR
+ and CONVERT_EXPR.
+ * cp-tree.h (IMPLICIT_CONV_EXPR_DIRECT_INIT): New.
+
+2011-10-11 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50611
+ * pt.c (tsubst_copy_and_build): If (complain & tf_error) is false
+ do not call unqualified_name_lookup_error.
+
+2011-10-10 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50660
+ * call.c (conversion_null_warnings): Don't look through references.
+
+2011-10-09 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/38980
+ * init.c (constant_value_1): Add bool parameter.
+ (decl_constant_value_safe): Add.
+ (integral_constant_value): Adjust.
+ (decl_constant_value): Adjust.
+ * cp-tree.h (decl_constant_value_safe): Declare.
+ * typeck.c (decay_conversion): Use decl_constant_value_safe.
+ * call.c (convert_like_real): Likewise.
+
+2011-10-09 Jakub Jelinek <jakub@redhat.com>
+ Diego Novillo <dnovillo@google.com>
+
+ * pt.c (reregister_specialization): Use htab_find instead of
+ htab_find_slot with INSERT.
+ (maybe_process_partial_specialization, lookup_template_class_1): Change
+ slot variable type to void ** to avoid aliasing problems.
+ (register_specialization): Likewise. Use slot != NULL instead of
+ more expensive !optimize_specialization_lookup_p (tmpl) test.
+
+2011-10-08 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/34927
+ * typeck2.c (abstract_virtuals_error_sfinae): Don't produce duplicate
+ inform messages in case of cloned destructor.
+
+2011-10-06 Jason Merrill <jason@redhat.com>
+
+ PR c++/39164
+ * decl.c (grokfndecl): Diagnose redefinition of defaulted fn.
+
+2011-10-02 Jason Merrill <jason@redhat.com>
+
+ * pt.c (tsubst_pack_expansion): Re-use ARGUMENT_PACK_SELECTs.
+ Change unsubstituted_packs to bool.
+
+ * parser.c (cp_parser_range_for): Don't try to deduce from {}
+ in a template.
+
+ PR c++/35722
+ Implement N2555 (expanding pack expansion to fixed parm list)
+ * pt.c (coerce_template_parms): Allow expanding a pack expansion
+ to a fixed-length argument list.
+ (unify_pack_expansion): Handle explicit args properly.
+ (unify) [TREE_VEC]: Handle pack expansions here.
+ [TYPE_ARGUMENT_PACK]: Not here.
+ (tsubst_pack_expansion): Don't try to do partial substitution.
+ (pack_deducible_p): New.
+ (fn_type_unification): Use it.
+ (find_parameter_packs_r): Take the TYPE_MAIN_VARIANT
+ of a type parameter.
+ (check_non_deducible_conversion): Split from type_unification_real.
+ (unify_one_argument): Split from type_unification_real...
+ (unify_pack_expansion): ...and here. Drop call_args_p parm.
+ (type_unification_real, unify, more_specialized_fn): Adjust.
+
+ * class.c (fixed_type_or_null): Handle NSDMI.
+ * method.c (walk_field_subobs): Disable NSDMI noexcept checking
+ for now.
+
+2011-09-30 Jason Merrill <jason@redhat.com>
+
+ * cp-tree.h (TREE_NEGATED_INT): Remove.
+ * semantics.c (finish_unary_op_expr): Don't set it.
+
+2011-09-30 Janis Johnson <janisjo@codesourcery.com>
+
+ PR c++/44473
+ * mangle.c (write_type): Handle CV qualifiers for decimal classes.
+
+2011-09-26 Andi Kleen <ak@linux.intel.com>
+
+ * repo.c (finish_repo): Use HOST_WIDE_INT_PRINT_HEX_PURE.
+
+2011-09-28 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/45278
+ * typeck.c (cp_build_binary_op): With -Wextra, warn for ordered
+ comparison of pointer with zero.
+
+2011-09-27 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/31489
+ * parser.c (cp_parser_elaborated_type_specifier): For RECORD_TYPE,
+ set CLASSTYPE_DECLARED_CLASS.
+
+2011-09-27 Jakub Jelinek <jakub@redhat.com>
+
+ * decl.c (duplicate_decls): If compatible stpcpy prototype
+ is seen, set implicit_built_in_decls[BUILT_IN_STPCPY].
+
+2011-09-26 Jason Merrill <jason@redhat.com>
+
+ PR c++/45012
+ * pt.c (tsubst_copy_and_build) [CONST_DECL]: Don't pull out
+ constant value if we're still in a template.
+
+ PR c++/46105
+ * typeck.c (structural_comptypes): Ignore cv-quals on typename scope.
+
+ PR c++/50508
+ * semantics.c (cxx_eval_logical_expression): Use tree_int_cst_equal
+ rather than ==.
+
+2011-09-26 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/45487
+ * error.c (dump_template_bindings): Separate bindings with semicolons
+ instead of commas.
+
+2011-09-26 Jason Merrill <jason@redhat.com>
+
+ PR c++/50512
+ * call.c (compare_ics): Only consider rvaluedness_matches_p
+ if the target type is the same or it too differs in rvalueness.
+
+ PR c++/50523
+ * call.c (implicit_conversion): Mask out inappropriate LOOKUP
+ flags at the top of the function.
+
+ * pt.c (tsubst_copy) [PARM_DECL]: Handle 'this' in NSDMI.
+
+2011-09-26 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * pt.c (convert_nontype_argument): Handle NULLPTR_TYPE.
+
+2011-09-26 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/26747
+ * cp-gimplify.c (get_bc_label): Remove obsolete diagnostics.
+
+2011-09-25 Jason Merrill <jason@redhat.com>
+
+ * parser.c (inject_this_parameter): Split out from
+ cp_parser_late_return_type_opt.
+ (cp_parser_class_specifier_1): Use it for NSDMIs.
+ * tree.c (bot_replace): Replace NSDMI 'this' with real 'this'.
+
+2011-09-24 Jason Merrill <jason@redhat.com>
+
+ * except.c (expr_noexcept_p): Split out from finish_noexcept_expr.
+ * cp-tree.h: Declare it.
+ * method.c (walk_field_subobs): Use it.
+
+ * init.c (perform_member_init): Instantiate NSDMI here.
+ * pt.c (tsubst_decl) [FIELD_DECL]: Not here.
+
+ Handle deferred parsing of NSDMIs.
+ * parser.h (cp_unparsed_functions_entry): Add nsdmis field.
+ * parser.c (unparsed_nsdmis, cp_parser_save_nsdmi): New.
+ (cp_parser_late_parse_one_default_arg): Split out from
+ cp_parser_late_parsing_default_args.
+ (cp_parser_late_parsing_nsdmi): New.
+ (push_unparsed_function_queues): Set it.
+ (cp_parser_parameter_declaration): Save the '=' token.
+ (cp_parser_template_parameter): Likewise.
+ (cp_parser_default_argument): Call cp_parser_initializer
+ rather than cp_parser_initializer_clause.
+ (cp_parser_class_specifier_1): Parse unparsed_nsdmis.
+ (cp_parser_member_declaration): Handle nsdmis.
+ * decl2.c (grokfield): Handle DEFAULT_ARG for a function.
+
+ Implement C++11 non-static data member initializers.
+ * cp-tree.h (enum cpp_warn_str): Add CPP0X_NSDMI.
+ * error.c (maybe_warn_cpp0x): Handle it.
+ * call.c (convert_like_real) [ck_user]: Don't complain about
+ using an explicit constructor for direct-initialization.
+ * class.c (check_field_decl): Fix ancient typo.
+ (check_field_decls): NSDMIs make the default ctor non-trivial.
+ * decl.c (cp_finish_decl): Record NSDMI.
+ (grokdeclarator): Allow NSDMI.
+ * decl2.c (grokfield): Allow NSDMI. Correct LOOKUP flags.
+ * init.c (perform_member_init): Use NSDMI.
+ * method.c (walk_field_subobs): Check for NSDMI.
+ * parser.c (cp_parser_member_declaration): Parse { } init.
+ * semantics.c (register_constexpr_fundef): Don't talk about
+ a return statement in a constexpr constructor.
+ (cxx_eval_call_expression): Check DECL_INITIAL instead of
+ DECL_SAVED_TREE.
+
+2011-09-24 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/44267
+ * class.c (build_base_path): Add a tsubst_flags_t parameter.
+ (convert_to_base): Adjust call.
+ * typeck.c (build_class_member_access_expr,
+ get_member_function_from_ptrfunc, build_static_cast_1): Likewise.
+ * init.c (dfs_initialize_vtbl_ptrs, emit_mem_initializers): Likewise.
+ * method.c (do_build_copy_constructor, do_build_copy_assign): Likewise.
+ * rtti.c (build_dynamic_cast_1): Likewise.
+ * typeck2.c (build_scoped_ref, build_m_component_ref): Likewise.
+ * call.c (build_over_call, build_special_member_call): Likewise.
+ * cvt.c (cp_convert_to_pointer, convert_to_pointer_force,
+ build_up_reference): Likewise.
+ * cp-tree.h (build_base_path): Adjust declaration.
+
+2011-09-23 Jason Merrill <jason@redhat.com>
+
+ Core 253 - allow const objects with no initializer or
+ user-provided default constructor if the defaulted constructor
+ initializes all the subobjects.
+ PR c++/20039
+ PR c++/42844
+ * class.c (default_init_uninitialized_part): New.
+ * cp-tree.h: Declare it.
+ * decl.c (check_for_uninitialized_const_var): Use it.
+ * init.c (perform_member_init): Likewise.
+ (build_new_1): Likewise.
+ * method.c (walk_field_subobs): Likewise.
+
+2011-09-23 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50258
+ * decl.c (check_static_variable_definition): Allow in-class
+ initialization of static data member of non-integral type in
+ permissive mode.
+
+2011-09-22 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50491
+ * semantics.c (potential_constant_expression_1): Handle USING_DECL.
+
+2011-09-22 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50371
+ * pt.c (invalid_nontype_parm_type_p): Handle NULLPTR_TYPE.
+
+2011-09-22 Jonathan Wakely <jwakely.gcc@gmail.com>
+ Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50344
+ * friend.c (make_friend_class): cv-qualification is ok in a
+ friend declaration.
+
+2011-09-21 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50454
+ * decl.c (grokdeclarator): Consistently handle both __int128
+ and unsigned __int128 with -pedantic; suppress diagnostic in
+ system headers.
+
+2011-09-20 Jason Merrill <jason@redhat.com>
+
+ * cp-tree.h (DECL_TEMPLOID_INSTANTIATION): New.
+ (DECL_GENERATED_P): New.
+ * class.c (finalize_literal_type_property): Use them.
+ * semantics.c (is_instantiation_of_constexpr): Likewise.
+ (register_constexpr_fundef): Likewise.
+
+ * call.c (convert_default_arg): Avoid redundant copy.
+ * tree.c (bot_manip): Copy everything.
+
+2011-09-20 Roberto Agostino Vitillo <ravitillo@lbl.gov>
+
+ * call.c (build_new_method_call_1): Use non-virtual lookup
+ for final virtual functions.
+
+2011-09-16 Jason Merrill <jason@redhat.com>
+
+ PR c++/50424
+ * call.c (set_flags_from_callee): Split out from build_call_a.
+ * cp-tree.h: Declare it.
+ * tree.c (bot_manip): Call it.
+
+2011-09-15 Jason Merrill <jason@redhat.com>
+
+ PR c++/50365
+ * parser.c (cp_parser_late_return_type_opt): Check quals parameter
+ for clearing current_class_ptr, too.
+
+2011-09-14 Diego Novillo <dnovillo@google.com>
+
+ * name-lookup.c (lookup_arg_dependent): Use conditional
+ timevars.
+ * decl.c (xref_tag): Likewise.
+
+2011-09-14 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50391
+ * pt.c (regenerate_decl_from_template): Don't pass an error_mark_node
+ to build_exception_variant.
+
+2011-09-13 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/48320
+ * pt.c (template_parameter_pack_p): Support TEMPLATE_PARM_INDEX
+ nodes. Add a comment.
+ (arg_from_parm_pack_p): New static function, factorized out from
+ tsubst_pack_expansion and extended to support non-type parameter
+ packs represented with TEMPLATE_PARM_INDEX nodes.
+ (tsubst_pack_expansion): Use arg_from_parm_pack_p.
+
+2011-09-12 Jason Merrill <jason@redhat.com>
+
+ * pt.c (type_unification_real): Fix handling of DEDUCE_CONV
+ with no deducible template parameters.
+ * call.c (rejection_reason_code): Add rr_template_conversion.
+ (print_z_candidate): Handle it.
+ (template_conversion_rejection): New.
+ (build_user_type_conversion_1): Use it.
+
+ * call.c (merge_conversion_sequences): Set bad_p and user_conv_p
+ on all of the second conversion sequence.
+ (build_user_type_conversion_1): Set bad_p on the ck_user conv.
+ (convert_like_real): Handle bad ck_ref_bind with user_conv_p in the
+ first section. Fix loop logic.
+ (initialize_reference): Call convert_like for diagnostics when
+ we have a (bad) conversion.
+
+ * call.c (convert_class_to_reference)
+ (convert_class_to_reference_1): Remove.
+ (reference_binding): Use build_user_type_conversion_1 instead.
+
+ * call.c (initialize_reference): Add flags parm.
+ * decl.c (grok_reference_init): Likewise.
+ (check_initializer): Pass it.
+ * typeck.c (convert_for_initialization): Likewise.
+ * cp-tree.h: Adjust.
+
+ * cp-tree.h (LOOKUP_NO_RVAL_BIND): New.
+ * call.c (conditional_conversion): Use it.
+ (reference_binding): Fix handling of xvalues.
+
+2011-09-09 Jason Merrill <jason@redhat.com>
+
+ * call.c (implicit_conversion): Check BRACE_ENCLOSED_INITIALIZER_P
+ before forcing instantiation.
+
+2011-09-08 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50324
+ * typeck2.c (digest_init_r): Call complete_type_or_maybe_complain
+ instead of complete_type_or_else.
+
+2011-09-08 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/33255 - Support -Wunused-local-typedefs warning
+ * name-lookup.c (pushdecl_maybe_friend_1): Use the new
+ record_locally_defined_typedef.
+ * decl.c (finish_function): Use the new
+ maybe_warn_unused_local_typedefs.
+ (grokfield): Use the new record_locally_defined_typedef.
+ * parser.c (lookup_name): Use the new maybe_record_typedef_use.
+
+2011-09-07 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/50309
+ * decl.c (grokdeclarator): Check u.function.exception_specification
+ for error_mark_node.
+
+2011-09-07 Jason Merrill <jason@redhat.com>
+
+ PR c++/50298
+ * parser.c (cp_parser_member_declaration): Don't require a constant
+ rvalue here in C++0x.
+
+ * pt.c (type_unification_real): Correct complain arg for tsubsting
+ default template args.
+
+ * pt.c (tsubst_aggr_type): Check TYPE_P before tsubsting.
+
+2011-09-06 Jason Merrill <jason@redhat.com>
+
+ PR c++/50296
+ * semantics.c (register_constexpr_fundef): Call is_valid_constexpr_fn.
+ (cx_check_missing_mem_inits): Handle bases and empty trivial members.
+ (validate_constexpr_fundecl): Remove.
+ * decl.c (start_preparsed_function): Don't call it.
+ * cp-tree.h: Don't declare it.
+
+2011-09-04 Jason Merrill <jason@redhat.com>
+
+ PR c++/49267
+ * call.c (reference_binding): Don't set is_lvalue for an rvalue
+ reference rfrom.
+
+ PR c++/49267
+ PR c++/49458
+ DR 1328
+ * call.c (reference_binding): Set rvaluedness_matches_p properly
+ for reference to function conversion ops.
+ (compare_ics): Adjust.
+
+ * class.c (trivial_default_constructor_is_constexpr): Rename from
+ synthesized_default_constructor_is_constexpr.
+ (type_has_constexpr_default_constructor): Adjust.
+ (add_implicitly_declared_members): Call it instead.
+ (explain_non_literal_class): Explain about non-constexpr default ctor.
+ * cp-tree.h: Adjust.
+ * method.c (synthesized_method_walk): Adjust.
+ * semantics.c (explain_invalid_constexpr_fn): Handle defaulted
+ functions, too.
+
+ PR c++/50248
+ Core 1358
+ * init.c (perform_member_init): Don't diagnose missing inits here.
+ (emit_mem_initializers): Or here.
+ * method.c (process_subob_fn): Don't instantiate constexpr ctors.
+ * semantics.c (cx_check_missing_mem_inits): New.
+ (explain_invalid_constexpr_fn): Call it.
+ (register_constexpr_fundef): Likewise. Leave
+ DECL_DECLARED_CONSTEXPR_P set when the body is unsuitable.
+ (cxx_eval_call_expression): Adjust diagnostics.
+ (cxx_eval_constant_expression): Catch use of 'this' in a constructor.
+
+2011-08-30 Jason Merrill <jason@redhat.com>
+
+ PR c++/50084
+ * cp-tree.h (cp_decl_specifier_seq): Rename user_defined_type_p
+ to type_definition_p.
+ * parser.c (cp_parser_set_decl_spec_type): Likewise.
+ * decl.c (grokdeclarator): Check it.
+
+ PR c++/50089
+ * semantics.c (finish_id_expression): Use
+ current_nonlambda_class_type for qualified-ids.
+
+ PR c++/50114
+ * decl.c (poplevel): Disable for scope compatibility hack
+ in C++11 mode.
+
+ PR c++/50220
+ * semantics.c (add_capture): Call complete_type for copy.
+
+ PR c++/50234
+ * semantics.c (cxx_eval_component_reference): Handle
+ value-initialization for omitted initializers.
+
+2011-08-29 Jason Merrill <jason@redhat.com>
+
+ PR c++/50224
+ * semantics.c (finish_id_expression): Mark captured variables used.
+
+2011-08-29 Jakub Jelinek <jakub@redhat.com>
+ Jason Merrill <jason@redhat.com>
+
+ PR c++/50207
+ * class.c (finish_struct_1): Complain if the first field is
+ artificial.
+
+2011-08-29 Jason Merrill <jason@redhat.com>
+
+ PR c++/50209
+ Core DR 994
+ * parser.c (cp_parser_default_argument): Use
+ cp_parser_initializer_clause.
+ (cp_parser_late_parsing_default_args): Likewise.
+
+2011-08-26 Jason Merrill <jason@redhat.com>
+
+ Core DR 342
+ PR c++/48582
+ * pt.c (check_valid_ptrmem_cst_expr): A null member pointer value
+ is valid in C++11.
+ (convert_nontype_argument): Likewise. Implicitly convert nullptr
+ and do constant folding.
+ * mangle.c (write_template_arg_literal): Mangle null member
+ pointer values as 0.
+ * call.c (null_member_pointer_value_p): New.
+ * cp-tree.h: Declare it.
+
+2011-08-25 Jason Merrill <jason@redhat.com>
+
+ * call.c (convert_like_real): Remove redundant complain checks.
+
+ PR c++/50157
+ * call.c (convert_like_real): Exit early if bad and !tf_error.
+
+2011-08-23 Jason Merrill <jason@redhat.com>
+
+ * typeck2.c (build_functional_cast): Don't try to avoid calling
+ build_value_init.
+ * pt.c (instantiate_class_template_1): Don't copy TYPE_HAS_* flags.
+
+2011-08-23 Jason Merrill <jason@redhat.com>
+
+ PR c++/49045
+ Core 1321
+ * tree.c (dependent_name): New.
+ (cp_tree_equal): Two calls with the same dependent name are
+ equivalent even if the overload sets are different.
+
+2011-08-23 Jason Merrill <jason@redhat.com>
+
+ * tree.c (build_target_expr): Set TREE_CONSTANT on
+ literal TARGET_EXPR if the value is constant.
+ * typeck2.c (build_functional_cast): Don't set it here.
+
+2011-08-23 Jason Merrill <jason@redhat.com>
+
+ Core 903 (partial)
+ * call.c (null_ptr_cst_p): Only 0 qualifies in C++11.
+
+2011-08-23 Jason Merrill <jason@redhat.com>
+
+ Core 975
+ * decl.c (cxx_init_decl_processing): Initialize
+ dependent_lambda_return_type_node.
+ * cp-tree.h (cp_tree_index): Add CPTI_DEPENDENT_LAMBDA_RETURN_TYPE.
+ (dependent_lambda_return_type_node): Define.
+ (DECLTYPE_FOR_LAMBDA_RETURN): Remove.
+ * semantics.c (lambda_return_type): Handle overloaded function.
+ Use dependent_lambda_return_type_node instead of
+ DECLTYPE_FOR_LAMBDA_RETURN.
+ (apply_lambda_return_type): Don't check dependent_type_p.
+ * pt.c (tsubst_copy_and_build): Handle lambda return type deduction.
+ (instantiate_class_template_1): Likewise.
+ (tsubst): Don't use DECLTYPE_FOR_LAMBDA_RETURN.
+ * mangle.c (write_type): Likewise.
+ * typeck.c (structural_comptypes): Likewise.
+ (check_return_expr): Handle dependent_lambda_return_type_node.
+
+2011-08-23 Jason Merrill <jason@redhat.com>
+
+ PR c++/50024
+ * semantics.c (maybe_constant_value): Don't try to fold { }.
+ * pt.c (build_non_dependent_expr): Don't wrap { }.
+ * init.c (build_value_init): Allow scalar value-init in templates.
+
+2011-08-23 Jason Merrill <jason@redhat.com>
+
+ * semantics.c (potential_constant_expression_1): Allow 'this'.
+
+2011-08-23 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/50158
+ * typeck.c (cp_build_modify_expr): Call mark_rvalue_use on rhs
+ if it has side-effects and needs to be preevaluated.
+
+2011-08-23 Siddhesh Poyarekar <siddhesh.poyarekar@gmail.com>
+
+ PR c++/50055
+ * except.c (begin_eh_spec_block): Build EH_SPEC block on the
+ same line as the function.
+
+2011-08-23 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/46862
+ * class.c (finish_struct_1): If TYPE_TRANSPARENT_AGGR is set on a type
+ which doesn't have any fields, clear it and diagnose.
+
+2011-08-18 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
+ Marc Glisse <marc.glisse@normalesup.org>
+
+ PR libstdc++-v3/1773
+ * mangle.c (decl_mangling_context): Call
+ targetm.cxx.decl_mangling_context.
+ (write_unscoped_name): Use decl_mangling_context.
+
+2011-08-18 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/45625
+ * pt.c (parameter_of_template_p): Handle comparison with DECLs of
+ template parameters as created by process_template_parm.
+
+2011-08-16 Jason Merrill <jason@redhat.com>
+
+ PR c++/50086
+ * pt.c (unify_pack_expansion): Correct overloaded unification
+ logic.
+
+ * pt.c (instantiate_class_template_1): If DECL_PRESERVE_P is set
+ on a member function or static data member, call mark_used.
+
+ PR c++/50054
+ * typeck2.c (cxx_incomplete_type_diagnostic): Handle
+ init_list_type_node.
+
+2011-08-13 Jason Merrill <jason@redhat.com>
+
+ PR c++/50075
+ * name-lookup.c (local_bindings_p): New.
+ * name-lookup.h: Declare it.
+ * lex.c (unqualified_name_lookup_error): Use it.
+
+ PR c++/50059
+ * error.c (dump_expr): Handle MODIFY_EXPR properly.
+
+ * decl.c (grok_reference_init): Handle constexpr here.
+ * call.c (initialize_reference): Not here.
+
+2011-08-12 David Li <davidxl@google.com>
+
+ * class.c (update_vtable_entry_for_fn): Set
+ LOST_PRIMARY bit properly.
+
+2011-08-12 Jason Merrill <jason@redhat.com>
+
+ PR c++/50034
+ * call.c (convert_arg_to_ellipsis): force_rvalue only in
+ potentially evaluated context.
+
+2011-08-12 Richard Guenther <rguenther@suse.de>
+
+ * call.c (build_over_call): Instead of memcpy use an
+ assignment of two MEM_REFs.
+
+2011-08-11 Romain Geissler <romain.geissler@gmail.com>
+ Brian Hackett <bhackett1024@gmail.com>
+
+ * decl.c (cp_finish_decl): Invoke callbacks on finish_decl event.
+
+2011-08-10 Richard Guenther <rguenther@suse.de>
+
+ * call.c (build_over_call): Call memcpy unconditionally.
+
+2011-08-08 Jason Merrill <jason@redhat.com>
+
+ PR c++/50020
+ * semantics.c (finish_call_expr): Don't look at 'this' if we
+ had an explicit object argument.
+
+ PR c++/50011
+ * typeck2.c (check_narrowing): Fix integer logic.
+
+2011-08-08 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
+
+ * Make-lang.in (g++$(exeext)): Add $(EXTRA_GCC_LIBS).
+
+2011-08-05 Jason Merrill <jason@redhat.com>
+
+ PR c++/48993
+ * semantics.c (potential_constant_expression_1) [CALL_EXPR]: Sorry
+ on 'this' in a constructor.
+
+ PR c++/49921
+ * semantics.c (finish_decltype_type): Call invalid_nonstatic_memfn_p.
+
+ PR c++/49669
+ * init.c (perform_member_init): Handle invalid array initializer.
+
+ PR c++/49988
+ * semantics.c (cxx_eval_array_reference): Handle failure to
+ reduce the array operand to something we can work with.
+
+2011-08-05 Gabriel Charette <gchare@google.com>
+
+ * decl.c (finish_function): Remove unecessary line 0 hack.
+
+2011-08-05 Jason Merrill <jason@redhat.com>
+
+ PR c++/47453
+ * typeck.c (build_x_compound_expr_from_list): Also complain
+ about ({...}).
+
+ PR c++/49812
+ * typeck.c (cp_build_unary_op) [POSTINCREMENT_EXPR]: Strip cv-quals.
+
+ PR c++/49983
+ * parser.c (cp_parser_range_for): Only do auto deduction in
+ template if the range is non-dependent.
+
+ * init.c (perform_member_init): Always build_aggr_init
+ for a class member with an explicit mem-initializer.
+
+ * pt.c (unify) [TEMPLATE_TYPE_PARM]: Allow VLA for C++0x 'auto'.
+
+2011-08-04 Jakub Jelinek <jakub@redhat.com>
+
+ PR middle-end/49905
+ * decl.c (cxx_init_decl_processing): Add alloc_size (1) attribute
+ for operator new and operator new []. Call init_attributes.
+
+2011-08-02 Jason Merrill <jason@redhat.com>
+
+ PR c++/43886
+ * parser.c (cp_parser_lambda_body): Clear local_variables_forbidden_p.
+
+ PR c++/49577
+ * typeck2.c (check_narrowing): Check unsigned mismatch.
+ * semantics.c (finish_compound_literal): check_narrowing.
+
+ PR c++/49593
+ * pt.c (find_parameter_packs_r): Handle CONSTRUCTOR.
+
+ PR c++/49803
+ * init.c (sort_mem_initializers): Initialize uses_unions_p here.
+ (build_field_list): Not here.
+
+ PR c++/49834
+ * parser.c (build_range_temp): Split out from...
+ (cp_convert_range_for): ...here.
+ (do_range_for_auto_deduction): New.
+ (cp_parser_range_for): Use it.
+
+2011-08-02 Jakub Jelinek <jakub@redhat.com>
+
+ * cp-tree.h (finish_omp_atomic): Adjust prototype.
+ (cxx_omp_const_qual_no_mutable): New prototype.
+ (finish_omp_taskyield): New prototype.
+ * parser.c (cp_parser_omp_atomic): (cp_parser_omp_atomic): Handle
+ parsing OpenMP 3.1 atomics. Adjust finish_omp_atomic caller.
+ (cp_parser_omp_clause_name): Handle final and mergeable clauses.
+ (cp_parser_omp_clause_final, cp_parser_omp_clause_mergeable): New
+ functions.
+ (cp_parser_omp_all_clauses): Handle PRAGMA_OMP_CLAUSE_FINAL
+ and PRAGMA_OMP_CLAUSE_MERGEABLE.
+ (OMP_TASK_CLAUSE_MASK): Allow final and mergeable clauses.
+ (cp_parser_omp_taskyield): New function.
+ (cp_parser_pragma): Handle PRAGMA_OMP_TASKYIELD.
+ (cp_parser_omp_clause_reduction): Handle min and max.
+ * pt.c (tsubst_expr) <case OMP_ATOMIC>: Handle OpenMP 3.1 atomics.
+ (tsubst_omp_clauses): Handle OMP_CLAUSE_FINAL and
+ OMP_CLAUSE_MERGEABLE.
+ * semantics.c (finish_omp_atomic): Add OPCODE, V, LHS1 and RHS1
+ arguments. Handle OpenMP 3.1 atomics. Adjust c_finish_omp_atomic
+ caller.
+ (finish_omp_clauses): Don't complain about const qualified
+ predetermined vars and static data members in firstprivate clause.
+ Handle OMP_CLAUSE_FINAL and OMP_CLAUSE_MERGEABLE. Handle MIN_EXPR
+ and MAX_EXPR.
+ (finish_omp_taskyield): New function.
+ * cp-gimplify.c (cxx_omp_const_qual_no_mutable): New function.
+ (cxx_omp_predetermined_sharing): Use it.
+
+2011-08-02 Jason Merrill <jason@redhat.com>
+
+ * call.c (build_call_a): Also check at_function_scope_p.
+
+2011-08-01 Jason Merrill <jason@redhat.com>
+
+ PR c++/49932
+ * mangle.c (write_prefix): Handle decltype.
+
+ PR c++/49924
+ * semantics.c (cxx_eval_vec_init_1): Fix logic.
+
+ PR c++/49813
+ * semantics.c (potential_constant_expression_1): Allow any builtin.
+ (morally_constexpr_builtin_function_p): Remove.
+
+2011-07-29 Jason Merrill <jason@redhat.com>
+
+ PR c++/49867
+ * parser.c (cp_parser_lambda_expression): Also clear in_statement
+ and in_switch_statement_p.
+ (cp_parser_class_specifier): Likewise.
+
+2011-07-28 Jason Merrill <jason@redhat.com>
+
+ PR c++/49808
+ * pt.c (tsubst) [TEMPLATE_PARM_INDEX]: Call convert_from_reference.
+ (convert_nontype_argument, tsubst_template_arg): Handle its output.
+
+2011-07-28 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/49813
+ * semantics.c (potential_constant_expression_1): Handle FMA_EXPR.
+
+2011-07-27 Jeffrey Yasskin <jyasskin@google.com>
+
+ * pt.c (build_template_decl): Copy the function_decl's
+ source location to the new template_decl.
+
+2011-07-26 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/49776
+ * typeck.c (cp_build_modify_expr): Check digest_init return value
+ for error_mark_node.
+
+2011-07-25 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR bootstrap/49845
+ * parser.c (cp_parser_perform_range_for_lookup): Always assign *being
+ and *end before returning.
+
+2011-07-25 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/49838
+ * parser.c (cp_parser_perform_range_for_lookup): Early return if
+ error_operand_p (range).
+
+2011-07-23 Jason Merrill <jason@redhat.com>
+
+ PR c++/49823
+ * parser.c (cp_parser_qualifying_entity): Handle templates.
+
+2011-07-22 Jason Merrill <jason@redhat.com>
+
+ PR c++/49793
+ * typeck2.c (check_narrowing): Downgrade permerror to pedwarn.
+ Make conditional on -Wnarrowing.
+
+2011-07-22 Ville Voutilainen <ville.voutilainen@gmail.com>
+
+ Warn about the use of final/override in non-c++0x mode, and
+ add __final for non-c++0x mode.
+ * cp-tree.h (cpp0x_warn_str): Add CPP0X_OVERRIDE_CONTROLS.
+ * error.c (maybe_warn_cpp0x): Adjust.
+ * parser.c (cp_parser_virt_specifier_seq_opt): Use it. Add
+ '__final' as a non-c++0x alternative for 'final'.
+
+2011-07-22 Jason Merrill <jason@redhat.com>
+ Mark Glisse <marc.glisse@normalesup.org>
+
+ PR c++/30112
+ * decl.c (cp_finish_decl): Apply pragma redefine_extname in
+ other namespaces as well.
+ * name-lookup.c (c_linkage_bindings): Define.
+ (lookup_extern_c_fun_in_all_ns): Rename from
+ lookup_extern_c_fun_binding_in_all_ns. Return tree.
+ (pushdecl_maybe_friend_1): Adjust. Copy DECL_ASSEMBLER_NAME.
+
+2011-07-20 Jason Merrill <jason@redhat.com>
+
+ * parser.c (cp_parser_initializer_list): Handle C99 .id= and [N]=
+ designated initializer syntax.
+ * decl.c (check_array_designated_initializer): Add index parm.
+ (maybe_deduce_size_from_array_init): Pass it.
+ (reshape_init_array_1): Likewise.
+
+ PR c++/6709 (DR 743)
+ PR c++/42603 (DR 950)
+ * parser.c (token_is_decltype, cp_lexer_next_token_is_decltype): New.
+ (cp_parser_nested_name_specifier_opt): Allow decltype.
+ (cp_parser_qualifying_entity): Likewise.
+ (cp_parser_decltype): Replace source tokens with CPP_DECLTYPE.
+ (cp_parser_simple_type_specifier): Handle decltype as scope.
+ (cp_parser_base_specifier): Allow decltype.
+ (cp_parser_base_clause): Don't crash on null base.
+ * parser.h (CPP_KEYWORD, CPP_TEMPLATE_ID): Move to c-common.h.
+ (CPP_NESTED_NAME_SPECIFIER, N_CP_TTYPES): Likewise.
+
+2011-07-19 Jason Merrill <jason@redhat.com>
+
+ PR c++/49785
+ * pt.c (coerce_template_parms): Handle non-pack after pack.
+
+2011-07-19 Richard Guenther <rguenther@suse.de>
+
+ * call.c (build_special_member_call): Use fold_build_pointer_plus.
+ * class.c (build_base_path): Likewise.
+ (convert_to_base_statically): Likewise.
+ (dfs_accumulate_vtbl_inits): Likewise.
+ * cp-gimplify.c (cxx_omp_clause_apply_fn): Likewise.
+ * except.c (expand_start_catch_block): Likewise.
+ * init.c (expand_virtual_init): Likewise.
+ (build_new_1): Likewise.
+ (build_vec_delete_1): Likewise.
+ (build_vec_delete): Likewise.
+ * rtti.c (build_headof): Likewise.
+ (tinfo_base_init): Likewise.
+ * typeck.c (get_member_function_from_ptrfunc): Likewise.
+ (cp_build_addr_expr_1): Likewise.
+ * typeck2.c (build_m_component_ref): Likewise.
+
+2011-07-18 Martin Jambor <mjambor@suse.cz>
+
+ * parser.c (cp_parser_parameter_declaration_list): Initialize
+ parenthesized_p.
+
+2011-07-16 Jason Merrill <jason@redhat.com>
+
+ * pt.c (tinst_level_tick, last_template_error_tick): Replace with
+ last_error_tinst_level.
+ (push_tinst_level, pop_tinst_level): Adjust.
+ (problematic_instantiation_changed): Adjust.
+ (record_last_problematic_instantiation): Adjust.
+ * error.c (cp_print_error_function): Don't print
+ current_function_decl if we're in a template instantiation context.
+ (print_instantiation_full_context): Always print first line.
+
+2011-07-16 Nathan Froyd <froydnj@codesourcery.com>
+ Jason Merrill <jason@redhat.com>
+
+ PR c++/45329
+ PR c++/48934
+ * cp-tree.h (fn_type_unification): Add `bool' parameter.
+ * pt.c (enum template_base_result): Define.
+ (unify_success, unify_unknown): Define.
+ (unify_parameter_deduction_failure): Define.
+ (unify_invalid, unify_cv_qual_mismatch, unify_type_mismatch): Define.
+ (unify_parameter_pack_mismatch): Define.
+ (unify_parameter_pack_inconsistent): Define.
+ (unify_ptrmem_cst_mismatch, unify_vla_arg): Define.
+ (unify_expression_unequal, unify_inconsistency): Define.
+ (unify_method_type_error, unify_arity): Likewise.
+ (unify_too_many_parameters, unify_too_few_parameters): Define.
+ (unify_arg_conversion, unify_no_common_base): Define.
+ (unify_illformed_ptrmem_cst_expr): Define.
+ (unify_substitution_failure): Define.
+ (unify_inconsistent_template_template_parameters): Define.
+ (unify_template_deduction_failure): Define.
+ (unify_template_argument_mismatch): Define.
+ (unify_overload_resolution_failure): Define.
+ (comp_template_args_with_info): New function, split out from...
+ (comp_template_args): ...here. Call it.
+ (deduction_tsubst_fntype): Add `complain' parameter'. Pass it
+ to tsubst.
+ (unify): Add `explain_p' parameter. Pass to all relevant calls.
+ Call above status functions when appropriate.
+ (resolve_overloaded_unification, try_one_overload): Likewise.
+ (type_unification, type_unification_real): Likewise.
+ (unify_pack_expansion): Likewise.
+ (get_template_base, try_class_unification): Likewise.
+ (get_bindings, more_specialized_fn): Pass false to unification
+ calls.
+ (get_class_bindings, do_auto_deduction): Likewise.
+ (convert_nontype_argument): Likewise.
+ (fn_type_unification): Likewise. Pass tf_warning_or_error if
+ explain_p.
+ (get_template_base): Add `explain_p' parameter and pass it to
+ try_class_unification. Return an enum template_base_result.
+ * class.c (resolve_address_of_overloaded_function): Pass false to
+ fn_type_unification.
+ * call.c (enum rejection_reason_code): Add new codes.
+ (struct rejection_reason): Add template_unification field.
+ Add template_instantiation field.
+ (template_unification_rejection): Define.
+ (template_unification_error_rejection): Define.
+ (template_instantiation_rejection): Define.
+ (invalid_copy_with_fn_template_rejection): Define.
+ (add_template_candidate): Pass false to unify.
+ Provide more rejection reasons when possible.
+ (print_template_unification_rejection): Define.
+ (print_arity_rejection): Define, split out from...
+ (print_z_candidate): ...here. Add cases for new rejection
+ reasons.
+
+2011-07-15 Jason Merrill <jason@redhat.com>
+
+ * Make-lang.in (check-g++-strict-gc): New.
+ (cp/except.o): Depend on gt-cp-except.h
+ * except.c: Include gt-cp-except.h.
+ * config-lang.in (gtfiles): Add cp/except.c.
+ * decl2.c (mark_used): Adjust constexpr condition, set
+ function_depth around template instantiation.
+ * parser.c (cp_parser_lambda_body): Set function_depth.
+ * semantics.c (maybe_add_lambda_conv_op): Likewise.
+
+ PR testsuite/49741
+ * Make-lang.in (check-c++0x): Use --extra_opts instead of--tool_opts.
+
+2011-07-13 Jason Merrill <jason@redhat.com>
+
+ * Make-lang.in (check-c++0x): New.
+
+2011-07-13 Richard Sandiford <richard.sandiford@linaro.org>
+
+ * typeck2.c (split_nonconstant_init_1): Pass the initializer directly,
+ rather than a pointer to it. Return true if the whole of the value
+ was initialized by the generated statements. Use
+ complete_ctor_at_level_p instead of count_type_elements.
+
+2011-07-12 Diego Novillo <dnovillo@google.com>
+
+ * name-lookup.h (cp_binding_level): Rename from cxx_scope.
+ Update all users.
+ (struct cp_binding_level): Fix indentation.
+
+2011-07-11 Jason Merrill <jason@redhat.com>
+
+ PR c++/49672
+ * pt.c (extract_fnparm_pack): Split out from...
+ (make_fnparm_pack): ...here.
+ (instantiate_decl): Handle non-pack parms after a pack.
+ * semantics.c (maybe_add_lambda_conv_op): Don't in a template.
+
+ * decl2.c (decl_constant_var_p): Use decl_maybe_constant_var_p.
+
+ PR c++/44609
+ * cp-tree.h (struct tinst_level): Add errors field.
+ * pt.c (neglectable_inst_p, limit_bad_template_recurson): New.
+ (push_tinst_level): Don't start another decl in that case.
+ (reopen_tinst_level): Adjust errors field.
+ * decl2.c (cp_write_global_declarations): Don't complain about
+ undefined inline if its template was defined.
+ * mangle.c (mangle_decl_string): Handle failure from push_tinst_level.
+
+2011-07-10 Jason Merrill <jason@redhat.com>
+
+ PR c++/49691
+ * parser.c (cp_parser_late_return_type_opt): Check quals parameter
+ rather than current_class_type to determine whether to set 'this'.
+ (cp_parser_direct_declarator): Pass -1 to quals if member_p is false.
+ (cp_parser_init_declarator): Pass down member_p.
+
+2011-07-09 Jason Merrill <jason@redhat.com>
+
+ * tree.c (build_vec_init_elt): Strip TARGET_EXPR.
+
+2011-07-08 Jason Merrill <jason@redhat.com>
+
+ PR c++/45437
+ * typeck.c (cp_build_modify_expr): Preevaluate RHS.
+
+ * method.c (use_thunk): Use cgraph_add_to_same_comdat_group.
+ * optimize.c (maybe_clone_body): Likewise.
+ * semantics.c (maybe_add_lambda_conv_op): Likewise.
+
+ PR c++/45603
+ * decl.c (expand_static_init): Don't get confused by user
+ declaration of __cxa_guard_acquire.
+
+ * typeck.c (cp_apply_type_quals_to_decl): Don't check
+ COMPLETE_TYPE_P either.
+
+ PR c++/49673
+ * typeck.c (cp_apply_type_quals_to_decl): Don't check
+ TYPE_NEEDS_CONSTRUCTING.
+
+2011-07-07 Jason Merrill <jason@redhat.com>
+
+ PR c++/49663
+ * pt.c (push_deduction_access_scope): Preserve
+ processing_template_decl across push_to_top_level.
+ And revert:
+ * class.c (pushclass): Accept NULL argument.
+ (popclass): Deal with popping null class.
+ * pt.c (push_access_scope, pop_access_scope): Use them rather than
+ push_to_top_level/pop_from_top_level.
+ * name-lookup.c (lookup_name_real_1): Check current_class_type.
+
+2011-07-07 Jakub Jelinek <jakub@redhat.com>
+
+ PR c/49644
+ * typeck.c (cp_build_binary_op): For MULT_EXPR and TRUNC_DIV_EXPR with
+ one non-complex and one complex argument, call save_expr on both
+ operands.
+
+2011-07-06 Jason Merrill <jason@redhat.com>
+
+ PR c++/49353
+ * semantics.c (expand_or_defer_fn_1): Clear DECL_EXTERNAL
+ on kept inlines.
+
+ PR c++/49568
+ * method.c (make_thunk, use_thunk): Copy DECL_COMDAT.
+
+2011-07-05 Jason Merrill <jason@redhat.com>
+
+ PR c++/48157
+ * pt.c (tsubst_qualified_id): Preserve TEMPLATE_ID_EXPR in
+ partial instantiation.
+
+ PR c++/49598
+ * semantics.c (finish_id_expression): convert_from_reference.
+
+2011-07-05 Richard Guenther <rguenther@suse.de>
+
+ * decl.c (cxx_init_decl_processing): Defer building common
+ tree nodes to c_common_nodes_and_builtins.
+
+2011-07-04 Jason Merrill <jason@redhat.com>
+
+ DR 1207
+ PR c++/49589
+ * mangle.c (write_expression): Handle 'this'.
+ * parser.c (cp_parser_postfix_dot_deref_expression): Allow
+ incomplete *this.
+ * semantics.c (potential_constant_expression_1): Check that
+ DECL_CONTEXT is set on 'this'.
+
+ * error.c (dump_template_bindings): Don't print typenames
+ for a partial instantiation.
+ (dump_function_decl): If we aren't printing function arguments,
+ print template arguments as <args> rather than [with ...].
+ (dump_expr): Don't print return type or template header.
+ [BASELINK]: Use BASELINK_FUNCTIONS rather than get_first_fn.
+ * pt.c (dependent_template_arg_p): Handle null arg.
+
+ * error.c (type_to_string): Avoid redundant akas.
+
+2011-07-01 Jonathan Wakely <jwakely.gcc@gmail.com>
+
+ PR c++/49605
+ * init.c (build_delete): Only warn for sfk_deleting_destructor.
+
+2011-07-01 Jakub Jelinek <jakub@redhat.com>
+
+ * Make-lang.in (cp/decl.o): Depend on pointer-set.h.
+ (cp/class.o): Likewise.
+ (cp/error.o): Likewise.
+ (cp/name-lookup.o): Likewise.
+ (cp/decl2.o): Likewise. Don't depend on $(POINTER_SET_H).
+
+2011-07-01 Jason Merrill <jason@redhat.com>
+
+ PR c++/48261
+ * pt.c (lookup_template_function): Handle non-function.
+
+ PR c++/48593
+ * pt.c (tsubst_qualified_id): Check PTRMEM_OK_P.
+ * tree.c (build_qualified_name): Set PTRMEM_OK_P.
+ * semantics.c (finish_parenthesized_expr): Clear PTRMEM_OK_P on
+ SCOPE_REF, too.
+ * cp-tree.h (PTRMEM_OK_P): Apply to SCOPE_REF, too.
+ (QUALIFIED_NAME_IS_TEMPLATE): Switch to lang flag 1.
+
+ PR c++/48883
+ PR c++/49609
+ * pt.c (resolve_nondeduced_context): Call mark_used.
+
+ PR c++/49085
+ * semantics.c (finish_offsetof): Complain about incomplete type.
+
+2011-06-30 Jason Merrill <jason@redhat.com>
+
+ PR c++/49387
+ * rtti.c (get_tinfo_decl): Call complete_type.
+
+ PR c++/49569
+ * method.c (implicitly_declare_fn): Set DECL_PARM_LEVEL and
+ DECL_PARM_INDEX on rhs parm.
+
+ * pt.c (iterative_hash_template_arg): Use cp_tree_operand_length.
+
+ PR c++/49355
+ * tree.c (stabilize_init): Handle aggregate initialization.
+
+ PR c++/48481
+ * name-lookup.c (struct arg_lookup): Add fn_set.
+ (add_function): Check it.
+ (lookup_arg_dependent_1): Initialize it.
+
+2011-06-29 Jason Merrill <jason@redhat.com>
+
+ PR c++/49216
+ * init.c (build_new_1): Pass {} down to build_vec_init.
+ (build_vec_init): Handle it.
+
+ DR 1207
+ PR c++/49003
+ * cp-tree.h (struct saved_scope): Add x_current_class_ptr,
+ x_current_class_ref.
+ (current_class_ptr, current_class_ref): Use them.
+ * decl.c (build_this_parm): Handle getting the class type.
+ * parser.c (cp_parser_late_return_type_opt): Set up 'this'
+ for use within the trailing return type.
+
+ * pt.c (tsubst_decl) [VAR_DECL]: In unevaluated operand,
+ don't tsubst DECL_INITIAL unless our type use auto.
+
+ PR c++/49520
+ * semantics.c (constexpr_fn_retval): Handle CLEANUP_POINT_EXPR here.
+ (massage_constexpr_body): Not here.
+
+ PR c++/49554
+ * semantics.c (lambda_proxy_type): New.
+ (build_capture_proxy): Use it.
+ * cp-tree.h (DECLTYPE_FOR_LAMBDA_PROXY): New.
+ * pt.c (tsubst) [DECLTYPE_TYPE]: Use them.
+
+ PR c++/45923
+ * class.c (explain_non_literal_class): New.
+ (finalize_literal_type_property): Call it.
+ * cp-tree.h: Declare it.
+ * semantics.c (ensure_literal_type_for_constexpr_object): Call it.
+ (is_valid_constexpr_fn): Likewise.
+ (massage_constexpr_body): Split out from...
+ (register_constexpr_fundef): ...here.
+ (is_instantiation_of_constexpr): New.
+ (expand_or_defer_fn_1): Leave DECL_SAVED_TREE alone in that case.
+ (explain_invalid_constexpr_fn): New.
+ (cxx_eval_call_expression): Call it.
+ (potential_constant_expression_1): Likewise. Avoid redundant errors.
+ * method.c (process_subob_fn): Diagnose non-constexpr.
+ (walk_field_subobs): Likewise.
+ (synthesized_method_walk): Don't shortcut if we want diagnostics.
+ (explain_implicit_non_constexpr): New.
+ (defaulted_late_check): Use it.
+ * call.c (build_cxx_call): Remember location.
+
+ * method.c (maybe_explain_implicit_delete): Use pointer_set
+ instead of htab.
+
+ * class.c (finalize_literal_type_property): Update conditions.
+ * method.c (defaulted_late_check): Set TYPE_HAS_CONSTEXPR_CTOR.
+
+ * tree.c (build_vec_init_expr): Don't add TARGET_EXPR.
+ * typeck2.c (digest_init_r): Handle VEC_INIT_EXPR.
+ * semantics.c (cxx_eval_vec_init_1): Correct type.
+
+ * init.c (build_value_init): Decide whether or not to zero-initialize
+ based on user-providedness of default ctor, not any ctor.
+ (build_value_init_noctor): Adjust assert.
+
+ DR 990
+ * call.c (convert_like_real) [ck_user]: Handle value-initialization.
+ (build_new_method_call_1): Likewise.
+ * init.c (expand_default_init): Handle direct list-initialization
+ of aggregates.
+
+2011-06-27 Jakub Jelinek <jakub@redhat.com>
+
+ * cp-tree.h (union lang_tree_node): Use it in chain_next expression.
+
+2011-06-26 Jason Merrill <jason@redhat.com>
+
+ PR c++/49528
+ * semantics.c (potential_constant_expression_1): Check
+ for non-literality rather than cleanup.
+ (cxx_eval_constant_expression): Likewise.
+
+ PR c++/49528
+ * semantics.c (potential_constant_expression_1): A TARGET_EXPR
+ with a cleanup isn't constant.
+ (cxx_eval_constant_expression): Likewise.
+ * init.c (expand_default_init): Use maybe_constant_init.
+
+2011-06-24 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/46400
+ * cp-tree.h (union lang_tree_node): Use TYPE_NEXT_VARIANT
+ instead of TYPE_CHAIN for chain_next for types.
+
+2011-06-23 Gabriel Charette <gchare@google.com>
+
+ * name-lookup.h (cp_binding_level): Removed unused
+ member names_size. Update all users.
+
+2011-06-23 Jason Merrill <jason@redhat.com>
+
+ * typeck2.c (build_functional_cast): Strip cv-quals for value init.
+ * init.c (build_zero_init_1): Not here.
+
+ PR c++/35255
+ * pt.c (resolve_overloaded_unification): Fix DR 115 handling.
+
+2011-06-23 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/44625
+ * decl2.c (build_anon_union_vars): Early return error_mark_node
+ for a nested anonymous struct.
+
+2011-06-23 Jason Merrill <jason@redhat.com>
+
+ PR c++/49507
+ * decl2.c (mark_used): Don't call synthesize_method for
+ functions defaulted outside the class.
+
+ * optimize.c (maybe_clone_body): Set linkage flags before
+ cgraph_same_body_alias.
+
+ PR c++/49440
+ * class.c (set_linkage_according_to_type): Hand off to
+ determine_visibility.
+
+ PR c++/49395
+ * init.c (build_zero_init_1): Strip cv-quals from scalar types.
+
+ PR c++/36435
+ * pt.c (most_specialized_instantiation): Do check return types.
+
+2011-06-22 Jason Merrill <jason@redhat.com>
+
+ PR c++/49260
+ * call.c (build_call_a): Set cp_function_chain->can_throw here.
+ (build_cxx_call): Not here.
+
+2011-06-21 Jason Merrill <jason@redhat.com>
+
+ PR c++/49172
+ * decl.c (cp_finish_decl): Adjust init_const_expr_p for refs.
+ (grokdeclarator): constexpr doesn't apply const for refs.
+ * parser.c (cp_parser_initializer_clause): Don't call
+ maybe_constant_value here.
+ * call.c (initialize_reference): Handle constexpr.
+
+ PR c++/49482
+ * semantics.c (maybe_add_lambda_conv_op): Call mark_exp_read for
+ static fn parameters.
+
+ * call.c (add_builtin_candidates): Use cv_unqualified rather than
+ TYPE_MAIN_VARIANT.
+ * pt.c (tsubst_arg_types): Likewise.
+ * except.c (build_throw): Use cv_unqualified.
+
+ PR c++/49418
+ * call.c (cxx_type_promotes_to): Don't strip cv-quals.
+ * semantics.c (lambda_return_type): Strip them here.
+
+2011-06-21 Andrew MacLeod <amacleod@redhat.com>
+
+ * semantics.c: Add sync_ or SYNC__ to builtin names.
+
+2011-06-20 Jason Merrill <jason@redhat.com>
+
+ PR c++/49216
+ * init.c (build_vec_init): Don't try to use a CONSTRUCTOR when
+ base is a pointer.
+ * typeck2.c (process_init_constructor_array): Use {} for classes,
+ too.
+ * call.c (convert_like_real): Handle substitution failure.
+
+ PR c++/48138
+ * pt.c (canonicalize_type_argument): New.
+ (convert_template_argument, unify): Use it.
+
+ PR c++/47080
+ * call.c (rejection_reason_code): Add rr_explicit_conversion.
+ (print_z_candidate): Handle it.
+ (explicit_conversion_rejection): New.
+ (build_user_type_conversion_1): Reject an explicit conversion
+ function that requires more than a qualification conversion.
+
+ PR c++/47635
+ * decl.c (grokdeclarator): Don't set ctype to an ENUMERAL_TYPE.
+
+ PR c++/48138
+ * tree.c (strip_typedefs): Use build_aligned_type.
+
+ PR c++/49205
+ * call.c (sufficient_parms_p): Allow parameter packs too.
+
+ PR c++/43321
+ * semantics.c (describable_type): Remove.
+ * cp-tree.h: Likewise.
+ * decl.c (cp_finish_decl): Don't call it.
+ * init.c (build_new): Likewise.
+ * parser.c (cp_parser_omp_for_loop): Likewise.
+ * pt.c (tsubst_decl): Likewise.
+ (do_auto_deduction): If we fail in a template, try again
+ at instantiation time.
+
+ PR c++/43831
+ * parser.c (cp_parser_lambda_introducer): Complain about redundant
+ captures.
+ * semantics.c (add_capture): Likewise.
+ (register_capture_members): Clear IDENTIFIER_MARKED.
+
+2011-06-17 Jason Merrill <jason@redhat.com>
+
+ PR c++/49458
+ * call.c (convert_class_to_reference_1): Allow binding function
+ lvalue to rvalue reference.
+
+ PR c++/43912
+ Generate proxy VAR_DECLs for better lambda debug info.
+ * cp-tree.h (FUNCTION_NEEDS_BODY_BLOCK): Add lambda operator().
+ (LAMBDA_EXPR_PENDING_PROXIES): New.
+ (struct tree_lambda_expr): Add pending_proxies.
+ * name-lookup.c (pushdecl_maybe_friend_1): Handle capture shadowing.
+ (qualify_lookup): Use is_lambda_ignored_entity.
+ * parser.c (cp_parser_lambda_expression): Don't adjust field names.
+ Call insert_pending_capture_proxies.
+ (cp_parser_lambda_introducer): Use this_identifier.
+ (cp_parser_lambda_declarator_opt): Call the object parameter
+ of the op() "__closure" instead of "this".
+ (cp_parser_lambda_body): Call build_capture_proxy.
+ * semantics.c (build_capture_proxy, is_lambda_ignored_entity): New.
+ (insert_pending_capture_proxies, insert_capture_proxy): New.
+ (is_normal_capture_proxy, is_capture_proxy): New.
+ (add_capture): Add __ to field names here, return capture proxy.
+ (add_default_capture): Use this_identifier, adjust to expect
+ add_capture to return a capture proxy.
+ (outer_lambda_capture_p, thisify_lambda_field): Remove.
+ (finish_id_expression, lambda_expr_this_capture): Adjust.
+ (build_lambda_expr): Initialize LAMBDA_EXPR_PENDING_PROXIES.
+ * pt.c (tsubst_copy_and_build): Check that LAMBDA_EXPR_PENDING_PROXIES
+ is null.
+
+ * name-lookup.c (pushdecl_maybe_friend_1): Do check for shadowing
+ of artificial locals.
+
+ * parser.c (cp_parser_lambda_expression): Clear
+ LAMBDA_EXPR_THIS_CAPTURE after parsing.
+ * pt.c (tsubst_copy_and_build): Make sure it isn't set.
+
+ * cp-tree.h (struct tree_lambda_expr): Change common to typed.
+ Move non-pointers to end of struct.
+
+ * pt.c (tsubst_decl): Handle DECL_VALUE_EXPR on reference.
+ * decl.c (check_initializer): Handle DECL_VALUE_EXPR_P.
+
+ * semantics.c (finish_non_static_data_member): Preserve dereference
+ in template.
+
+2011-06-16 Jason Merrill <jason@redhat.com>
+
+ PR c++/44160
+ * parser.c (cp_parser_lambda_body): Share code between
+ simple and complex cases instead of using cp_parser_function_body.
+
+ PR c++/45378
+ * decl.c (check_initializer): Check narrowing.
+
+ PR c++/49229
+ * pt.c (tsubst_decl) [FUNCTION_DECL]: Handle substitution failure.
+
+ PR c++/49251
+ * semantics.c (finish_id_expression): Mark even dependent
+ variables as used.
+
+ PR c++/49420
+ * error.c (dump_template_argument): Don't try to omit default
+ template args from an argument pack.
+
+2011-06-15 H.J. Lu <hongjiu.lu@intel.com>
+
+ PR c++/49412
+ * decl.c (get_dso_handle_node): Mark __dso_handle hidden if
+ assembler supports hidden visibility.
+
+2011-06-14 Jason Merrill <jason@redhat.com>
+
+ PR c++/49107
+ * cp-tree.h (DEFERRED_NOEXCEPT_SPEC_P): Handle overload.
+ * method.c (defaulted_late_check): Only maybe_instantiate_noexcept
+ if the declaration had an exception-specifier.
+ (process_subob_fn): Don't maybe_instantiate_noexcept.
+ * pt.c (maybe_instantiate_noexcept): Handle overload.
+ * typeck2.c (nothrow_spec_p_uninst): New.
+ (merge_exception_specifiers): Add 'fn' parm. Build up overload.
+ * typeck.c (merge_types): Adjust.
+
+ * pt.c (deduction_tsubst_fntype): Don't save input_location.
+ (maybe_instantiate_noexcept): Likewise.
+
+2011-06-14 Joseph Myers <joseph@codesourcery.com>
+
+ * Make-lang.in (cp/method.o): Update dependencies.
+ * method.c: Include common/common-target.h.
+ (use_thunk): Use targetm_common.have_named_sections.
+
+2011-06-14 Steve Ellcey <sje@cup.hp.com>
+
+ * decl.c (cxx_init_decl_processing): Use ptr_mode instead of Pmode.
+
+2011-06-14 Jason Merrill <jason@redhat.com>
+
+ * error.c (type_to_string): Print typedef-stripped version too.
+
+ PR c++/49117
+ * call.c (perform_implicit_conversion_flags): Print source type as
+ well as expression.
+
+ PR c++/49389
+ * typeck2.c (build_m_component_ref): Preserve rvalueness.
+
+ PR c++/49369
+ * class.c (build_base_path): Fix cv-quals in unevaluated context.
+
+ PR c++/49290
+ * semantics.c (cxx_fold_indirect_ref): Local, more permissive copy
+ of fold_indirect_ref_1.
+ (cxx_eval_indirect_ref): Use it.
+
+2011-06-11 Jan Hubicka <jh@suse.cz>
+
+ * decl2.c (cp_write_global_declarations): Process aliases; look trhough
+ same body aliases.
+
+2011-06-10 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/41769
+ * decl.c (grokdeclarator): Reject operator names in parameters.
+
+2011-06-10 Jan Hubicka <jh@suse.cz>
+
+ * decl2.c (clear_decl_external): New functoin.
+ (cp_write_global_declarations): Use it.
+
+2011-06-10 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * cp-tree.h (error_operand_p): Remove.
+
+2011-06-09 David Krauss <potswa@mac.com>
+
+ PR c++/49118
+ * typeck2.c (build_x_arrow): Push fake template context
+ to produce diagnostic on acyclic endless operator-> drill-down.
+ * call.c (build_new_op): Change Boolean overload status
+ value to a pointer to the overload function.
+ * cp-tree.h: Likewise.
+ * typeck.c: Likewise.
+ * parser.c: Likewise.
+ * decl2.c: Likewise.
+ * pt.c: Likewise.
+
+2011-06-09 Jason Merrill <jason@redhat.com>
+
+ * semantics.c (maybe_constant_value): Handle overflowed input.
+ (non_const_var_error): Handle non-constant DECL_INITIAL.
+
+ * pt.c (build_non_dependent_expr): Use fold_non_dependent_expr_sfinae.
+
+ * parser.c (cp_parser_constant_expression): Just return the
+ non-constant expression.
+
+ * semantics.c (finish_compound_literal): Set TREE_HAS_CONSTRUCTOR.
+
+2011-06-09 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/29003
+ * decl.c (grokdeclarator): Reject operator names in typedefs.
+
+2011-06-08 Jason Merrill <jason@redhat.com>
+
+ PR c++/49107
+ * cp-tree.def (DEFERRED_NOEXCEPT): New.
+ * cp-tree.h (struct tree_deferred_noexcept): New.
+ (DEFERRED_NOEXCEPT_PATTERN, DEFERRED_NOEXCEPT_ARGS): New.
+ (DEFERRED_NOEXCEPT_SPEC_P): New.
+ (enum cp_tree_node_structure_enum): Add TS_CP_DEFERRED_NOEXCEPT.
+ (union lang_tree_node): Add tree_deferred_noexcept.
+ (maybe_instantiate_noexcept): Declare.
+ * cp-objcp-common.c (cp_tree_size): Handle DEFERRED_NOEXCEPT.
+ * error.c (dump_exception_spec): Likewise.
+ * cxx-pretty-print.c (pp_cxx_exception_specification): Likewise.
+ * ptree.c (cxx_print_xnode): Likewise.
+ * tree.c (cp_tree_equal): Likewise.
+ * decl.c (cp_tree_node_structure): Likewise.
+ (duplicate_decls): Call maybe_instantiate_noexcept.
+ * except.c (build_noexcept_spec): Handle DEFERRED_NOEXCEPT.
+ (nothrow_spec_p, type_noexcept_p, type_throw_all_p): Check
+ DEFERRED_NOEXCEPT_SPEC_P.
+ * typeck2.c (merge_exception_specifiers): Likewise.
+ * decl2.c (mark_used): Call maybe_instantiate_noexcept.
+ * method.c (process_subob_fn, defaulted_late_check): Likewise.
+ * pt.c (tsubst_exception_specification): Add defer_ok parm.
+ Build DEFERRED_NOEXCEPT.
+ (maybe_instantiate_noexcept): New.
+ (tsubst, regenerate_decl_from_template, instantiate_decl): Adjust.
+ * search.c (check_final_overrider): Call maybe_instantiate_noexcept.
+
+ * semantics.c (potential_constant_expression_1): Handle destructor
+ call.
+
+2011-06-08 Jakub Jelinek <jakub@redhat.com>
+
+ * cp-tree.h (struct tinst_level): Add chain_next GTY
+ markup.
+
+2011-06-08 Jason Merrill <jason@redhat.com>
+
+ PR c++/49322
+ * pt.c (deduction_tsubst_fntype): Don't free the tinst entry
+ if a pending_template entry is pointing at it.
+
+2011-06-07 Jason Merrill <jason@redhat.com>
+
+ PR c++/48969
+ PR c++/44175
+ * error.c (subst_to_string): New.
+ (cp_printer): Use it for 'S'.
+ (print_instantiation_partial_context_line): Handle subst context.
+ * pt.c (push_tinst_level): Handle subst context.
+ (deduction_tsubst_fntype): Don't track specific substitutions.
+ Use push_tinst_level.
+
+ * pt.c (deduction_tsubst_fntype): Use push_deduction_access_scope.
+ (fn_type_unification): Don't call push_deduction_access_scope here.
+
+2011-06-06 Jason Merrill <jason@redhat.com>
+
+ PR c++/48780
+ * typeck.c (perform_integral_promotions): Don't promote scoped enums.
+ * call.c (convert_arg_to_ellipsis): Promote them here in old ABI.
+
+2011-06-06 Nicola Pero <nicola.pero@meta-innovation.com>,
+
+ PR obj-c++/48275
+ * parser.c (cp_parser_objc_at_property_declaration): Allow setter
+ and getter names to use all the allowed method names.
+
+2011-06-06 Jason Merrill <jason@redhat.com>
+
+ PR c++/49298
+ * semantics.c (potential_constant_expression_1): Handle FIELD_DECL.
+
+ PR objc++/49221
+ * decl.c (cp_finish_decl): Check DECL_FUNCTION_SCOPE_P rather than
+ at_function_scope_p.
+
+ PR c++/49134
+ * tree.c (build_target_expr): Deal with ARM ABI tweaks.
+
+2011-06-04 Jonathan Wakely <jwakely.gcc@gmail.com>
+
+ * init.c (build_delete): Warn when deleting type with non-virtual
+ destructor.
+
+2011-06-03 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/49276
+ * mangle.c (write_nested_name): Use CP_DECL_CONTEXT instead of
+ DECL_CONTEXT.
+
+2011-06-01 Jason Merrill <jason@redhat.com>
+
+ * pt.c (build_non_dependent_expr): Remove special handling of
+ REFERENCE_REF_P.
+
+ PR c++/44175
+ * pt.c (template_args_equal): Handle one arg being NULL_TREE.
+ (deduction_tsubst_fntype): Handle excessive non-infinite recursion.
+
+ PR c++/49253
+ * typeck2.c (build_x_arrow): Don't use build_min_nt.
+
+2010-05-31 Fabien Chêne <fabien@gcc.gnu.org>
+
+ PR c++/48010
+ * name-lookup.c (supplement_binding_1): If the old binding was a
+ type name, also check that the DECL actually refers to the same
+ type or is not a type.
+
+2011-05-31 Jason Merrill <jason@redhat.com>
+
+ PR c++/44870
+ * tree.c (lvalue_kind): Recurse on NON_DEPENDENT_EXPR. Handle
+ ARROW_EXPR, TYPEID_EXPR, and arbitrary class-valued expressions.
+ (build_min_non_dep): Preserve reference refs.
+ (build_min_non_dep_call_vec): Likewise
+
+2011-05-30 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/49223
+ * semantics.c (finish_omp_clauses): Call require_complete_type
+ even for copyin/copyprivate clauses. Only call
+ cxx_omp_create_clause_info if inner_type is COMPLETE_TYPE_P.
+
+2011-05-28 Jason Merrill <jason@redhat.com>
+
+ PR c++/46124
+ * parser.c (cp_parser_lambda_expression): Improve error recovery.
+ (cp_parser_lambda_declarator_opt): Likewise. Return bool.
+
+2011-05-27 Jason Merrill <jason@redhat.com>
+
+ PR c++/47277
+ * parser.c (cp_parser_pseudo_destructor_name): Commit to parse
+ after we see the ~.
+
+ * mangle.c (mangle_decl_string): Make sure we don't try to mangle
+ templates.
+
+ PR c++/47049
+ * semantics.c (maybe_add_lambda_conv_op): Fix COMDAT sharing.
+ * decl.c (start_preparsed_function): Don't call comdat_linkage for
+ a template.
+
+ PR c++/47132
+ * mangle.c (write_expression): Handle MODOP_EXPR.
+
+ PR c++/47277
+ * parser.c (cp_parser_unqualified_id): Don't check
+ constructor_name_p for enums.
+
+ PR c++/47687
+ * pt.c (dependent_type_p_r): Avoid infinite recursion.
+
+ PR c++/48284
+ * error.c (dump_expr) [COMPONENT_REF]: Use pp_cxx_dot
+ with INDIRECT_REF of REFERENCE_TYPE.
+
+ PR c++/49181
+ * pt.c (get_mostly_instantiated_function_type): Use push_access_scope.
+
+2011-05-27 Nathan Froyd <froydnj@codesourcery.com>
+
+ * cp-tree.h (building_stmt_tree): Delete.
+ * decl.c (save_function_data): Tweak initializer for x_cur_stmt_list.
+ (build_aggr_init_full_exprs): Call building_stmt_list_p
+ instead of building_stmt_tree.
+ (initialize_local_var): Likewise.
+ (finish_function): Likewise.
+ * decl2.c (finish_anon_union): Likewise.
+ * init.c (begin_init_stmts): Likewise.
+ (finish_init_stmts): Likewise.
+ (expand_aggr_init_1): Likewise.
+ * name-lookup.c (do_local_using_decl): Likewise.
+ (do_namespace_alias): Likewise.
+ (do_using_directive): Likewise.
+ (cp_emit_debug_info_for_using): Likewise.
+ * semantics.c (add_stmt): Assert that stmt_list_stack is non-empty.
+
+2011-05-27 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/42056
+ * typeck2.c (build_functional_cast): Complain early for invalid uses
+ of 'auto' and set type to error_mark_node.
+
+2011-05-26 Jason Merrill <jason@redhat.com>
+
+ PR c++/47721
+ * parser.c (cp_parser_member_declaration): Allow friend T.
+ * friend.c (make_friend_class): Ignore non-classes.
+ * pt.c (instantiate_class_template_1): Handle TEMPLATE_TYPE_PARM.
+
+ DR 1004
+ * pt.c (convert_template_argument): Don't complain about using
+ injected-class-name as template template argument.
+
+ PR c++/47956
+ * decl.c (check_static_variable_definition): Now static.
+ (cp_finish_decl): Call it here.
+ (grokdeclarator): Not here.
+ * pt.c (instantiate_class_template_1): Or here.
+ * cp-tree.h: Don't declare it.
+
+2011-05-26 Janis Johnson <janis187@us.ibm.com>
+ Nathan Froyd <froydnj@codesourcery.com>
+
+ PR c++/2288
+ PR c++/18770
+ * name-lookup.h (enum scope_kind): Add sk_cond.
+ * name-lookup.c (pushdecl_maybe_friend): Get scope of shadowed local.
+ Detect and report error for redeclaration from for-init or if
+ or switch condition.
+ (begin_scope): Handle sk_cond.
+ * semantics.c (begin_if_stmt): Use sk_cond.
+ (begin switch_stmt): Ditto.
+
+2011-05-26 Jason Merrill <jason@redhat.com>
+
+ PR c++/48211
+ * name-lookup.h (cp_class_binding): Make base a pointer.
+ * name-lookup.c (new_class_binding): Adjust.
+ (poplevel_class): Adjust.
+
+ PR c++/48424
+ * decl.c (grokparms): Function parameter packs don't need to
+ go at the end.
+ * pt.c (type_unification_real): But they aren't deduced otherwise.
+
+2011-05-25 Jason Merrill <jason@redhat.com>
+
+ PR c++/48536
+ * decl.c (build_enumerator): If incremented enumerator won't fit in
+ previous integral type, find one it will fit in.
+
+ PR c++/48599
+ * decl.c (create_array_type_for_decl): Complain about array of auto.
+
+ PR c++/44994
+ PR c++/49156
+ * error.c (dump_template_bindings): Set processing_template_decl
+ for a partial instantiation.
+
+ PR c++/45401
+ * decl.c (grokdeclarator): Don't change type when adding rvalue ref
+ to another reference type.
+
+ PR c++/44311
+ * decl.c (case_conversion): New.
+ (finish_case_label): Use it.
+
+ * ptree.c (cxx_print_xnode): Handle ARGUMENT_PACK_SELECT.
+
+ PR c++/45698
+ * pt.c (dependent_template_arg_p): See through ARGUMENT_PACK_SELECT.
+
+ PR c++/46005
+ * decl.c (grokdeclarator): Complain about auto typedef.
+
+ PR c++/46245
+ * decl.c (grokdeclarator): Complain later for auto parameter.
+ * pt.c (splice_late_return_type): Handle use in a template
+ type-parameter.
+
+ PR c++/46696
+ * typeck.c (cp_build_modify_expr): Check DECL_DEFAULTED_FN.
+
+ PR c++/47184
+ * parser.c (cp_parser_parameter_declaration): Recognize
+ list-initialization.
+ (cp_parser_direct_declarator): Check for the closing
+ paren before parsing definitely.
+
+ PR c++/48935
+ * parser.c (cp_parser_constructor_declarator_p): Don't check
+ constructor_name_p for enums.
+ (cp_parser_diagnose_invalid_type_name): Correct error message.
+
+ PR c++/45418
+ * init.c (perform_member_init): Handle list-initialization
+ of array of non-trivial class type.
+
+ PR c++/45080
+ * pt.c (instantiate_class_template_1): Call maybe_add_lambda_conv_op.
+ * semantics.c (lambda_function): Check COMPLETE_OR_OPEN_TYPE_P.
+
+ PR c++/48292
+ * pt.c (tsubst_decl) [PARM_DECL]: Handle partial instantiation of
+ function parameter pack.
+ (tsubst_pack_expansion): Likewise.
+
+ * cp-objcp-common.c (cp_common_init_ts): TYPE_ARGUMENT_PACK has
+ TS_COMMON.
+
+2011-05-25 Jakub Jelinek <jakub@redhat.com>
+
+ * cp-objcp-common.c (cp_common_init_ts): Mark CTOR_INITIALIZER
+ as TS_TYPED.
+
+ PR c++/49136
+ * semantics.c (cxx_eval_bit_field_ref): Handle the
+ case when BIT_FIELD_REF doesn't cover only a single field.
+
+2011-05-24 Jason Merrill <jason@redhat.com>
+
+ PR c++/49042
+ * pt.c (get_mostly_instantiated_function_type): Use
+ push_deferring_access_checks rather than set flag_access_control.
+
+2011-05-24 Nicola Pero <nicola.pero@meta-innovation.com>,
+
+ * parser.c (cp_parser_objc_class_ivars): Deal gracefully with a
+ syntax error in declaring an ObjC instance variable.
+
+2011-05-24 Jason Merrill <jason@redhat.com>
+
+ PR c++/48884
+ * class.c (pushclass): Accept NULL argument.
+ (popclass): Deal with popping null class.
+ * pt.c (push_access_scope, pop_access_scope): Use them rather than
+ push_to_top_level/pop_from_top_level.
+ (push_deduction_access_scope, pop_defarg_context): New.
+ (fn_type_unification): Use them.
+ * name-lookup.c (lookup_name_real_1): Check current_class_type.
+
+2011-05-24 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * decl.c (grokdeclarator): Use current_class_name.
+
+2011-05-24 Joseph Myers <joseph@codesourcery.com>
+
+ * Make-lang.in (GXX_OBJS): Remove prefix.o.
+ (g++$(exeext)): Use libcommon-target.a.
+ (CXX_C_OBJS): Remove prefix.o.
+
+2011-05-23 Jason Merrill <jason@redhat.com>
+
+ * pt.c (tsubst_copy_and_build): Use current_class_name.
+
+ PR c++/49102
+ * call.c (convert_arg_to_ellipsis): Call force_rvalue.
+
+ PR c++/49105
+ * typeck.c (cp_build_c_cast): Don't strip cv-quals when
+ converting to reference.
+ (build_static_cast_1): Update for glvalues.
+
+ PR c++/49105
+ * typeck.c (build_const_cast_1): Handle rvalue references.
+
+ PR c++/47263
+ * decl.c (use_eh_spec_block): Do use an EH spec block for a
+ lambda op().
+
+ PR c++/49058
+ * call.c (splice_viable): Be strict in templates.
+
+ PR c++/47336
+ * error.c (dump_template_bindings): Suppress access control.
+
+ PR c++/47544
+ * pt.c (instantiate_decl): Handle =default.
+
+ PR c++/48617
+ * pt.c (invalid_nontype_parm_type_p): Allow DECLTYPE_TYPE.
+
+2011-05-23 Nathan Froyd <froydnj@codesourcery.com>
+
+ * call.c (build_over_call): Tweak call to check_function_arguments.
+ * typeck.c (cp_build_function_call_vec): Likewise.
+
+2011-05-23 Jonathan Wakely <jwakely.gcc@gmail.com>
+
+ PR c++/18016
+ * init.c (perform_member_init): Check for self-initialization.
+
+2011-05-22 Jason Merrill <jason@redhat.com>
+
+ PR c++/48647
+ * typeck.c (composite_pointer_type_r): Return error_mark_node
+ on error in SFINAE context.
+
+2011-05-20 Jason Merrill <jason@redhat.com>
+
+ PR c++/48945
+ * decl.c (grokdeclarator): Don't add set const function-cv-qual
+ for constexpr fns to memfn_quals, just add it to the type.
+ (revert_static_member_fn): Don't complain about quals.
+ (check_static_quals): New.
+ (grokfndecl): Call it.
+ (start_preparsed_function): Don't call revert_static_member_fn.
+
+ PR c++/48945
+ * decl.c (revert_static_member_fn): Ignore const on constexpr fn.
+
+ PR c++/48780
+ * cvt.c (type_promotes_to): Don't promote scoped enums.
+
+ PR c++/49066
+ * decl.c (duplicate_decls): Preserve DECL_DELETED_FN.
+
+ PR c++/48873
+ * tree.c (stabilize_expr): Fix typo.
+
+ DR 1073
+ PR c++/49082
+ * typeck.c (comp_except_specs): noexcept(false) is not compatible
+ with throw(type-list).
+ * typeck2.c (merge_exception_specifiers): noexcept(false)
+ beats any more limited specification.
+
+ PR c++/24163
+ PR c++/29131
+ * pt.c (tsubst_copy_and_build) [CALL_EXPR]: Avoid repeating
+ unqualified lookup.
+ * semantics.c (perform_koenig_lookup): Add complain parm.
+ * cp-tree.h: Adjust.
+ * parser.c (cp_parser_postfix_expression): Adjust.
+ (cp_parser_perform_range_for_lookup): Adjust.
+
+2011-05-20 Jason Merrill <jason@redhat.com>
+
+ * semantics.c (finish_call_expr): SET_EXPR_LOCATION.
+
+2011-05-20 Joseph Myers <joseph@codesourcery.com>
+
+ * Make-lang.in (GXX_OBJS): Remove intl.o and version.o.
+
+2011-05-19 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/49043
+ * decl.c (check_omp_return): Stop searching on sk_function_parms.
+
+ PR c++/48869
+ * method.c (get_dtor, get_copy_ctor): Add COMPLAIN argument,
+ pass it down to locate_fn_flags.
+ * cp-tree.h (get_dtor, get_copy_ctor): Adjust prototypes.
+ * semantics.c (cxx_omp_create_clause_info): Adjust callers.
+ * cp-gimplify.c: Include splay-tree.h.
+ (splay_tree_compare_decl_uid, omp_var_to_track,
+ omp_cxx_notice_variable): New functions.
+ (struct cp_genericize_omp_taskreg): New type.
+ (struct cp_genericize_data): Add omp_ctx field.
+ (cp_genericize_r): Attempt to determine implicitly determined
+ firstprivate class type variables.
+ (cp_genericize): Clear omp_ctx.
+ * Make-lang.in (cp/cp-gimplify.o): Depend on $(SPLAY_TREE_H).
+
+2011-05-18 Jason Merrill <jason@redhat.com>
+
+ PR c++/48948
+ PR c++/49015
+ * class.c (finalize_literal_type_property): Do check
+ for constexpr member functions of non-literal class.
+ (finish_struct): Don't call check_deferred_constexpr_decls.
+ * cp-tree.h: Don't declare it.
+ (DECL_DEFERRED_CONSTEXPR_CHECK): Remove.
+ * decl.c (grok_special_member_properties): Don't check it
+ (grokfnedcl): Don't call validate_constexpr_fundecl.
+ (start_preparsed_function): Do call it.
+ * pt.c (tsubst_decl): Don't call it.
+ (instantiate_class_template_1): Don't call
+ check_deferred_constexpr_decls.
+ * semantics.c (literal_type_p): Check for any incompleteness.
+ (ensure_literal_type_for_constexpr_object): Likewise.
+ (is_valid_constexpr_fn): Revert deferral changes.
+ (validate_constexpr_fundecl): Likewise.
+ (register_constexpr_fundef): Likewise.
+ (check_deferred_constexpr_decls): Remove.
+
+2011-05-16 Jason Merrill <jason@redhat.com>
+
+ PR c++/48969
+ * pt.c (deduction_tsubst_fntype): Use a VEC initially.
+
+2011-05-15 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * cxx-pretty-print.c: Update comment.
+ * semantics.c (trait_expr_value, finish_trait_expr):
+ Reorder the cases.
+ * parser.c (cp_parser_primary_expression): Likewise.
+
+2011-05-15 Jonathan Wakely <jwakely.gcc@gmail.com>
+
+ PR c++/48994
+ * parser.c (cp_parser_perform_range_for_lookup): Call complete_type.
+
+2011-05-13 Ville Voutilainen <ville.voutilainen@gmail.com>
+
+ Implement final on class.
+ * class.c (check_bases): Diagnose derivation from a final class.
+ * cp-tree.h (lang_type_class): Add is_final and adjust dummy.
+ (CLASSTYPE_FINAL): New.
+ * parser.c (cp_parser_class_head): Parse class-virt-specifier, set
+ CLASSTYPE_FINAL.
+ * pt.c (instantiate_class_template_1): Copy CLASSTYPE_FINAL.
+
+2011-05-13 Jason Merrill <jason@redhat.com>
+
+ PR c++/48969
+ * pt.c (deduction_tsubst_fntype): New.
+ (fn_type_unification): Use it.
+ (init_template_processing): Initialize hash table.
+ (print_template_statistics): Print hash table stats.
+
+ * call.c (build_op_call): Use timevar_cond_start/stop.
+ (build_user_type_conversion): Likewise.
+
+2011-05-12 Jason Merrill <jason@redhat.com>
+
+ * cp-tree.h (DECL_DEFERRED_CONSTEXPR_CHECK): New.
+ * semantics.c (validate_constexpr_fundecl): Set it.
+ (check_deferred_constexpr_decls): Clear it.
+ (register_constexpr_fundef): Make sure it isn't set.
+ * decl.c (grok_special_member_properties): Check it.
+
+2011-05-11 Jason Merrill <jason@redhat.com>
+
+ PR c++/48948
+ * semantics.c (validate_constexpr_fundecl): Defer checking if
+ an argument type is being defined.
+ (is_valid_constexpr_fn): Add defer_ok parm.
+ (cxx_eval_call_expression): Adjust.
+ (check_deferred_constexpr_decls): New.
+ (literal_type_p): Make sure type isn't being defined.
+ (ensure_literal_type_for_constexpr_object): Handle type being defined.
+ * cp-tree.h: Declare check_deferred_constexpr_decls.
+ * decl.c (grokfndecl): Call validate_constexpr_fundecl here.
+ (start_preparsed_function, cp_finish_decl): Not here.
+ * class.c (finalize_literal_type_property): Don't call
+ validate_constexpr_fundecl.
+ (finish_struct): Call check_deferred_constexpr_decls.
+ * pt.c (tsubst_decl): Call validate_constexpr_fundecl.
+ (instantiate_class_template): Call check_deferred_constexpr_decls.
+
+ * semantics.c (validate_constexpr_fundecl): Check DECL_TEMPLATE_INFO
+ rather than DECL_TEMPLATE_INSTANTIATION.
+ (cxx_eval_call_expression): Likewise.
+
+ * semantics.c (register_constexpr_fundef): Add to hash table here.
+ (validate_constexpr_fundecl): Not here.
+
+ * decl.c (grokdeclarator): Only set DECL_DECLARED_CONSTEXPR_P once.
+
+ * pt.c (build_non_dependent_expr): Don't check null_ptr_cst_p,
+ do call maybe_constant_value in C++0x mode.
+ * semantics.c (cxx_eval_constant_expression): Handle TEMPLATE_DECL.
+
+ PR c++/48745
+ * pt.c (value_dependent_expr_p): Handle CONSTRUCTOR.
+
+2011-05-11 Nathan Froyd <froydnj@codesourcery.com>
+
+ * cp-tree.h (TYPENAME_TYPE_FULLNAME, TYPEOF_TYPE_EXPR): Use
+ TYPE_VALUES_RAW.
+ (UNDERLYING_TYPE_TYPE, DECLTYPE_TYPE_EXPR): Likewise.
+ (DECLTYPE_TYPE_ID_EXPR_OR_MEMBER_ACCESS_P): Likewise.
+ (TEMPLATE_TYPE_PARM_INDEX): Likewise.
+
+2011-05-10 Jason Merrill <jason@redhat.com>
+
+ PR c++/48930
+ * class.c (type_build_ctor_call): New.
+ * cp-tree.h: Declare it.
+ * decl.c (check_initializer): Use it instead of
+ TYPE_NEEDS_CONSTRUCTING.
+ * init.c (build_value_init, build_value_init_noctor): Likewise.
+ (perform_member_init, expand_aggr_init_1, build_new_1): Likewise.
+ (build_vec_init): Likewise.
+ * typeck2.c (process_init_constructor_array): Likewise.
+ (process_init_constructor_record): Likewise.
+
+ PR c++/48736
+ * pt.c (tsubst_copy_and_build): Handle substitution of a pack
+ expansion producing another expansion.
+
+2011-05-10 Ville Voutilainen <ville.voutilainen@gmail.com>
+
+ Fixes for override/final.
+ * class.c (check_for_override): Diagnose final on a nonvirtual
+ member function, diagnose override for a virtual with no matching
+ override. Don't fiddle around with DECL_VINDEX.
+
+2011-05-10 Nathan Froyd <froydnj@codesourcery.com>
+
+ * cp-tree.def (EXPR_PACK_EXPANSION): Add an operand.
+ * cp-objcp-common.c (cp_common_init_ts): Mark it as TS_TYPED.
+ * cp-tree.h (PACK_EXPANSION_PARAMETER_PACKS): Use the new
+ operand of EXPR_PACK_EXPANSION.
+ (cp_tree_operand_length): Declare.
+ * tree.c (cp_tree_operand_length): Define.
+ (cp_tree_equal): Call it.
+ * pt.c (value_dependent_expr_P): Likewise.
+ * mangle.c (write_expression): Likewise.
+
+2011-05-09 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/48737
+ PR c++/48744
+ * decl.c (reshape_init): Take a complain parameter and do
+ not call error if tf_error is not set.
+ (check_initializer, reshape_init_r, reshape_init_array,
+ reshape_init_array_1, reshape_init_vector, reshape_init_class):
+ Adjust.
+ * typeck2.c (digest_init_r): Take a complain parameter and
+ pass it to convert_for_initialization.
+ (digest_init, digest_init_flags, process_init_constructor_array,
+ process_init_constructor_record, process_init_constructor_union,
+ process_init_constructor, digest_init_r): Adjust.
+ * init.c (expand_default_init, build_new_1): Likewise.
+ * typeck.c (cp_build_modify_expr): Likewise.
+ * decl2.c (grokfield): Likewise.
+ * call.c (convert_like_real, convert_default_arg): Likewise.
+ * semantics.c (finish_compound_literal): Pass complain to
+ reshape_init and digest_init.
+ * cp-tree.h: Adjust declarations.
+
+2011-05-07 Fabien Chêne <fabien@gcc.gnu.org>
+
+ PR c++/48859
+ * init.c (diagnose_uninitialized_cst_or_ref_member_1): stop the
+ recursion if there is user defined constructor.
+
+2011-05-09 Jason Merrill <jason@redhat.com>
+
+ PR c++/34772
+ * decl.c (initialize_local_var): Use DECL_INITIAL for simple
+ initialization.
+
+2011-05-08 Ville Voutilainen <ville.voutilainen@gmail.com>
+
+ Implement final/override for member functions.
+ * class.c (check_for_override): Check for DECL_OVERRIDE_P.
+ * cp-tree.h (DECL_OVERRIDE_P, DECL_FINAL_P): New.
+ (cp_virt_specifiers, enum virt_specifier): New.
+ * decl.c (set_virt_specifiers): New.
+ (grokdeclarator): Use them. Diagnose virt-specifiers on non-fields.
+ * parser.c (make_call_declarator): add virt-specifiers parameter.
+ (cp_parser_lambda_declarator_opt): Adjust.
+ (cp_parser_direct_declarator): Likewise.
+ (cp_parser_virt_specifier_seq_opt): New.
+ * search.c (check_final_overrider): Diagnose attempts to override
+ a final member function.
+
+2011-05-09 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/48574
+ * class.c (fixed_type_or_null): Use type_dependent_p_push to test
+ if the instance has a dependent initializer.
+
+2011-05-08 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/48816
+ * cxx-pretty-print.c (pp_cxx_template_declaration): Remove
+ effectively unused variable.
+
+2011-05-07 Eric Botcazou <ebotcazou@adacore.com>
+
+ * name-lookup.h (global_bindings_p): Adjust prototype.
+ * name-lookup.c (global_bindings_p): Return bool.
+
+2011-05-06 Jason Merrill <jason@redhat.com>
+
+ * decl.c (stabilize_save_expr_r): Set *walk_subtrees as
+ appropriate.
+
+ PR c++/48909
+ * semantics.c (cxx_eval_conditional_expression): Check
+ integer_zerop instead.
+ (potential_constant_expression_1): Likewise.
+
+ PR c++/48911
+ * semantics.c (cxx_eval_array_reference): Handle implicit
+ initializers.
+
+2011-05-06 Nathan Froyd <froydnj@codesourcery.com>
+
+ * cp-tree.h (type_of_this_parm, class_of_this_parm): New functions.
+ * call.c (standard_conversion): Call class_of_this_parm.
+ * cxx-pretty-print.c (pp_cxx_implicit_parameter_type): Likewise.
+ (pp_cxx_direct_abstract_declarator): Likewise.
+ * decl2.c (change_return_type): Likewise.
+ (cp_reconstruct_complex_type): Likewise.
+ * error.c (dump_type_suffix, dump_function_decl): Likewise.
+ * mangle.c (write_function_type): Likewise.
+ * pt.c (unify): Likewise.
+ * typeck.c (merge_types, type_memfn_quals): Likewise.
+ * decl.c (build_this_parm): Call type_of_this_parm.
+
+2011-05-06 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/48838
+ * cp-tree.h (non_static_member_function_p): Declare new function.
+ * tree.c (non_static_member_function_p): Define it.
+ * semantics.c (finish_call_expr): Use it.
+
+2011-05-05 Nathan Froyd <froydnj@codesourcery.com>
+
+ * decl.c (finish_case_label): Omit the loc argument to
+ build_case_label.
+
+2011-05-05 Jason Merrill <jason@redhat.com>
+
+ * cp-tree.h (REFERENCE_REF_P): Just check the type.
+ * cvt.c (convert_from_reference): Adjust.
+ * pt.c (build_non_dependent_expr): Adjust.
+ * semantics.c (finish_offsetof): Adjust.
+ * tree.c (lvalue_kind): Use it.
+
+ PR c++/48873
+ * tree.c (stabilize_expr): Don't make gratuitous copies of classes.
+
+2011-05-05 Eric Botcazou <ebotcazou@adacore.com>
+
+ * decl.c (start_preparsed_function): Do not set
+ dont_save_pending_sizes_p.
+
+2011-05-05 Joseph Myers <joseph@codesourcery.com>
+
+ * parser.c (cp_parser_objc_method_definition_list): Update call to
+ objc_start_method_definition.
+
+2011-05-04 Jason Merrill <jason@redhat.com>
+
+ PR c++/48749
+ * class.c (resolves_to_fixed_type_p): Don't look closely
+ in templates.
+
+2011-05-03 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/28501
+ * call.c (add_builtin_candidate): Handle REALPART_EXPR and
+ IMAGPART_EXPR.
+
+2011-05-02 Lawrence Crowl <crowl@google.com>
+
+ * decl.c: (push_local_name): Change TV_NAME_LOOKUP to start/stop.
+ (poplevel): Refactor POP_TIMEVAR_AND_RETURN to plain code.
+ Change TV_NAME_LOOKUP to start/stop.
+ (define_label): Refactor timevar calls out to a wrapper function.
+ Change TV_NAME_LOOKUP to start/stop.
+ (xref_tag): Likewise.
+ (lookup_label): Refactor timevar calls out to a wrapper function.
+ Change TV_NAME_LOOKUP to start_cond/stop_cond.
+
+ * pt.c: (instantiate_class_template): Add a wrapper to push/pop new
+ TV_TEMPLATE_INST.
+ (instantiate_template): Add a wrapper to push/pop new TV_TEMPLATE_INST.
+ (lookup_template_class): Refactor timevar calls out to a wrapper
+ function. Change use of TV_NAME_LOOKUP to TV_TEMPLATE_INST.
+ (instantiate_decl): Change TV_PARSE to TV_TEMPLATE_INST.
+
+ * name-lookup.c: (store_bindings): Change TV_NAME_LOOKUP to start/stop.
+ (poplevel_class): Change TV_NAME_LOOKUP to start_cond/stop_cond.
+ (push_namespace): Likewise.
+ (pop_nested_namespace): Likewise.
+ (pushdecl_namespace_level): Likewise.
+ (store_class_bindings): Likewise.
+ (push_to_top_level): Likewise.
+ (identifier_type_value): Refactor timevar calls out to a wrapper
+ function. Change TV_NAME_LOOKUP to start/stop.
+ (find_binding): Likewise.
+ (push_using_decl): Likewise.
+ (lookup_arg_dependent): Likewise.
+ (push_using_directive): Likewise.
+ (qualified_lookup_using_namespace): Refactor POP_TIMEVAR_AND_RETURN
+ to plain code. Change TV_NAME_LOOKUP to start/stop.
+ (lookup_type_current_level): Likewise. Refactor inner return to
+ break.
+ (pushdecl_class_level): Refactor POP_TIMEVAR_AND_RETURN to plain
+ code. Change TV_NAME_LOOKUP to start_cond/stop_cond.
+ (pushdecl_top_level_1): Likewise.
+ (lookup_using_namespace): Likewise.
+ (pushdecl_with_scope): Refactor timevar calls out to a wrapper
+ function. Change TV_NAME_LOOKUP to start_cond/stop_cond.
+ (push_overloaded_decl): Likewise.
+ (push_class_level_binding): Likewise.
+ (namespace_binding): Likewise.
+ (set_namespace_binding): Likewise.
+ (supplement_binding): Likewise.
+ (unqualified_namespace_lookup): Likewise.
+ (lookup_name_real): Likewise.
+ (lookup_type_scope): Likewise.
+ (namespace_ancestor): Likewise.
+ (lookup_name_innermost_nonclass_level): Likewise.
+ (pushtag): Likewise.
+ (pop_from_top_level): Likewise.
+ (pushdecl_maybe_friend): Refactor timevar calls out to a wrapper
+ function. Change TV_NAME_LOOKUP to start_cond/stop_cond. Wrap long
+ lines.
+ (add_using_namespace): Refactor timevar calls out to a wrapper
+ function. Change TV_NAME_LOOKUP to start_cond/stop_cond. Bypass
+ wrapper on call to self.
+
+ * decl2.c: (cp_write_global_declarations): Add start/stop of
+ new TV_PHASE_DEFERRED, TV_PHASE_CGRAPH, TV_PHASE_CHECK_DBGINFO.
+ Remove push/pop calls to TV_VARCONST.
+
+ * parser.c: Add include of "timevar.h".
+ (cp_parser_explicit_instantiation): Add push/pop calls to
+ TV_TEMPLATE_INST.
+ (cp_parser_enum_specifier): Add push/pop calls to new TV_PARSE_ENUM.
+ (cp_parser_class_specifier): Add wrapper to add push/pop calls to
+ TV_PARSE_STRUCT.
+ (cp_parser_function_definition_from_specifiers_and_declarator): Add
+ push/pop calls to new TV_PARSE_FUNC or TV_PARSE_INLINE.
+ (cp_parser_late_parsing_for_member): Add push/pop calls to
+ new TV_PARSE_INMETH.
+
+ * call.c: Add include of "timevar.h".
+ (convert_class_to_reference): Wrap and add push/pop calls to
+ TV_OVERLOAD.
+ (build_op_call): Likewise.
+ (build_conditional_expr): Likewise.
+ (build_new_op): Likewise.
+ (build_new_method_call): Likewise.
+ (build_user_type_conversion): Reorganize to single return and add
+ push/pop calls to TV_OVERLOAD.
+ (perform_overload_resolution): Likewise.
+
+ * Make-lang.in: Add dependence of call.o and parser.o on $(TIMEVAR_H).
+
+2011-05-02 Jason Merrill <jason@redhat.com>
+
+ * tree.c (build_vec_init_expr): Take complain parm.
+ (build_vec_init_elt): Likewise. Free arg vector.
+ (diagnose_non_constexpr_vec_init, build_array_copy): Adjust.
+ * cp-tree.h (VEC_INIT_EXPR_SLOT): Use VEC_INIT_EXPR_CHECK.
+ (VEC_INIT_EXPR_INIT): Likewise.
+ Adjust build_vec_init_expr declaration.
+ * init.c (perform_member_init): Adjust.
+
+ Revert:
+ PR c++/40975
+ * cp-tree.def (VEC_INIT_EXPR): Add third operand.
+ * cp-tree.h (VEC_INIT_EXPR_NELTS): New.
+ * cp-gimplify.c (cp_gimplify_expr) [VEC_INIT_EXPR]: Handle it.
+ * tree.c (build_vec_init_expr): Handle getting pointer/nelts.
+ (build_vec_init_elt): Don't expect an array type.
+ (build_array_copy): Adjust.
+ * init.c (perform_member_init): Adjust.
+ (build_new_1): Use build_vec_init_expr.
+
+ PR c++/48834
+ * tree.c (build_vec_init_expr): Set TREE_SIDE_EFFECTS.
+ Protect an explicit target.
+
+ PR c++/48446
+ * decl.c (stabilize_save_expr_r, stabilize_vla_size): New.
+ (compute_array_index_type): Revert earlier 48446 changes.
+ (grokdeclarator): Use stabilize_vla_size.
+
+2011-05-02 Dmitry Gorbachev <d.g.gorbachev@gmail.com>
+ Eric Botcazou <ebotcazou@adacore.com>
+
+ * parser.c (cp_parser_init_declarator): Set pushed_scope to NULL_TREE
+ instead of inappropriate zero values.
+
+2011-05-02 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/47969
+ * decl.c (compute_array_index_type): Check build_expr_type_conversion
+ return value for NULL_TREE.
+
+2011-04-29 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/48606
+ * init.c (perform_member_init): Check build_value_init return
+ value for error_mark_node.
+
+2011-04-29 Diego Novillo <dnovillo@google.com>
+ Le-Chun Wu <lcwu@google.com>
+
+ * call.c (conversion_null_warnings): Also handle assignments
+ when warning about NULL conversions.
+
+2011-04-29 Le-Chun Wu <lcwu@google.com>
+
+ * cp-tree.h (LOOKUP_EXPLICIT_TMPL_ARGS): Define.
+ * call.c (build_new_function_call): Set it for TEMPLATE_ID_EXPRs.
+ (build_over_call): Use it to determine whether to emit a NULL
+ warning for template function instantiations.
+ (build_new_method_call): Set LOOKUP_EXPLICIT_TMPL_ARGS if
+ EXPLICIT_TARGS is set.
+
+2011-04-29 Nicola Pero <nicola.pero@meta-innovation.com>,
+ Mike Stump <mikestump@comcast.net>
+
+ * Make-lang.in ($(srcdir)/cp/cfns.h): Enable the dependency only
+ in maintainer mode. Use the --output-file option of gperf instead
+ of > to prevent creating an empty cp/cfns.h when gperf is not
+ available.
+
+2011-04-28 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/48798
+ * semantics.c (finish_base_specifier): cv-qualified base class
+ is fine, per DR 484.
+
+2011-04-28 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/48656
+ * semantics.c (finish_call_expr): Don't forget BASELINK nodes when
+ considering call expressions involving a member function.
+
+2011-04-28 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/48530
+ * tree.c (build_cplus_new): Check build_target_expr return
+ value for error_mark_node.
+
+2011-04-28 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/48771
+ * semantics.c (literal_type_p): Reference types are literal types,
+ per the FDIS.
+ (valid_type_in_constexpr_fundecl_p): Remove.
+ (is_valid_constexpr_fn): Adjust.
+
+2011-04-27 Jason Merrill <jason@redhat.com>
+
+ PR libstdc++/48760
+ Implement list-initialization of _Complex.
+ * decl.c (reshape_init_r): Allow {real,imag} for _Complex.
+ (check_initializer): Likewise.
+ * call.c (build_complex_conv): New.
+ (implicit_conversion): Call it.
+ (convert_like_real): Handle it.
+ * typeck2.c (check_narrowing): Handle it.
+
+ * init.c (build_vec_delete_1): Look for sfk_deleting_destructor to
+ decide whether to delete.
+ (build_vec_init): Pass sfk_complete_destructor.
+
+ PR c++/40975
+ * cp-tree.def (VEC_INIT_EXPR): Add third operand.
+ * cp-tree.h (VEC_INIT_EXPR_NELTS): New.
+ * cp-gimplify.c (cp_gimplify_expr) [VEC_INIT_EXPR]: Handle it.
+ * tree.c (build_vec_init_expr): Handle getting pointer/nelts.
+ (build_vec_init_elt): Don't expect an array type.
+ (build_array_copy): Adjust.
+ * init.c (perform_member_init): Adjust.
+ (build_new_1): Use build_vec_init_expr.
+
+ * class.c (resolve_address_of_overloaded_function): Don't
+ change OVERLOAD to TREE_LIST.
+ * pt.c (print_candidates_1): Remove nonsensical assert.
+
+ PR c++/48046
+ * parser.c (cp_parser_diagnose_invalid_type_name): Commit
+ to tentative parse sooner.
+
+2011-04-26 Jason Merrill <jason@redhat.com>
+
+ PR c++/42687
+ * parser.c (cp_parser_primary_expression): Set *idk to
+ CP_ID_KIND_NONE for a parenthesized identifier.
+
+ * ptree.c (cxx_print_type) [TYPENAME_TYPE]: Dump fullname.
+ (cxx_print_identifier): Correct indentation.
+
+ PR c++/48530
+ * decl.c (cxx_maybe_build_cleanup): Add complain parm.
+ * tree.c (force_target_expr): Add complain parm.
+ (build_target_expr_with_type): Likewise.
+ (get_target_expr_sfinae): Split out.
+ (build_vec_init_expr, bot_manip): Adjust.
+ * init.c (build_vec_delete, build_vec_delete_1): Add complain parm.
+ (build_delete, build_dtor_call): Likewise.
+ (perform_direct_initialization_if_possible): Adjust.
+ (build_vec_init): Handle error return.
+ * cvt.c (force_rvalue): Add complain parm.
+ Call build_special_member_call directly.
+ * decl2.c (delete_sanity): Add complain parm.
+ (build_cleanup): Adjust.
+ * pt.c (tsubst_copy_and_build, tsubst_expr): Adjust.
+ * semantics.c (finish_stmt_expr_expr): Adjust.
+ (finish_compound_literal): Adjust.
+ * parser.c (cp_parser_delete_expression): Adjust.
+ * typeck2.c (build_functional_cast): Adjust.
+ * cp-tree.h: Adjust.
+
+2011-04-26 Martin Jambor <mjambor@suse.cz>
+
+ * class.c (cp_fold_obj_type_ref): Remove.
+ * cp-tree.h (cp_fold_obj_type_ref): Remove declaration.
+
+2011-04-25 Paolo Carlini <paolo.carlini@oracle.com>
+
+ * cp-tree.def: Add a new UNDERLYING_TYPE tree code.
+ * cp-tree.h (enum cp_trait_kind): Add CPTK_UNDERLYING_TYPE, tidy.
+ (UNDERLYING_TYPE_TYPE): Add.
+ * cp-objcp-common.c (cp_common_init_ts): Mark UNDERLYING_TYPE
+ as TS_COMMON.
+ * parser.c (cp_lexer_next_token_is_decl_specifier_keyword,
+ cp_parser_simple_type_specifier): Handle UNDERLYING_TYPE.
+ (cp_parser_trait_expr): Deal with RID_UNDERLYING_TYPE; tidy.
+ * semantics.c (finish_underlying_type): New.
+ * typeck.c (structural_comptypes): Handle UNDERLYING_TYPE.
+ * error.c (dump_type, dump_type_prefix, dump_type_suffix): Likewise.
+ * cxx-pretty-print.c (p_cxx_type_id): Likewise.
+ * tree.c (cp_walk_subtrees): Likewise.
+ * pt.c (for_each_template_parm_r, tsubst, unify,
+ dependent_type_p_r): Likewise.
+ * mangle.c (write_type): Sorry for __underlying_type.
+
+2011-04-25 Jason Merrill <jason@redhat.com>
+
+ PR c++/48707
+ * decl.c (type_dependent_init_p): New.
+ (cp_finish_decl): Check it.
+ * pt.c (any_type_dependent_elements_p): New.
+ * cp-tree.h: Declare it.
+
+2011-04-20 Jason Merrill <jason@redhat.com>
+
+ * semantics.c (finish_compound_literal): Don't put an array
+ with a dtor in a static variable.
+
+ * call.c (build_over_call): Handle trivial dtor.
+
+ * search.c (lookup_fnfields_slot): Call complete_type.
+
+ PR c++/48594
+ * decl2.c (build_offset_ref_call_from_tree): Move
+ non-dependency of object outside condition.
+
+ PR c++/48657
+ * decl.c (cp_finish_decl): Simplify template handling.
+
+2011-04-20 Jim Meyering <meyering@redhat.com>
+
+ * tree.c (cxx_printable_name_internal): Remove useless if-before-free.
+
+2011-04-19 Jason Merrill <jason@redhat.com>
+
+ PR c++/46304
+ * typeck.c (cp_build_binary_op): Fold COMPLEX_EXPR.
+
+ PR c++/45267
+ * decl.c (duplicate_decls): Keep always_inline attribute
+ in sync with DECL_DISREGARD_INLINE_LIMITS.
+
+2011-04-18 Jason Merrill <jason@redhat.com>
+
+ PR c++/48569
+ * typeck2.c (build_functional_cast): Handle VOID_TYPE.
+
+ PR c++/48537
+ * init.c (build_value_init): Handle UNION_TYPE the same.
+
+2011-04-18 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/48632
+ * parser.c (cp_parser_omp_for_loop): Don't use cp_parser_omp_for_incr
+ for type dependent pointers.
+
+2011-04-18 Jim Meyering <meyering@redhat.com>
+
+ * pt.c (type_unification_real): Fix typo in comment: s/in in/in/.
+
+2011-04-17 Jan Hubicka <jh@suse.cz>
+
+ * semantics.c (finish_goto_stmt): Do set UNINLINABLE flag on computed
+ gotos.
+
+2011-04-17 Jason Merrill <jason@redhat.com>
+
+ PR c++/48531
+ * typeck2.c (build_functional_cast): Disallow array type.
+
+ * tree.c (get_target_expr): Handle VEC_INIT_EXPR.
+
+2011-04-17 Jan Hubicka <jh@suse.cz>
+
+ * class.c (cp_fold_obj_type_ref): Drop vtable_method.
+
+2011-04-15 Rodrigo Rivas Costa <rodrigorivascosta@gmail.com>
+
+ Implement N3271
+ * parser.c (cp_convert_range_for): Split into
+ cp_parser_perform_range_for_lookup.
+ (cp_parser_perform_range_for_lookup): New.
+ (cp_parser_range_for_member_function): New.
+ (cp_parser_for_init_statement): Correct error message.
+ * semantics.c (finish_call_expr): Accept COMPONENT_REF.
+
+2011-04-14 Nicola Pero <nicola.pero@meta-innovation.com>
+
+ * parser.c (cp_parser_objc_protocol_declaration): Updated for
+ change from objc_declare_protocols() to objc_declare_protocol().
+
+2011-04-14 Nathan Froyd <froydnj@codesourcery.com>
+
+ PR objc++/48479
+ * typeck.c (cxx_mark_addressable) [CONST_DECL]: Mark addressable
+ and return immediately.
+
+2011-04-14 Nathan Froyd <froydnj@codesourcery.com>
+
+ * cp-tree.def (SWITCH_STMT): Add an extra operand.
+ * cp-objcp-common.c (cp_common_init_ts): Mark it as TS_TYPED.
+ * cp-tree.h (SWITCH_STMT_SCOPE): Define.
+ * semantics.c (begin_switch__stmt): Pass scope to build_stmt.
+ (finish_switch_stmt): Use SWITCH_STMT_SCOPE instead of TREE_CHAIN.
+
+2011-04-14 Nathan Froyd <froydnj@codesourcery.com>
+
+ * cp-tree.def (IF_STMT): Add an extra operand.
+ * cp-objcp-common.c (cp_common_init_ts): Mark it as TS_TYPED.
+ * cp-tree.h (IF_SCOPE): Define.
+ * semantics.c (begin_if_stmt): Pass scope to build_stmt.
+ (finish_if_stmt): Use IF_SCOPE instead of TREE_CHAIN.
+
+2011-04-14 Nathan Froyd <froydnj@codesourcery.com>
+
+ * cp-tree.def (FOR_STMT, RANGE_FOR_STMT): Add an extra operand.
+ * cp-objcp-common.c (cp_common_init_ts): Mark them as TS_TYPED.
+ * cp-tree.h (FOR_SCOPE, RANGE_FOR_SCOPE): Define.
+ * semantics.c (begin_for_stmt): Pass an extra arg to build_stmt.
+ Use FOR_SCOPE instead of TREE_CHAIN.
+ (begin_range_for_stmt): Likewise, with RANGE_FOR_SCOPE.
+ (finish_for_stmt): Likewise.
+
+2011-04-14 Jason Merrill <jason@redhat.com>
+
+ * parser.c (cp_parser_postfix_expression): Fix flags passed to
+ build_new_method_call.
+ * semantics.c (finish_call_expr): Likewise.
+
+ PR c++/48531
+ * init.c (build_value_init_noctor): Check complain consistently.
+
+ PR c++/48557
+ * typeck.c (cp_build_binary_op): Don't decay void operands.
+
+ PR c++/48446
+ * decl.c (compute_array_index_type): Use get_temp_regvar instead
+ of variable_size.
+ * init.c (get_temp_regvar): No longer static.
+ * cp-tree.h: Declare it.
+
+2011-04-14 Nicola Pero <nicola.pero@meta-innovation.com>
+
+ * parser.c (cp_parser_objc_class_declaration): Updated for change
+ in objc_declare_class().
+
+2011-04-14 Nathan Froyd <froydnj@codesourcery.com>
+
+ * decl.c (poplevel): Use block_chainon.
+
+2011-04-13 Jason Merrill <jason@redhat.com>
+
+ PR c++/48594
+ * decl2.c (build_offset_ref_call_from_tree): Fix calling a functor
+ or pointer to (non-member) function.
+
+2011-04-13 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/48570
+ * semantics.c (cxx_eval_array_reference): Handle reading from
+ wchar_t, char16_t and char32_t STRING_CST.
+
+2011-04-13 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/48574
+ * class.c (fixed_type_or_null): We cannot determine the dynamic
+ type of a reference variable if its initializer is dependent.
+
+2011-04-13 Jason Merrill <jason@redhat.com>
+
+ PR c++/48581
+ * pt.c (tsubst_copy_and_build) [CALL_EXPR]: Don't complain about
+ unqualified lookup failing if we're still in a template.
+
+2011-04-12 Nathan Froyd <froydnj@codesourcery.com>
+
+ * cp-lang.c (cp_init_ts): Call cp_common_init_ts. Move
+ tree_contains_struct initialization to...
+ * cp-objcp-common.c (cp_common_init_ts): ...here. Use MARK_*
+ macros.
+ * cp-objcp-common.h (cp_common_init_ts): Declare.
+ * cp-tree.h (union lang_tree_node): Check for TS_COMMON before
+ calling TREE_CHAIN.
+
+2011-04-12 Nicola Pero <nicola.pero@meta-innovation.com>
+
+ * parser.c (cp_parser_objc_message_expression): Updated call
+ to objc_build_message_expr.
+
+2011-04-12 Martin Jambor <mjambor@suse.cz>
+
+ * class.c (cp_fold_obj_type_ref): Call cgraph_get_node instead of
+ cgraph_get_create_node.
+ * decl2.c (cp_write_global_declarations): Call cgraph_get_node
+ instead of cgraph_get_create_node.
+ * method.c (make_alias_for_thunk): Call cgraph_get_node
+ instead of cgraph_get_create_node, assert it returns non-NULL.
+ (use_thunk): Likewise.
+ * optimize.c (maybe_clone_body): Call cgraph_same_body_alias only
+ when flag_syntax_only is not set. Call cgraph_get_node instead of
+ cgraph_get_create_node.
+ (maybe_clone_body): Call cgraph_get_node instead of
+ cgraph_get_create_node.
+
+2011-04-12 Martin Jambor <mjambor@suse.cz>
+
+ * class.c (cp_fold_obj_type_ref): Call cgraph_get_create_node
+ instead of cgraph_node.
+ * decl2.c (cxx_callgraph_analyze_expr): Likewise.
+ (cp_write_global_declarations): Likewise.
+ * optimize.c (maybe_clone_body): Likewise.
+ * semantics.c (maybe_add_lambda_conv_op): Likewise.
+ * mangle.c (mangle_decl): Likewise.
+ * method.c (make_alias_for_thunk): Likewise.
+ (use_thunk): Likewise.
+
+2011-04-11 Jason Merrill <jason@redhat.com>
+
+ PR c++/48535
+ * decl.c (cp_complete_array_type_or_error): New.
+ * semantics.c (finish_compound_literal): Use it.
+ * cp-tree.h: Declare it.
+
+ PR c++/48535
+ * semantics.c (finish_compound_literal): Handle references.
+
+ PR c++/48535
+ * semantics.c (finish_compound_literal): Take complain parm.
+ (build_lambda_object): Adjust.
+ * cp-tree.h: Adjust.
+ * call.c (convert_like_real): Adjust.
+ * decl.c (check_initializer): Adjust.
+ * parser.c (cp_parser_postfix_expression): Adjust.
+ (cp_parser_functional_cast): Adjust.
+ * pt.c (tsubst_copy_and_build): Adjust.
+ * typeck2.c (process_init_constructor_record): Adjust.
+
+ PR c++/48534
+ * cvt.c (ocp_convert): Use build_nop to convert to underlying type
+ of scoped enum.
+
+ PR c++/48523
+ * tree.c (maybe_dummy_object): Use build_x_indirect_ref rather
+ than cp_build_indirect_ref.
+
+ PR c++/48457, Core 1238
+ * call.c (reference_binding): Allow rvalue reference to bind to
+ function lvalue.
+ * tree.c (lvalue_kind): Functions are always lvalues.
+
+2011-04-07 Jason Merrill <jason@redhat.com>
+
+ PR c++/48500
+ * semantics.c (potential_constant_expression_1) [CALL_EXPR]: Check
+ arguments even if we don't know the function.
+
+ PR c++/48481
+ * tree.c (build_overload): Allow an unwrapped FUNCTION_DECL
+ at the end of the chain.
+ * pt.c (dependent_template_p): Use OVL_CURRENT/NEXT.
+ (iterative_hash_template_arg): Likewise.
+
+ PR c++/48481
+ * cp-tree.h (OVL_ARG_DEPENDENT): New.
+ * name-lookup.c (add_function): Set it.
+ * semantics.c (finish_call_expr): Free OVERLOADs if it's set.
+
+ PR c++/48481
+ * call.c (build_user_type_conversion_1): Use lookup_fnfields_slot.
+ Release unused vector.
+
+ PR c++/48451
+ * pt.c (fn_type_unification): Don't clear incomplete pack flag.
+ (type_unification_real): Clear it here instead.
+
+ PR c++/48468
+ * except.c (build_noexcept_spec): Propagate error_mark_node.
+ (finish_noexcept_expr): Likewise.
+
+ PR c++/48452
+ * typeck.c (build_x_compound_expr_from_list): Return error_mark_node
+ in SFINAE context.
+
+ PR c++/48450
+ * call.c (resolve_args): Take complain.
+ (build_new_function_call, build_operator_new_call): Pass it.
+ (build_op_call, build_new_op, build_new_method_call): Pass it.
+
+ PR c++/48450
+ * typeck.c (check_for_casting_away_constness): Take complain.
+ (build_static_cast_1, build_reinterpret_cast_1): Pass it.
+ (build_const_cast_1): Pass it. Take full complain parm.
+ (build_const_cast, cp_build_c_cast): Adjust.
+
+ * tree.c (build_aggr_init_expr): Always return error_mark_node
+ on abstract violation.
+
+ PR c++/48450
+ * tree.c (build_cplus_new, build_aggr_init_expr): Take complain.
+ (bot_manip): Adjust.
+ * cp-tree.h: Adjust.
+ * call.c (convert_like_real, build_cxx_call): Adjust.
+ (perform_direct_initialization_if_possible): Adjust.
+ * cvt.c (ocp_convert): Adjust.
+ * init.c (build_value_init): Adjust.
+ * semantics.c (maybe_add_lambda_conv_op): Adjust.
+ * typeck.c (unary_complex_lvalue, cp_build_modify_expr): Adjust.
+ * typeck2.c (build_functional_cast): Adjust.
+
+ * init.c (build_value_init_noctor): Handle REFERENCE_TYPE at top
+ level.
+ (perform_member_init): Not here.
+ * typeck2.c (build_functional_cast): Limit REFERENCE_TYPE special
+ case to templates.
+ (abstract_virtuals_error_sfinae): Remove RESULT_DECL special case.
+
+ PR c++/48449
+ * typeck2.c (build_functional_cast): Check complain consistently.
+ Use build_value_init and abstract_virtuals_error_sfinae.
+ (abstract_virtuals_error_sfinae): Split out.
+ * cp-tree.h: Declare it.
+ * init.c (build_new_1): Use it.
+ (build_value_init_noctor): Handle FUNCTION_TYPE.
+
+ * semantics.c (finish_decltype_type): Simplify handling of unknown
+ type.
+
+ * semantics.c (finish_decltype_type): Add complain parm.
+ * cp-tree.h: Adjust.
+ * parser.c (cp_parser_decltype): Adjust.
+ * pt.c (tsubst): Adjust.
+
+ PR c++/48450
+ * cvt.c (ocp_convert): Handle converting scoped enum to bool.
+
+2011-03-31 Jason Merrill <jason@redhat.com>
+
+ PR c++/48277
+ * semantics.c (finish_call_expr): Remove assert.
+
+ PR c++/48280
+ * method.c (defaultable_fn_check): Templates are not defaultable.
+
+ * parser.c (cp_parser_init_declarator): Avoid redundant
+ cp_finish_decl for member declarations.
+
+2011-03-30 Jason Merrill <jason@redhat.com>
+
+ PR c++/48212
+ * semantics.c (non_const_var_error): Just return if DECL_INITIAL
+ is error_mark_node.
+
+2011-03-30 Jason Merrill <jason@redhat.com>
+
+ PR c++/48369
+ * semantics.c (potential_constant_expression_1): Handle
+ UNORDERED_EXPR and ORDERED_EXPR.
+
+ PR c++/48281
+ * semantics.c (finish_compound_literal): Do put static/constant
+ arrays in static variables.
+
+ * call.c (convert_like_real) [ck_list]: Build up the
+ initializer_list object directly.
+ * decl.c (build_init_list_var_init): Adjust.
+
+ * call.c (convert_like_real): Correct TREE_CONSTANT on CONSTRUCTOR.
+ * decl.c (reshape_init_array_1): Likewise.
+
+2011-03-29 Jason Merrill <jason@redhat.com>
+
+ PR c++/48265
+ * pt.c (value_dependent_expression_p) [VAR_DECL]: Make sure
+ the variable is constant before looking at its initializer.
+
+ PR c++/48319
+ * pt.c (value_dependent_expression_p): Handle TEMPLATE_ID_EXPR.
+
+ PR c++/48089
+ * semantics.c (potential_constant_expression_1): Change error about
+ use of *this in constructor into sorry.
+
+ PR c++/48296
+ * decl.c (cp_finish_decl): Defer validation of constexpr member
+ functions.
+ * class.c (finalize_literal_type_property): Validate them here.
+ * semantics.c (is_valid_constexpr_fn): Don't check completeness.
+
+ * semantics.c (is_valid_constexpr_fn): Specify input location.
+
+2011-03-28 Jason Merrill <jason@redhat.com>
+
+ PR c++/48313
+ * pt.c (maybe_adjust_types_for_deduction): Handle T&& deduction
+ from overloaded function.
+
+ Core 1232
+ * call.c (build_array_conv): New.
+ (implicit_conversion): Use it.
+
+ * call.c (reference_binding): Allow direct binding to an array
+ rvalue.
+
+ Core 898
+ * parser.c (cp_parser_compound_statement): Add function_body parm.
+ Complain about non-body compound-stmt in constexpr fn.
+ (cp_parser_primary_expression, cp_parser_statement): Adjust.
+ (cp_parser_implicitly_scoped_statement): Adjust.
+ (cp_parser_function_body, cp_parser_try_block): Adjust.
+ (cp_parser_handler, cp_parser_objc_synchronized_statement): Adjust.
+ (cp_parser_objc_try_catch_finally_statement): Adjust.
+
+ Core 898
+ * semantics.c (constexpr_fn_retval): New. Allow using-declaration
+ and using-definition.
+ (register_constexpr_fundef): Call it.
+
+ * except.c (build_noexcept_spec): Call cxx_constant_value after
+ converting to bool.
+
+2011-03-25 Kai Tietz <ktietz@redhat.com>
+
+ * lex.c (interface_strcmp): Handle dos-paths.
+ (handle_pragma_implementation): Use filename_cmp instead of
+ strcmp.
+ (in_main_input_context): Likewise.
+
+2011-03-25 Jason Merrill <jason@redhat.com>
+
+ Core 1135
+ * method.c (defaulted_late_check): Check for exception spec mismatch.
+ (defaultable_fn_check): Allow exception spec and virtual.
+ * class.c (check_for_override): A virtual dtor is non-trivial.
+
+ PR c++/48289
+ * pt.c (build_non_dependent_expr): Keep dereferences outside the
+ NON_DEPENDENT_EXPR.
+
+2011-03-25 Kai Tietz <ktietz@redhat.com>
+
+ * decl.c (decls_match): Replace target hook
+ call of comp_type_attributes by version in tree.c file.
+ * search.c (check_final_overrider): Likewise.
+ * typeck.c (structural_comptypes): Likewise.
+
+2011-03-21 Kai Tietz <ktietz@redhat.com>
+
+ PR target/12171
+ * cxx-pretty-print.c (pp_cxx_ptr_operator):
+ Display allowed attributes for function pointer types.
+ * error.c (dump_type_prefix): Likewise.
+
+ * tree.c (cxx_attribute_table): Adjust table.
+
+2011-03-18 Jason Merrill <jason@redhat.com>
+
+ PR c++/48162
+ * semantics.c (finish_call_expr): Allow TARGET_EXPR for now.
+
+ PR c++/48118
+ * call.c (build_over_call): Don't skip ck_rvalue.
+
+2011-03-17 Jason Merrill <jason@redhat.com>
+
+ PR c++/47504
+ * semantics.c (cxx_eval_constant_expression) [NOP_EXPR]: Don't let
+ the conversion set TREE_OVERFLOW.
+
+ Core 1212
+ * semantics.c (finish_decltype_type): Return T&& for xvalue.
+ * typeck.c (unlowered_expr_type): Preserve cv-quals.
+
+ PR c++/48166
+ * decl.c (revert_static_member_fn): Strip function-cv-quals.
+
+2011-03-16 Jason Merrill <jason@redhat.com>
+
+ PR c++/48089
+ * semantics.c (potential_constant_expression_1): Don't allow *this
+ in a constructor.
+ (register_constexpr_fundef): Use potential_rvalue_constant_expression.
+
+ PR c++/47301
+ * decl.c (compute_array_index_type): Don't bother trying to deal
+ with literal classes in ABI v1.
+
+ PR c++/46336
+ * decl.c (duplicate_decls): Return NULL_TREE for clashing
+ C functions.
+
+ PR c++/47570
+ * semantics.c (cxx_eval_constant_expression) [COMPOUND_EXPR]: Don't
+ use the generic binary expression handling.
+
+2011-03-16 Diego Novillo <dnovillo@google.com>
+
+ * Make-lang.in (CXX_PARSER_H): New.
+ (cp/parser.o): Add dependency on CXX_PARSER_H.
+ Add dependency on tree-pretty-print.h
+ (cp/cp-lang.o): Add dependency on CXX_PARSER_H.
+ * cp-lang.c: Include parser.h.
+ * parser.c: Include parser.h.
+ (struct cp_token): Add bitfield purged_p.
+ Update all users.
+ Move to parser.h.
+ (CPP_PURGED): Remove. Update all users.
+ (struct cp_lexer): Change field buffer to be a VEC of cp_token.
+ Remove field buffer_length.
+ Update all users.
+ Move to parser.h.
+ (struct tree_check): Move to parser.h.
+ (cp_token_position): Likewise.
+ (struct cp_token_cache): Likewise.
+ (CPP_KEYWORD): Likewise.
+ (CPP_TEMPLATE_ID): Likewise.
+ (CPP_NESTED_NAME_SPECIFIER): Likewise.
+ (N_CP_TTYPES): Likewise.
+ (enum cp_parser_status_kind): Likewise.
+ (struct cp_parser_context): Likewise.
+ (struct cp_default_arg_entry_d): Likewise.
+ (struct cp_unparsed_functions_entry_d): Likewise.
+ (struct cp_parser): Likewise.
+ (cp_lexer_dump_tokens): New.
+ (cp_lexer_debug_tokens): New.
+ (cp_lexer_finished_p): New.
+ (cp_lexer_alloc): Factor out of cp_lexer_new_main.
+ (cp_lexer_new_main): Re-write main lexing loop to push
+ tokens into the new VEC buffer.
+ (cp_lexer_print_token): Improve printing of CPP_NUMBER tokens.
+ Do not abort if the token type is not recognized, just print
+ its code.
+ * parser.h: New file.
+ * config-lang.in (gtfiles): Add cp/parser.h.
+
+2011-03-16 Jason Merrill <jason@redhat.com>
+
+ Core 1148
+ * typeck.c (check_return_expr): Fix conditions for setting
+ LOOKUP_PREFER_RVALUE.
+
+ * call.c (build_over_call): Remove require_complete_type_sfinae call.
+
+ PR c++/48132
+ * decl.c (check_array_designated_initializer): Allow integer index.
+ (reshape_init_array_1): Set index on the elements.
+
+2011-03-16 Jason Merrill <jason@redhat.com>
+
+ PR c++/48113
+ * typeck.c (convert_for_initialization): Use
+ perform_implicit_conversion_flags.
+ * call.c (standard_conversion): If LOOKUP_PREFER_RVALUE, set
+ rvaluedness_matches_p on ck_rvalue.
+ (convert_like_real) [ck_rvalue]: And restore it here.
+
+ PR c++/48115
+ * call.c (convert_arg_to_ellipsis): Handle incomplete type.
+
+2011-03-16 Jason Merrill <jason@redhat.com>
+
+ * parser.c (cp_parser_abort_tentative_parse): Make sure we haven't
+ committed to this tentative parse.
+
+ PR c++/47999
+ * semantics.c (finish_call_expr): Preserve reference semantics
+ in templates.
+
+ * call.c (convert_default_arg): Use LOOKUP_IMPLICIT.
+
+2011-03-16 Jakub Jelinek <jakub@redhat.com>
+
+ * cp-objcp-common.c (cp_function_decl_explicit_p): Don't crash if
+ DECL_LANG_SPECIFIC is NULL.
+
+2011-03-15 Jason Merrill <jason@redhat.com>
+
+ Core 1074
+ * pt.c (value_dependent_expression_p) [NOEXCEPT_EXPR]: Don't
+ check value_dependent_expression_p on the operand.
+
+ * semantics.c (push_cx_call_context): Return bool.
+ (cxx_eval_call_expression): Handle excess depth.
+
+ Core 1191
+ * method.c (synthesized_method_walk): Cleanups don't affect the
+ triviality of a constructor, but do affect deletion and exception
+ specification.
+
+2011-03-15 Rodrigo Rivas Costa <rodrigorivascosta@gmail.com>
+
+ * decl2.c (cp_check_const_attributes): New.
+ (cplus_decl_attributes): Call cp_check_const_attributes.
+
+2011-03-15 Jason Merrill <jason@redhat.com>
+
+ PR c++/34758
+ * call.c (convert_default_arg): Use DECL_ORIGIN of fn. Check for
+ recursion first.
+ (push_defarg_context, pop_defarg_context): New.
+ * parser.c (cp_parser_late_parsing_default_args): Use them.
+ * cp-tree.h: Declare them.
+
+2011-03-11 Dodji Seketeli <dodji@redhat.com>
+
+ * call.c (add_builtin_candidate)<case INDIRECT_REF>: The type of
+ the argument of the indirection operator should not be dependent.
+ Fix the comment.
+
+2011-03-11 Jason Merrill <jason@redhat.com>
+
+ PR c++/47125
+ * pt.c (tsubst) [TYPENAME_TYPE]: Only give errors if tf_error.
+
+ PR c++/47144
+ * parser.c (cp_parser_template_type_arg): Set
+ type_definition_forbidden_message.
+
+ PR c++/47808
+ * decl.c (compute_array_index_type): Discard folding
+ if it didn't produce a constant.
+
+2011-03-11 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/48035
+ * init.c (build_zero_init_1): Extracted from build_zero_init.
+ Add FIELD_SIZE argument, if non-NULL and field bit_position
+ as not smaller than that, don't add that field's initializer.
+ Pass DECL_SIZE as last argument to build_zero_init_1
+ for DECL_FIELD_IS_BASE fields.
+ (build_zero_init): Use build_zero_init_1.
+
+2011-03-10 Jason Merrill <jason@redhat.com>
+
+ PR c++/48029
+ * pt.c (iterative_hash_template_arg): Remove special case for
+ ARRAY_TYPE.
+
+ PR c++/47198
+ * parser.c (cp_parser_single_declaration): Just return if
+ cp_parser_parse_and_diagnose_invalid_type_name complained.
+
+2011-03-09 Jason Merrill <jason@redhat.com>
+
+ PR c++/44629
+ * pt.c (unify): An unresolved overload is a nondeduced context.
+
+2011-03-09 Martin Jambor <mjambor@suse.cz>
+
+ PR tree-optimization/47714
+ * method.c (use_thunk): Clear addressable flag of thunk arguments.
+
+2011-03-08 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/47705
+ * pt.c (convert_nontype_argument): Only call decay_conversion on
+ arrays.
+
+2011-03-08 Jason Merrill <jason@redhat.com>
+
+ PR c++/47488
+ * mangle.c (write_template_arg_literal) [STRING_CST]: Sorry.
+
+ PR c++/47705
+ * pt.c (convert_nontype_argument): Don't crash on non-pointer
+ argument to pointer parameter.
+
+ PR c++/45651
+ * pt.c (instantiate_decl): Don't clear DECL_INTERFACE_KNOWN on
+ !TREE_PUBLIC decls.
+
+2011-03-08 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/47957
+ * name-lookup.c (binding_to_template_parms_of_scope_p): Only
+ consider scopes of primary template definitions. Adjust comments.
+
+2011-03-07 Jason Merrill <jason@redhat.com>
+
+ PR c++/48003
+ * pt.c (convert_nontype_argument): Fix -fpermissive allowing
+ integer overflow.
+ * semantics.c (potential_constant_expression_1): Check TREE_OVERFLOW.
+
+ PR c++/48015
+ * init.c (constant_value_1): Always require init to be TREE_CONSTANT.
+
+ PR c++/48008
+ * mangle.c (write_type): Strip cv-quals from FUNCTION_TYPE here.
+ (write_CV_qualifiers_for_type): Not here.
+
+2011-03-06 Joseph Myers <joseph@codesourcery.com>
+
+ * lang-specs.h: Match -save-temps* instead of -save-temps.
+
+2011-03-05 Jason Merrill <jason@redhat.com>
+
+ * mangle.c (write_expression): Change ABI v6 to v5.
+ (write_type): Likewise.
+
+2011-03-04 Jan Hubicka <jh@suse.cz>
+
+ PR lto/47497
+ * optimize.c (maybe_clone_body): Update call of cgraph_same_body_alias
+ and cgraph_add_thunk.
+ * method.c (make_alias_for_thunk, use_thunk): Likewise.
+ * mangle.c (mangle_decl): Likewise.
+
+2011-03-04 Jason Merrill <jason@redhat.com>
+
+ PR c++/47971
+ * pt.c (tsubst_copy_and_build) [PSEUDO_DTOR_EXPR]: Use tsubst for type.
+ (tsubst_copy) [default]: Just return t if !ENABLE_CHECKING.
+
+ PR c++/46220
+ * search.c (check_final_overrider): Allow pointer to same incomplete
+ class type with different cv-quals.
+
+2011-03-03 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/47974
+ * pt.c (tsubst_template_args): Check argument t for error_mark_node.
+
+2011-03-03 Jason Merrill <jason@redhat.com>
+
+ PR c++/47950
+ * pt.c (tsubst_copy_and_build) [TARGET_EXPR]: Retain TREE_CONSTANT.
+
+2011-03-02 Jason Merrill <jason@redhat.com>
+
+ PR c++/47950
+ * parser.c (cp_parser_condition): Don't fold_non_dependent_expr here.
+
+ PR c++/47774
+ * tree.c (build_vec_init_elt): Split out from...
+ (build_vec_init_expr): ...here.
+ (diagnose_non_constexpr_vec_init): New fn.
+ * semantics.c (potential_constant_expression_1): Use it.
+ * cp-tree.h: Declare it.
+
+2011-03-01 Jason Merrill <jason@redhat.com>
+
+ PR c++/46159
+ * parser.c (cp_parser_primary_expression): Don't warn about a
+ failed tentative parse.
+
+ PR c++/47200
+ * semantics.c (cxx_bind_parameters_in_call): Don't call
+ adjust_temp_type on non-constant args.
+
+ PR c++/47851
+ * call.c (standard_conversion): Provide requested cv-quals on
+ class rvalue conversion.
+
+ PR c++/46282
+ * decl2.c (grokbitfield): Handle type-dependent width.
+
+2011-02-28 Jason Merrill <jason@redhat.com>
+
+ PR c++/47873
+ * class.c (update_vtable_entry_for_fn): Check BINFO_LOST_PRIMARY_P
+ after checking for a non-thunk.
+
+2011-02-26 Jason Merrill <jason@redhat.com>
+
+ PR c++/47904
+ * tree.c (cp_tree_equal): Compare DECL_PARM_LEVEL.
+ * pt.c (iterative_hash_template_arg): And hash it.
+
+ PR c++/47897
+ * semantics.c (non_const_var_error): Split out from...
+ (cxx_eval_constant_expression): ...here.
+ (potential_constant_expression_1) [VAR_DECL]: Use it.
+ Allow dependent variables.
+
+2011-02-24 Jason Merrill <jason@redhat.com>
+
+ * parser.c (cp_parser_constant_expression): Set
+ non_integral_constant_expression correctly for C++0x too.
+ (cp_parser_static_assert): Allow non-constant expression.
+ (cp_parser_direct_declarator): Expect non_constant_p to be set
+ properly for C++0x.
+ * pt.c (value_dependent_expression_p): Handle TYPEID_EXPR.
+ * semantics.c (maybe_constant_value): Check type_unknown_p too.
+ (potential_rvalue_constant_expression): New.
+ (require_potential_rvalue_constant_expression): New.
+
+2011-02-23 Jason Merrill <jason@redhat.com>
+
+ * cp-tree.h (DECL_PARM_LEVEL): New.
+ (struct lang_decl_parm): Add level field.
+ * name-lookup.c (function_parm_depth): New fn.
+ * name-lookup.h: Declare it.
+ * parser.c (cp_parser_parameter_declaration_list): Use it.
+ * mangle.c (struct globals): Add parm_depth field.
+ (write_bare_function_type): Adjust it.
+ (write_expression): Include the level delta in PARM_DECL mangling
+ for abi >= 6.
+
+ * semantics.c (finish_decltype_type): Remove shortcut for decltype
+ of id-expression.
+ * mangle.c (write_type) [DECLTYPE_TYPE]: Strip it here for abi < 6.
+
+2011-02-23 Nathan Froyd <froydnj@codesourcery.com>
+
+ PR c++/46868
+ * parser.c (cp_parser_class_specifier): Require a closing brace
+ to attempt error recovery.
+
+2011-02-23 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/47833
+ * pt.c (struct pending_template): Add chain_next GTY option.
+ * decl.c (struct named_label_use_entry): Likewise.
+
+2011-02-22 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/47242
+ * semantics.c (build_lambda_object): Bail out if a field is
+ error_mark_node.
+
+2011-02-22 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/47666
+ * class.c (dfs_declare_virt_assop_and_dtor)
+ (declare_virt_assop_and_dtor): New static functions.
+ (add_implicitly_declared_members): Use
+ declare_virt_assop_and_dtor.
+
+2011-02-21 Jason Merrill <jason@redhat.com>
+
+ PR c++/47207
+ * decl2.c (decl_constant_var_p): A constexpr var needs an
+ initializer to be constant.
+ * semantics.c (cxx_eval_constant_expression): Complain about
+ constexpr var used in its own initializer.
+ * call.c (set_up_extended_ref_temp): Set
+ DECL_INITIALIZED_BY_CONSTANT_EXPRESSION_P too.
+
+2011-02-20 Jason Merrill <jason@redhat.com>
+
+ PR c++/47199
+ * semantics.c (cxx_eval_call_expression): Call
+ cxx_eval_constant_expression in trivial shortcut.
+
+ PR c++/46831
+ * call.c (convert_class_to_reference): Don't try to set up a
+ second conv sequence for non-viable candidates.
+
+ PR c++/47703
+ * error.c (location_of): Handle non-tagged types.
+
+ PR c++/46472
+ * method.c (process_subob_fn): Instantiate constexpr templates.
+ * optimize.c (maybe_clone_body): Propagate DECL_DECLARED_CONSTEXPR_P.
+
+2011-02-20 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/46394
+ * pt.c (tsubst_pack_expansion): do not use
+ cp_tree_equal/same_type_p to detect an expansion of a parameter
+ pack.
+
+2011-02-19 Jason Merrill <jason@redhat.com>
+
+ PR c++/47503
+ * semantics.c (cxx_eval_call_expression): Shortcut trivial copy.
+
+2011-02-18 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/47795
+ * semantics.c (finish_non_static_data_member): Early return if
+ object is error_mark_node.
+
+2011-02-18 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/47208
+ * pt.c (do_auto_deduction): Do not mention error_mark_node in
+ diagnostics.
+ * semantics.c (finish_id_expression): Do not pass erroneous decl
+ to decl_constant_var_p.
+
+2011-02-17 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/47783
+ * cvt.c (convert_from_reference): Call mark_exp_read.
+
+2011-02-11 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/47172
+ * pt.c (finish_call_expr): Consider a call expression that has a
+ dependent "this" pointer as being dependent. Add comments.
+ (dependent_type_p, type_dependent_expression_p): Update comments.
+
+2011-02-16 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/47326
+ * pt.c (tsubst_copy)<case SIZEOF_EXPR>: Ensure that even pack
+ expansion arguments are not evaluated.
+
+2011-02-16 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/47704
+ * cp-tree.h (ENUM_FIXED_UNDERLYING_TYPE_P): Use TYPE_LANG_FLAG_5
+ instead of TYPE_LANG_FLAG_3.
+ * pt.c (lookup_template_class): Copy over
+ ENUM_FIXED_UNDERLYING_TYPE_P.
+
+2011-02-15 Jason Merrill <jason@redhat.com>
+
+ PR c++/46807
+ * method.c (synthesized_method_walk): Always exit early for
+ trivial fn in C++98 mode.
+
+2011-02-14 Jason Merrill <jason@redhat.com>
+
+ PR c++/47482
+ * parser.c (cp_parser_enumerator_definition): Call
+ fold_non_dependent_expr.
+
+2011-02-09 Jason Merrill <jason@redhat.com>
+
+ * decl.c (cp_make_fname_decl): Set DECL_THIS_STATIC at toplevel.
+ * semantics.c (finish_fname): Only return the name if we're in
+ a function.
+
+ * decl.c (build_enumerator): Don't perform integral promotions on
+ non-integral constants.
+
+ * cvt.c (convert_to_void): Handle null op1.
+
+ * class.c (type_has_constexpr_default_constructor): Make sure the
+ caller stripped an enclosing array.
+ * init.c (perform_member_init): Strip arrays before calling it.
+
+ PR c++/47511
+ * semantics.c (potential_constant_expression_1): Handle TEMPLATE_DECL.
+
+2011-02-03 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/47398
+ * tree.c (cp_tree_equal)<TEMPLATE_PARM_INDEX>: Take the number of
+ template parameters in account.
+
+2011-02-03 Nathan Froyd <froydnj@codesourcery.com>
+
+ PR c++/46890
+ * parser.c (cp_parser_class_specifier): Fix setting of
+ want_semicolon.
+
+2011-01-31 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/47416
+ * semantics.c (build_data_member_initialization): Handle
+ STATEMENT_LIST always instead of just for CLEANUP_BODY.
+
+2011-01-31 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
+
+ * g++spec.c (lang_specific_driver) [HAVE_LD_STATIC_DYNAMIC] Use
+ LD_STATIC_OPTION, LD_DYNAMIC_OPTION.
+
+2011-01-29 Dodji Seketeli <dodji@redhat.com>
+
+ PR c++/47311
+ * cp-tree.h (fixup_template_parms): Declare.
+ * pt.c (end_template_parm_list): Do not fixup template parms here.
+ (fixup_template_parms): Remove static. Fix typo in the
+ comments. Remove useless code statement.
+ (fixup_template_parm): For a template template parameter, fixup
+ its attributes before fixing up its type.
+ * parser.c
+ (cp_parser_template_declaration_after_export): After parsing
+ template parameters fixup their types.
+
+2011-01-26 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/47476
+ * semantics.c (potential_constant_expression_1): Handle
+ TRUTH_XOR_EXPR.
+
+2011-01-26 Dave Korn <dave.korn.cygwin@gmail.com>
+
+ PR c++/43601
+ * semantics.c (expand_or_defer_fn_1): Handle it.
+ * decl2.c (decl_needed_p): Likewise.
+
+2011-01-21 Jason Merrill <jason@redhat.com>
+
+ PR c++/47041
+ * semantics.c (build_constexpr_constructor_member_initializers):
+ Handle trivial copy.
+
+2011-01-21 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/47388
+ * semantics.c (begin_for_stmt): If -fno-for-scope, don't
+ assume init must be NULL if scope is NULL.
+ (begin_range_for_stmt): Likewise.
+
+2011-01-21 Jason Merrill <jason@redhat.com>
+
+ PR c++/46552
+ * semantics.c (cxx_eval_constant_expression): Handle OFFSET_REF.
+
+ PR c++/46977
+ * semantics.c (potential_constant_expression_1): Split out from
+ potential_constant_expression. Add want_rval parm. Handle
+ template expression forms. Don't enforce restriction on address
+ of automatic variable here. Add a couple of diagnostics that
+ had been missing.
+ (require_potential_constant_expression): New entry point.
+ (build_data_member_initialization, register_constexpr_fundef): Adjust.
+ (maybe_constant_value): Check potential_constant_expression.
+ * pt.c (fold_non_dependent_expr_sfinae): Likewise.
+ * tree.c (build_vec_init_expr): Adjust.
+
+2011-01-19 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/47303
+ * decl2.c (finish_anon_union): Only call mangle_decl if TREE_STATIC
+ or DECL_EXTERNAL.
+
+2011-01-17 Jason Merrill <jason@redhat.com>
+
+ PR c++/47067
+ * semantics.c (base_field_constructor_elt): New fn.
+ (cxx_eval_bare_aggregate): Use it.
+ (build_data_member_initialization): Leave COMPONENT_REF for
+ vfield inits.
+
+2011-01-14 Rodrigo Rivas Costa <rodrigorivascosta@gmail.com>
+
+ * parser.c (cp_parser_range_for): Remove the "unused variable" warning
+ workaround.
+
+2011-01-15 Giovanni Funchal <gafunchal@gmail.com>
+ Jonathan Wakely <jwakely.gcc@gmail.com>
+
+ PR c++/33558
+ * decl.c (grokdeclarator): Reject mutable reference members.
+
+2011-01-14 Jason Merrill <jason@redhat.com>
+
+ PR c++/47289
+ * pt.c (coerce_template_parms): Fix error recovery.
+
+ PR c++/46903
+ * typeck2.c (check_narrowing): Only check arithmetic types.
+
+ PR c++/46688
+ * tree.c (build_vec_init_expr): Handle flexible array
+ properly.
+
+2011-01-13 Kai Tietz <kai.tietz@onevision.com>
+
+ PR c++/47213
+ * cp-tree.h (CLASSTYPE_VISIBILITY): Use
+ TYPE_MAIN_DECL instead of TYPE_NAME.
+ (CLASSTYPE_VISIBILITY_SPECIFIED): Likewise.
+ * decl2.c (determine_visibility): Add check
+ of CLASS_TYPE_P for underlying_type.
+
+2011-01-12 Rodrigo Rivas Costa <rodrigorivascosta@gmail.com>
+
+ * cp-tree.h (begin_for_scope): New prototype.
+ (begin_for_stmt): Update prototype.
+ (begin_range_for_stmt): Update prototype.
+ * init.c (build_vec_init): Update call to begin_for_stmt.
+ * parser.c (cp_parser_for): New.
+ (cp_parser_c_for): Add three new parameters.
+ (cp_parser_range_for): Likewise. Most parsing code removed.
+ (cp_parser_iteration_statement): Call cp_parser_for instead of
+ cp_parser_c_for and cp_parser_range_for.
+ (cp_parser_for_init_statement): Add new parameter and return type.
+ (cp_parser_block_declaration): Update call to
+ cp_parser_simple_declaration.
+ (cp_parser_simple_declaration): Add new parameter.
+ Update call to cp_parser_init_declarator.
+ (cp_parser_init_declarator): Add new parameter.
+ * pt.c (tsubst_expr): Update call to begin_for_stmt.
+ * semantics.c (begin_for_scope): New.
+ (begin_for_stmt): Add two new parameters.
+ (begin_range_for_stmt): Likewise.
+
+2011-01-12 Nicola Pero <nicola.pero@meta-innovation.com>
+
+ * parser.c (cp_parser_objc_at_property_declaration): Improved
+ error message.
+
+2011-01-11 Dodji Seketeli <dodji@redhat.com>
+
+ PR debug/46955
+ * cp-lang.c (get_template_innermost_arguments_folded)
+ (get_template_argument_pack_elems_folded)
+ (template_arg_needs_folding, fold_cplus_constants): New static
+ functions.
+ (LANG_HOOKS_GET_INNERMOST_GENERIC_ARGS): Set this hook to
+ get_template_innermost_arguments_folded.
+ (LANG_HOOKS_GET_ARGUMENT_PACK_ELEMS): Set this hook to
+ get_template_argument_pack_elems_folded.
+
+2011-01-11 Jason Merrill <jason@redhat.com>
+
+ PR c++/46658
+ * init.c (build_new_1): Handle value-init in templates differently.
+
+ PR c++/45520
+ * tree.c (maybe_dummy_object): Check current_class_ref against
+ context, not current_class_type.
+
+2011-01-08 Nicola Pero <nicola.pero@meta-innovation.com>
+
+ PR objc/47078
+ * parser.c (cp_parser_objc_typename): If the type is unknown, for
+ error recovery purposes behave as if it was not specified so that
+ the default type is used.
+
+2011-01-07 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/47022
+ * pt.c (tsubst_copy_and_build): Use tsubst instead of tsubst_copy
+ for the second build_x_va_arg argument.
+
+2011-01-05 Tom Tromey <tromey@redhat.com>
+
+ * typeck.c (cp_build_addr_expr_1): Update call to lvalue_error.
+ (lvalue_or_else): Likewise.
+
+2011-01-01 Kai Tietz <kai.tietz@onevision.com>
+
+ PR target/38662
+ * tree.c (cxx_type_hash_eq):
+ Allow METHOD_TYPE, too.
+
+
+Copyright (C) 2011 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.