1. 19 Aug, 2016 7 commits
  2. 18 Aug, 2016 23 commits
    • Implement the latest proposed resolution of LWG 2756. · a577f786
      	* include/std/optional (Optional_base(const _Tp&))
      	(Optional_base(_Tp&&), using _Base::_Base): Remove.
      	(optional(nullopt_t)): New.
      	(optional(_Up&&)): Invoke base directly with in_place
      	rather than creating a temporary, add default template
      	argument, change constraints.
      	(optional(const optional<_Up>&)): Invoke base directly
      	with in_place, remove unnecessary constraints.
      	(optional(optional<_Up>&& __t)): Likewise.
      	(optional(in_place_t, _Args&&...)): New.
      	(optional(in_place_t, initializer_list<_Up>, _Args&&...)): Likewise.
      	(operator=(_Up&&)): Add default template argument, change constraints.
      	(operator=(const optional<_Up>&)): Put is_same first in the
      	constraints.
      	(operator=(optional<_Up>&&)): Likewise.
      	* testsuite/20_util/optional/assignment/5.cc: Add a test to
      	verify assignment from something that can't be perfect-forwarded.
      	* testsuite/20_util/optional/cons/value.cc: Add tests to verify
      	that a nested optional is disengaged when constructed
      	from a disengaged element type,	and to verify that assignments
      	from an engaged element type engage the optional.
      
      From-SVN: r239593
      Ville Voutilainen committed
    • Implement <variant> · 197c757c
      	* include/Makefile.am: Add new file std/variant.
      	* include/Makefile.in: Generated from Makefile.am.
      	* include/bits/enable_special_members.h: Add a tag type to allow
      	the construction in non-default constructor.
      	* include/bits/uses_allocator.h: Add convenience traits to
      	detect constructibility.
      	* include/std/variant: Implement <variant>.
      	* testsuite/20_util/variant/compile.cc: Compile-time tests.
      	* testsuite/20_util/variant/run.cc: Runtime tests.
      
      From-SVN: r239590
      Tim Shen committed
    • Allow calling diagnostic_show_locus without a diagnostic_info · cc015f3a
      Much of diagnostic-show-locus.c currently expects a diagnostic_info *,
      but it only uses the rich_location and the diagnostic_t.
      
      Change the signature of diagnostic_show_locus from:
      
        void
        diagnostic_show_locus (diagnostic_context *,
                               const diagnostic_info *);
      
      to:
      
        void
        diagnostic_show_locus (diagnostic_context *,
                               rich_location *richloc,
                               diagnostic_t diagnostic_kind);
      
      so that it can be used for things other than diagnostics.
      
      Use this flexibility to add selftests for diagnostic_show_locus.
      
      gcc/c-family/ChangeLog:
      	* c-opts.c (c_diagnostic_finalizer): Update for change to
      	diagnostic_show_locus.
      
      gcc/ChangeLog:
      	* diagnostic-show-locus.c (colorizer::colorizer): Replace diagnostic
      	param with diagnostic_kind.
      	(class colorizer): Similarly replace field m_diagnostic with
      	m_diagnostic_kind.
      	(colorizer::colorizer): Replace diagnostic
      	param with diagnostic_kind.
      	(colorizer::begin_state): Update for above field change.
      	(layout::layout): Replace diagnostic param with rich_location *
      	and diagnostic_kind.
      	(diagnostic_show_locus): Replace diagnostic param with richloc
      	and diagnostic_kind.
      	(class selftest::test_diagnostic_context): New class.
      	(selftest::test_diagnostic_show_locus_unknown_location): New
      	function.
      	(selftest::test_one_liner_simple_caret): New function.
      	(selftest::test_one_liner_caret_and_range): New function.
      	(selftest::test_one_liner_multiple_carets_and_ranges): New
      	function.
      	(selftest::test_one_liner_fixit_remove): New function.
      	(selftest::test_one_liner_fixit_replace): New function.
      	(selftest::test_diagnostic_show_locus_one_liner): New function.
      	(selftest::diagnostic_show_locus_c_tests): Call the new test
      	functions.
      	* diagnostic.c (diagnostic_initialize): Initialize
      	colorize_source_p, show_ruler_p and parseable_fixits_p.
      	(default_diagnostic_finalizer): Update for change to
      	diagnostic_show_locus.
      	(diagnostic_append_note): Likewise.
      	* diagnostic.h (diagnostic_show_locus): Replace
      	const diagnostic_info * param with location * and diagnostic_t.
      
      gcc/fortran/ChangeLog:
      	* error.c (gfc_diagnostic_starter): Update for change to
      	diagnostic_show_locus.
      
      gcc/testsuite/ChangeLog:
      	* gcc.dg/plugin/diagnostic_plugin_test_show_locus.c
      	(custom_diagnostic_finalizer): Update for change to
      	diagnostic_show_locus.
      
      From-SVN: r239586
      David Malcolm committed
    • Spelling suggestions for misspelled preprocessor directives · cb18fd07
      This patch allows the preprocessor to offer suggestions for misspelled
      directives, taking us from e.g.:
      
      test.c:5:2: error: invalid preprocessing directive #endfi
       #endfi
        ^~~~~
      
      to:
      
      test.c:5:2: error: invalid preprocessing directive #endfi; did you mean #endif?
       #endfi
        ^~~~~
        endif
      
      gcc/c-family/ChangeLog:
      	* c-common.c: Include "spellcheck.h".
      	(cb_get_suggestion): New function.
      	* c-common.h (cb_get_suggestion): New decl.
      	* c-lex.c (init_c_lex): Initialize cb->get_suggestion to
      	cb_get_suggestion.
      
      gcc/testsuite/ChangeLog:
      	* gcc.dg/cpp/misspelled-directive-1.c: New testcase.
      	* gcc.dg/cpp/misspelled-directive-2.c: New testcase.
      
      libcpp/ChangeLog:
      	* directives.c (directive_names): New array.
      	(_cpp_handle_directive): Offer spelling suggestions for misspelled
      	directives.
      	* errors.c (cpp_diagnostic_at_richloc): New function.
      	(cpp_error_at_richloc): New function.
      	* include/cpplib.h (struct cpp_callbacks): Add field
      	"get_suggestion".
      	(cpp_error_at_richloc): New decl.
      
      From-SVN: r239585
      David Malcolm committed
    • re PR c/71514 (ICE on C11 code with atomic exchange at -O1 and above on… · a76989dc
      re PR c/71514 (ICE on C11 code with atomic exchange at -O1 and above on x86_64-linux-gnu: in copy_reference_ops_from_ref, at tree-ssa-sccvn.c:879)
      
      	PR c/71514
      	* c-common.c (get_atomic_generic_size): Disallow pointer-to-function
      	and pointer-to-VLA.
      
      	* gcc.dg/pr71514.c: New test.
      
      From-SVN: r239581
      Marek Polacek committed
    • selftest.h: add class line_table_test · f87e22c5
      input.c has a fixture class for running each selftest with a fresh
      line_table, and logic for looping over various interesting line_table
      test cases.
      
      This patch exposes the above in selftest.h so that such
      location-handling tests can be written in other files, renaming the
      class from temp_line_table to line_table_test.
      
      Also, the patch moves the stored line table ptr from being a member of
      the test class to being a global GC-root, to avoid it being collected
      if the GC runs during such a test.
      
      gcc/ChangeLog:
      	* input.c (saved_line_table): New global.
      	(class selftest::temp_line_table): Rename to line_table_test and
      	move declaration to selftest.h, and drop field m_old_line_table.
      	(selftest::temp_line_table::temp_line_table): Rename ctor to...
      	(selftest::line_table_test::line_table_test): ...this.  Add a
      	default ctor.  Store current value of line_table within
      	saved_line_table.
      	(selftest::temp_line_table::~temp_line_table): Rename dtor to...
      	(selftest::line_table_test::~line_table_test): ...this, and
      	restore line_table from the saved_line_table, rather than
      	m_old_line_table.
      	(selftest::test_accessing_ordinary_linemaps): Update for above
      	renaming.
      	(selftest::test_lexer): Likewise.
      	(struct selftest::lexer_test): Likewise.
      	(selftest::lexer_test::lexer_test): Likewise.
      	(selftest::input_c_tests): Move the looping over test cases from
      	here into...
      	(selftest::for_each_line_table_case): New function.
      	* input.h (saved_line_table): New decl.
      	* selftest.h (struct selftest::line_table_case): New forward decl.
      	(class selftest::line_table_test): New class, moved here from
      	selftest::temp_line_table in input.c, and renamed.
      	(selftest::for_each_line_table_case): New decl.
      
      From-SVN: r239580
      David Malcolm committed
    • Increase MOVE_RATIO to 17 for Lakemont · 89c88780
      Larger MOVE_RATIO will always make code faster.  17 is the number with
      smaller code sizes for Lakemont.
      
      gcc/
      
      	PR target/72839
      	* config/i386/i386.c (lakemont_cost): Set MOVE_RATIO to 17.
      
      gcc/testsuite/
      
      	PR target/72839
      	* gcc.target/i386/pr72839.c: New test.
      
      From-SVN: r239578
      H.J. Lu committed
    • re PR middle-end/70895 (OpenACC: loop reduction does not work. Output is zero.) · 2c71d454
      2016-08-18  Chung-Lin Tang  <cltang@codesourcery.com>
      
      	PR middle-end/70895
      	gcc/
      	* gimplify.c (omp_add_variable): Adjust/add variable mapping on
      	enclosing parallel construct for reduction variables on OpenACC loop
      	directives.
      
      	gcc/testsuite/
      	* gfortran.dg/goacc/loop-tree-1.f90: Add gimple scan-tree-dump test.
      	* c-c++-common/goacc/reduction-1.c: Likewise.
      	* c-c++-common/goacc/reduction-2.c: Likewise.
      	* c-c++-common/goacc/reduction-3.c: Likewise.
      	* c-c++-common/goacc/reduction-4.c: Likewise.
      
      	libgomp/
      	* testsuite/libgomp.oacc-fortran/reduction-7.f90: Add explicit
      	firstprivate clauses.
      	* testsuite/libgomp.oacc-fortran/reduction-6.f90: Remove explicit
      	copy clauses.
      	* testsuite/libgomp.oacc-c-c++-common/reduction-7.c: Likewise.
      	* testsuite/libgomp.oacc-c-c++-common/reduction-cplx-flt.c: Likewise.
      	* testsuite/libgomp.oacc-c-c++-common/reduction-flt.c: Likewise.
      	* testsuite/libgomp.oacc-c-c++-common/collapse-2.c: Likewise.
      	* testsuite/libgomp.oacc-c-c++-common/loop-red-wv-1.c: Likewise.
      	* testsuite/libgomp.oacc-c-c++-common/collapse-4.c: Likewise.
      	* testsuite/libgomp.oacc-c-c++-common/loop-red-v-1.c: Likewise.
      	* testsuite/libgomp.oacc-c-c++-common/reduction-cplx-dbl.c: Likewise.
      	* testsuite/libgomp.oacc-c-c++-common/loop-red-g-1.c: Likewise.
      	* testsuite/libgomp.oacc-c-c++-common/loop-red-gwv-1.c: Likewise.
      	* testsuite/libgomp.oacc-c-c++-common/loop-red-w-1.c: Likewise.
      	* testsuite/libgomp.oacc-c-c++-common/reduction-dbl.c: Likewise.
      
      From-SVN: r239576
      Chung-Lin Tang committed
    • DWARF: do not emit DW_TAG_variable to materialize DWARF procedures · 80c5ad35
      Hello,
      
      For -gdwarf-3 and newer, the DWARF back-end sometimes generates DWARF
      procedures to factorize complex location descriptions.  DWARF procedures
      can be materialized as DW_TAG_dwarf_procedure DIEs, but actually any DIE
      that can hold a DW_AT_location attribute is also accepted.
      
      Unlike what I thought at some point, the DW_TAG_dwarf_procedure tag was
      introduced in the DWARFv3 standard, not the DWARFv4 one, so the back-end
      can always emit DW_TAG_dwarf_procedure DIEs, as this simplifies code and
      prevents the types pruning pass from missing a DWARF procedure.
      
      Boostrapped and regtested on x86_64-linux: no regression.  Ok to commit?
      Thank you in advance!
      
      gcc/
      
      	* dwarf2out.c (copy_dwarf_procedure): Remove obsolete comment.
      	(new_dwarf_proc_die): Emit DW_TAG_dwarf_procedure DIEs even for
      	-gdwarf-3.
      	(function_to_dwarf_procedure): Update comment.
      
      From-SVN: r239575
      Pierre-Marie de Rodat committed
    • Expand libstdc++ docs on testing · 0b224dcf
      	* doc/xml/manual/test.xml (test.run.permutations): Expand section.
      	(test.new_tests): Rewrite section.
      	(tests.dg.directives): New section.
      	* doc/html/*: Regenerate.
      
      From-SVN: r239574
      Jonathan Wakely committed
    • Improve documentation of libstdc++ test targets · b56d48ef
      	* doc/xml/manual/test.xml: Improve documentation of test targets.
      	Document new-abi-baseline, check-debug, and check-parallel targets.
      
      From-SVN: r239573
      Jonathan Wakely committed
    • Document libstdc++.so versioning in manual · 409d5555
      	* doc/xml/manual/build_hacking.xml: New section on shared library
      	versioning.
      
      From-SVN: r239572
      Jonathan Wakely committed
    • Improve markup in libstdc++ manual · a8107a98
      	* doc/xml/manual/build_hacking.xml: Improve markup.
      	* doc/xml/manual/test.xml: Likewise. Change section title from "Test"
      	to "Testing".
      	* doc/xml/faq.xml: Change link text to "Testing".
      
      From-SVN: r239571
      Jonathan Wakely committed
    • Evict selftest tempfiles from the diagnostics file cache · f89b03b6
      Selftests can use class selftest::temp_source_file to write out files
      for testing input-handling, and the files are unlinked in the dtor.
      
      This leads to stale entries in input.c's cache of file content, which
      could lead to errors if a temporary filename gets reused during a run
      of the selftests.
      
      We don't normally expect files to be "deleted from under us", so
      special-case this by adding a special way for temp_source_file's
      dtor to purge any cache entries referring to it.
      
      gcc/ChangeLog:
      	* input.c (diagnostics_file_cache_forcibly_evict_file): New
      	function.
      	* input.h (diagnostics_file_cache_forcibly_evict_file): New
      	declaration.
      	* selftest.c (selftest::temp_source_file::~temp_source_file):
      	Evict m_filename from the diagnostic file cache.
      
      From-SVN: r239570
      David Malcolm committed
    • tree-pass.h (make_pass_materialize_all_clones): Declare. · f0251020
      2016-08-18  Richard Biener  <rguenther@suse.de>
      
      	* tree-pass.h (make_pass_materialize_all_clones): Declare.
      	* ipa.c (pass_data_materialize_all_clones, pass_materialize_all_clones,
      	make_pass_materialize_all_clones): New simple IPA pass encapsulating
      	clone materialization.
      	* passes.def (all_late_ipa_passes): Start with
      	pass_materialize_all_clones.
      	* cgraphunit.c (symbol_table::compile): Remove call to
      	materialize_all_clones.
      	* tree-into-ssa.c: Include statistics.h.
      	(update_ssa): Count number of times we do incremental/rewrite
      	SSA update.
      
      From-SVN: r239567
      Richard Biener committed
    • re PR c/7652 (-Wswitch-break : Warn if a switch case falls through) · 9c62c873
      	PR c/7652
      gcc/cp/
      	* call.c (add_builtin_candidate): Add gcc_fallthrough.
      	* cxx-pretty-print.c (pp_cxx_unqualified_id): Likewise.
      	* parser.c (cp_parser_skip_to_end_of_statement): Likewise.
      	(cp_parser_cache_defarg): Likewise.
      libcpp/
      	* pch.c (write_macdef): Add CPP_FALLTHRU.
      
      From-SVN: r239566
      Marek Polacek committed
    • re PR tree-optimization/77282 (test case gcc.dg/autopar/pr46193.c fails starting with r239414) · f9d97e40
      2016-08-18  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/77282
      	* tree-ssa-pre.c (eliminate_dom_walker::before_dom_children):
      	When doing auto-parallelizing also prevent use of PHIs that
      	carry dependences across loop backedges.
      
      From-SVN: r239565
      Richard Biener committed
    • Remove unintended dg-options directive · 6cb98491
      	* testsuite/tr1/3_function_objects/function/10.cc: Remove unintended
      	dg-options directive.
      
      From-SVN: r239564
      Jonathan Wakely committed
    • [PATCH] [GCC] Don't use section anchors for declarations that don't fit in a single anchor range · 65d21eaf
      On behalf of Tamar Christina  <tamar.christina@arm.com>.
      
      gcc/
      
      	* varasm.c (default_use_anchors_for_symbol_p): Reject too large decls.
      
      
      Co-Authored-By: Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
      
      From-SVN: r239561
      Tamar Christina committed
    • ssa-iterators.h (ssa_vuse_operand): New inline. · eeead3a6
      2016-08-18  Richard Biener  <rguenther@suse.de>
      
      	* ssa-iterators.h (ssa_vuse_operand): New inline.
      	* tree-if-conv.c (ifc_temp_var): Update virtual operand.
      	(predicate_all_scalar_phis): Use remove_phi_node to remove
      	phi nodes predicated.  Delay removing virtual PHIs.
      	(predicate_mem_writes): Update virtual operands.
      	(combine_blocks): Likewise.  Propagate out remaining virtual PHIs.
      	(tree_if_conversion): Do not rewrite virtual SSA form.
      	* tree-phinodes.c (release_phi_node): Make static.
      	* tree-phinodes.h (release_phi_node): Remove.
      
      From-SVN: r239560
      Richard Biener committed
    • i386.c (enum ix86_builtins): Remove IX86_BUILTIN_* codes that appear in bdesc_* arrays... · 5730589d
      	* config/i386/i386.c (enum ix86_builtins): Remove IX86_BUILTIN_*
      	codes that appear in bdesc_* arrays, instead include i386-builtin.def
      	twice to define those.
      	(bdesc_comi, bdesc_pcmpestr, bdesc_pcmpistr, bdesc_special_args,
      	bdesc_args, bdesc_round_args, bdesc_mpx, bdesc_mpx_const,
      	bdesc_multi_arg): Define by including i386-builtin.def the third time.
      	* config/i386/i386-builtin.def: New file.
      
      From-SVN: r239559
      Jakub Jelinek committed
    • Daily bump. · 395cbeb5
      From-SVN: r239553
      GCC Administrator committed
    • input.c: move test functions within #CHECKING_P and into selftest:: · 0e06d2b3
      gcc/ChangeLog:
      	* input.c (get_source_range_for_char): Rename to...
      	(selftest::get_source_range_for_char): ...this, and move within
      	the #if CHECKING_P guard.
      	(get_num_source_ranges_for_substring): Rename to...
      	(selftest::get_num_source_ranges_for_substring): ...this, move
      	within the #if CHECKING_P guard, and make static.
      	(selftest::assert_num_substring_ranges): Initialize
      	actual_num_ranges.
      
      From-SVN: r239550
      David Malcolm committed
  3. 17 Aug, 2016 10 commits