public inbox for gcc-patches@gcc.gnu.org
 help / color / mirror / Atom feed
From: Jonathan Wakely <jwakely@redhat.com>
To: "François Dumont" <frs.dumont@gmail.com>
Cc: "libstdc++@gcc.gnu.org" <libstdc++@gcc.gnu.org>,
	gcc-patches <gcc-patches@gcc.gnu.org>
Subject: Re: [PATCH] PR libstdc++/81064 fix versioned namespace
Date: Tue, 18 Jul 2017 13:31:00 -0000	[thread overview]
Message-ID: <20170718133115.GB15340@redhat.com> (raw)
In-Reply-To: <edfdef0d-8b65-181b-03bc-cc4d65e2ba06@gmail.com>

On 17/07/17 22:54 +0200, François Dumont wrote:
>Hi
>
>    Here is the patch to fix libstdc++ versioned namespace.
>
>    Now versioned namespace is only at std and __gnu_cxx levels, not 
>anymore in nested namespaces.
>
>   PR libstdc++/81064
>
>    * include/bits/algorithmfwd.h: Reorganize versioned namespace.
>    * include/bits/basic_string.h: Likewise.
>    * include/bits/c++config: Likewise.
>    * include/bits/deque.tcc: Likewise.
>    * include/bits/forward_list.h: Likewise.
>    * include/bits/forward_list.tcc: Likewise.
>    * include/bits/hashtable_policy.h: Likewise.
>    * include/bits/list.tcc: Likewise.
>    * include/bits/move.h: Likewise.
>    * include/bits/quoted_string.h: Likewise.
>    * include/bits/random.h: Likewise.
>    * include/bits/random.tcc: Likewise.
>    * include/bits/regex.h: Likewise.
>    * include/bits/regex.tcc: Likewise.
>    * include/bits/regex_automaton.h: Likewise.
>    * include/bits/regex_automaton.tcc: Likewise.
>    * include/bits/regex_compiler.h: Likewise.
>    * include/bits/regex_compiler.tcc: Likewise.
>    * include/bits/regex_constants.h: Likewise.
>    * include/bits/regex_error.h: Likewise.
>    * include/bits/regex_executor.h: Likewise.
>    * include/bits/regex_executor.tcc: Likewise.
>    * include/bits/regex_scanner.h: Likewise.
>    * include/bits/regex_scanner.tcc: Likewise.
>    * include/bits/specfun.h: Likewise.
>    * include/bits/stl_algo.h: Likewise.
>    * include/bits/stl_algobase.h: Likewise.
>    * include/bits/stl_bvector.h: Likewise.
>    * include/bits/stl_deque.h: Likewise.
>    * include/bits/stl_iterator.h: Likewise.
>    * include/bits/stl_iterator_base_funcs.h: Likewise.
>    * include/bits/stl_list.h: Likewise.
>    * include/bits/stl_map.h: Likewise.
>    * include/bits/stl_multimap.h: Likewise.
>    * include/bits/stl_multiset.h: Likewise.
>    * include/bits/stl_relops.h: Likewise.
>    * include/bits/stl_set.h: Likewise.
>    * include/bits/stl_vector.h: Likewise.
>    * include/bits/uniform_int_dist.h: Likewise.
>    * include/bits/unordered_map.h: Likewise.
>    * include/bits/unordered_set.h: Likewise.
>    * include/bits/vector.tcc: Likewise.
>    * include/c_global/cmath: Likewise.
>    * include/c_std/cmath: Likewise.
>    * include/decimal/decimal: Likewise.
>    * include/decimal/decimal.h: Likewise.
>    * include/experimental/algorithm: Likewise.
>    * include/experimental/any: Likewise.
>    * include/experimental/array: Likewise.
>    * include/experimental/bits/erase_if.h: Likewise.
>    * include/experimental/bits/fs_dir.h: Likewise.
>    * include/experimental/bits/fs_fwd.h: Likewise.
>    * include/experimental/bits/fs_ops.h: Likewise.
>    * include/experimental/bits/fs_path.h: Likewise.
>    * include/experimental/bits/shared_ptr.h: Likewise.
>    * include/experimental/bits/string_view.tcc: Likewise.
>    * include/experimental/chrono: Likewise.
>    * include/experimental/deque: Likewise.
>    * include/experimental/filesystem: Likewise.
>    * include/experimental/forward_list: Likewise.
>    * include/experimental/functional: Likewise.
>    * include/experimental/iterator: Likewise.
>    * include/experimental/list: Likewise.
>    * include/experimental/map: Likewise.
>    * include/experimental/memory: Likewise.
>    * include/experimental/memory_resource: Likewise.
>    * include/experimental/numeric: Likewise.
>    * include/experimental/optional: Likewise.
>    * include/experimental/propagate_const: Likewise.
>    * include/experimental/random: Likewise.
>    * include/experimental/ratio: Likewise.
>    * include/experimental/regex: Likewise.
>    * include/experimental/set: Likewise.
>    * include/experimental/source_location: Likewise.
>    * include/experimental/string: Likewise.
>    * include/experimental/string_view: Likewise.
>    * include/experimental/system_error: Likewise.
>    * include/experimental/tuple: Likewise.
>    * include/experimental/type_traits: Likewise.
>    * include/experimental/unordered_map: Likewise.
>    * include/experimental/unordered_set: Likewise.
>    * include/experimental/utility: Likewise.
>    * include/experimental/vector: Likewise.
>    * include/ext/bitmap_allocator.h: Likewise.
>    * include/ext/codecvt_specializations.h: Likewise.
>    * include/ext/rope: Likewise.
>    * include/ext/typelist.h: Likewise.
>    * include/std/chrono: Likewise.
>    * include/std/complex: Likewise.
>    * include/std/functional: Likewise.
>    * include/std/numeric: Likewise.
>    * include/std/string_view: Likewise.
>    * include/std/thread: Likewise.
>    * include/std/variant: Likewise.
>    * include/tr1/array: Likewise.
>    * include/tr1/bessel_function.tcc: Likewise.
>    * include/tr1/beta_function.tcc: Likewise.
>    * include/tr1/cmath: Likewise.
>    * include/tr1/complex: Likewise.
>    * include/tr1/ell_integral.tcc: Likewise.
>    * include/tr1/exp_integral.tcc: Likewise.
>    * include/tr1/functional: Likewise.
>    * include/tr1/functional_hash.h: Likewise.
>    * include/tr1/gamma.tcc: Likewise.
>    * include/tr1/hashtable.h: Likewise.
>    * include/tr1/hashtable_policy.h: Likewise.
>    * include/tr1/hypergeometric.tcc: Likewise.
>    * include/tr1/legendre_function.tcc: Likewise.
>    * include/tr1/modified_bessel_func.tcc: Likewise.
>    * include/tr1/poly_hermite.tcc: Likewise.
>    * include/tr1/poly_laguerre.tcc: Likewise.
>    * include/tr1/random.h: Likewise.
>    * include/tr1/random.tcc: Likewise.
>    * include/tr1/regex: Likewise.
>    * include/tr1/riemann_zeta.tcc: Likewise.
>    * include/tr1/shared_ptr.h: Likewise.
>    * include/tr1/special_function_util.h: Likewise.
>    * include/tr1/tuple: Likewise.
>    * include/tr1/type_traits: Likewise.
>    * include/tr1/unordered_map.h: Likewise.
>    * include/tr1/unordered_set.h: Likewise.
>    * include/tr1/utility: Likewise.
>    * include/tr2/bool_set: Likewise.
>    * include/tr2/bool_set.tcc: Likewise.
>    * include/tr2/dynamic_bitset: Likewise.
>    * include/tr2/dynamic_bitset.tcc: Likewise.
>    * include/tr2/ratio: Likewise.
>    * include/tr2/type_traits: Likewise.
>    * src/c++11/chrono.cc: Likewise.
>    * src/c++11/compatibility-c++0x.cc: Likewise.
>    * src/c++11/compatibility-chrono.cc: Likewise.
>    * src/c++11/cxx11-shim_facets.cc: Likewise.
>    * src/c++11/hashtable_c++0x.cc: Likewise.
>    * src/c++11/placeholders.cc: Likewise.
>    * src/c++11/thread.cc: Likewise.
>    * src/c++98/bitmap_allocator.cc: Likewise.
>    * src/c++98/hashtable_tr1.cc: Likewise.
>    * src/c++98/list.cc: Likewise.
>    * src/shared/hashtable-aux.cc: Likewise.
>    * python/libstdcxx/v6/printers.py: Adapt.
>    * testsuite/20_util/duration/literals/range.cc: Adapt line number.
>    * testsuite/20_util/duration/requirements/typedefs_neg1.cc: Likewise.
>    * testsuite/20_util/duration/requirements/typedefs_neg2.cc: Likewise.
>    * testsuite/20_util/duration/requirements/typedefs_neg3.cc: Likewise.
>    * testsuite/20_util/forward/c_neg.cc: Likewise.
>    * testsuite/20_util/forward/f_neg.cc: Likewise.
>    * testsuite/26_numerics/random/pr60037-neg.cc: Likewise.
>
>Tested under normal and versioned namespace modes.
>
>Ok to commit ?

This is quite a huge change, so I'd like to wait and see if anyone
else has any opinion on it.

Personally I think it's necessary (assuming I understand the PR
correctly) and so if nobody objects I think we should go with this
change for GCC 8. Let's give it a few days for comments (and I'll
finish going through the patch carefully).




  reply	other threads:[~2017-07-18 13:31 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-07-17 20:55 François Dumont
2017-07-18 13:31 ` Jonathan Wakely [this message]
2017-07-18 13:31   ` Jonathan Wakely
2017-07-18 14:03   ` Ville Voutilainen
2017-07-18 19:17     ` François Dumont
2017-07-19 21:02     ` François Dumont

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20170718133115.GB15340@redhat.com \
    --to=jwakely@redhat.com \
    --cc=frs.dumont@gmail.com \
    --cc=gcc-patches@gcc.gnu.org \
    --cc=libstdc++@gcc.gnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).