de38d64ad2
With GCC 6.4 and 6.5 (at least), unit tests that use gdbsupport/valid-expr.h's CHECK_VALID fail to compile, with: In file included from src/gdb/unittests/offset-type-selftests.c:24:0: src/gdb/unittests/offset-type-selftests.c: In substitution of 'template<class Expected, template<class ...> class Op, class ... Args> using is_detected_exact = std::is_same<Expected, typename gdb::detection_detail::detector<gdb::nonesuch, void, Op, Args ...>::type> [with Expected = selftests::offset_type::off_A&; Op = selftests::offset_type::check_valid_expr75::archetype; Args = {selftests::offset_type::off_A, selftests::offset_type::off_B}]': src/gdb/unittests/offset-type-selftests.c:75:1: required from here src/gdb/../gdbsupport/valid-expr.h:65:20: error: type/value mismatch at argument 2 in template parameter list for 'template<class Expected, template<class ...> class Op, class ... Args> using is_detected_exact = std::is_same<Expected, typename gdb::detection_detail::detector<gdb::nonesuch, void, Op, Args ...>::type>' archetype, TYPES>::value == VALID, \ ^ The important part is the "error: type/value mismatch" error. Seems like that GCC doesn't understand that archetype is an alias template, and is being strict in requiring a template class. The fix here is then to make archetype a template class, to pacify GCC. The resulting code looks like this: template <TYPENAMES, typename = decltype (EXPR)> struct archetype { }; static_assert (gdb::is_detected_exact<archetype<TYPES, EXPR_TYPE>, archetype, TYPES>::value == VALID, ""); is_detected_exact<Expected, Op, Args> checks whether Op<Args> is type Expected: - For Expected, we pass the explicit EXPR_TYPE, overriding the default parameter type of archetype. - For Args we don't pass the last template parameter, so archtype defaults to the EXPR's decltype. So in essence, we're really checking whether EXPR_TYPE is the same as decltype(EXPR). We need to do the decltype in a template context in order to trigger SFINAE instead of failing to compile. The hunk in unittests/enum-flags-selftests.c becomes necessary, because unlike with the current alias template version, this new version makes GCC trigger -Wenum-compare warnings as well: src/gdb/unittests/enum-flags-selftests.c:328:33: error: comparison between 'enum selftests::enum_flags_tests::RE' and 'enum selftests::enum_flags_tests::RE2' [-Werror=enum-compare] CHECK_VALID (true, bool, RE () != RE2 ()) ^ src/gdb/../gdbsupport/valid-expr.h:61:45: note: in definition of macro 'CHECK_VALID_EXPR_INT' template <TYPENAMES, typename = decltype (EXPR)> \ ^ Build-tested with: - GCC {4.8.5, 6.4, 6.5, 7.3.1, 9.3.0, 11.0.0-20200910} - Clang 10.0.0 gdbsupport/ChangeLog: * valid-expr.h (CHECK_VALID_EXPR_INT): Make archetype a template class instead of an alias template and adjust static_assert. gdb/ChangeLog: * unittests/enum-flags-selftests.c: Check whether __GNUC__ is defined before using '#pragma GCC diagnostic' instead of checking __clang__.
331 lines
9.6 KiB
Plaintext
331 lines
9.6 KiB
Plaintext
2020-09-29 Pedro Alves <pedro@palves.net>
|
|
|
|
* valid-expr.h (CHECK_VALID_EXPR_INT): Make archetype a template
|
|
class instead of an alias template and adjust static_assert.
|
|
|
|
2020-09-24 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* event-loop.c (struct file_handler): Remove typedef, re-format.
|
|
|
|
2020-09-16 John Baldwin <jhb@FreeBSD.org>
|
|
|
|
* common.m4 (GDB_AC_COMMON): Refactor checks for kinfo_getfile().
|
|
* configure, config.in: Regenerate.
|
|
|
|
2020-09-14 Pedro Alves <pedro@palves.net>
|
|
|
|
* enum-flags.h: Include "traits.h".
|
|
(DEF_ENUM_FLAGS_TYPE): Declare a function instead of defining a
|
|
structure.
|
|
(enum_underlying_type): Update comment.
|
|
(namespace enum_flags_detail): New. Move struct zero_type here.
|
|
(EnumIsUnsigned, EnumIsSigned): New.
|
|
(class enum_flags): Make most methods constexpr.
|
|
(operator&=, operator|=, operator^=): Take an enum_flags instead
|
|
of an enum_type. Make rvalue ref versions deleted.
|
|
(operator enum_type()): Delete.
|
|
(operator&, operator|, operator^, operator~): Delete, moved out of
|
|
class.
|
|
(raw()): New method.
|
|
(is_enum_flags_enum_type_t): Declare.
|
|
(ENUM_FLAGS_GEN_BINOP, ENUM_FLAGS_GEN_COMPOUND_ASSIGN)
|
|
(ENUM_FLAGS_GEN_COMP): New. Use them to reimplement global
|
|
operators.
|
|
(operator~): Now constexpr and reimplemented.
|
|
(operator<<, operator>>): New deleted functions.
|
|
* valid-expr.h (CHECK_VALID_EXPR_5, CHECK_VALID_EXPR_6): New.
|
|
|
|
2020-09-14 Pedro Alves <pedro@palves.net>
|
|
|
|
* traits.h (struct nonesuch, struct detector, detected_or)
|
|
(detected_or_t, is_detected, detected_t, detected_or)
|
|
(detected_or_t, is_detected_exact, is_detected_convertible): New.
|
|
* valid-expr.h (CHECK_VALID_EXPR_INT): Use gdb::is_detected_exact.
|
|
|
|
2020-09-10 Kamil Rytarowski <n54@gmx.com>
|
|
|
|
* eintr.h: New file.
|
|
|
|
2020-08-13 Simon Marchi <simon.marchi@polymtl.ca>
|
|
|
|
* selftest.h (run_tests): Change parameter to array_view.
|
|
* selftest.c (run_tests): Change parameter to array_view and use
|
|
it.
|
|
|
|
2020-07-30 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
|
|
|
|
* Makefile.am (AM_CPPFLAGS): Add LARGEFILE_CPPFLAGS.
|
|
* common.m4 (GDB_AC_COMMON): Use BFD_SYS_PROCFS_H to check for
|
|
<sys/procfs.h>.
|
|
* Makefile.in: Regenerate.
|
|
* configure, config.in: Regenerate.
|
|
|
|
2020-07-28 Tom de Vries <tdevries@suse.de>
|
|
|
|
PR build/26281
|
|
* gdb_optional.h (class optional): Add volatile member to union
|
|
contaning m_dummy and m_item.
|
|
|
|
2020-07-17 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
* tdesc.h (struct target_desc_deleter): Moved here
|
|
from gdb/target-descriptions.h, extend comment.
|
|
(target_desc_up): Likewise.
|
|
|
|
2020-06-30 Tom Tromey <tromey@adacore.com>
|
|
|
|
PR build/26183:
|
|
* gdb_string_view.h (basic_string_view::to_string): Remove.
|
|
(gdb::to_string): New function.
|
|
|
|
2020-06-27 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* tdesc.h (class print_xml_feature) <add_line>: Add
|
|
ATTRIBUTE_PRINTF.
|
|
|
|
2020-06-23 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
* tdesc.cc (print_xml_feature::visit_pre): Use add_line to add
|
|
output content, and call indent as needed in all overloaded
|
|
variants.
|
|
(print_xml_feature::visit_post): Likewise.
|
|
(print_xml_feature::visit): Likewise.
|
|
(print_xml_feature::add_line): Two new overloaded functions.
|
|
* tdesc.h (print_xml_feature::indent): New member function.
|
|
(print_xml_feature::add_line): Two new overloaded member
|
|
functions.
|
|
(print_xml_feature::m_depth): New member variable.
|
|
|
|
2020-06-23 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
* tdesc.cc (print_xml_feature::visit_pre): Print compatible
|
|
information.
|
|
* tdesc.h (struct tdesc_compatible_info): Declare new struct.
|
|
(tdesc_compatible_info_up): New typedef.
|
|
(tdesc_compatible_info_list): Declare new function.
|
|
(tdesc_compatible_info_arch_name): Declare new function.
|
|
|
|
2020-05-25 Michael Weghorn <m.weghorn@posteo.de>
|
|
|
|
* common-utils.cc, common-utils.h (stringify_argv): Drop
|
|
now unused function stringify_argv
|
|
|
|
2020-05-25 Michael Weghorn <m.weghorn@posteo.de>
|
|
|
|
* common-inferior.cc, common-inferior.h (construct_inferior_arguments):
|
|
Adapt to take a gdb::array_view<char * const> parameter.
|
|
Adapt call site.
|
|
|
|
2020-05-25 Michael Weghorn <m.weghorn@posteo.de>
|
|
|
|
* common-inferior.cc, common-inferior.h (construct_inferior_arguments):
|
|
Adapt to handle zero args and return a std::string.
|
|
Adapt call site.
|
|
|
|
2020-05-25 Michael Weghorn <m.weghorn@posteo.de>
|
|
|
|
* common-inferior.h, common-inferior.cc: (construct_inferior_arguments):
|
|
Move function here from gdb/infcmd.c, gdb/inferior.h
|
|
|
|
2020-05-14 Kevin Buettner <kevinb@redhat.com>
|
|
|
|
* btrace-common.h (btrace_cpu_vendor): Add CV_AMD.
|
|
|
|
2020-05-14 Tankut Baris Aktemur <tankut.baris.aktemur@intel.com>
|
|
|
|
* common-regcache.h (regcache_read_pc_protected): New function
|
|
declaration.
|
|
|
|
2020-04-28 Tankut Baris Aktemur <tankut.baris.aktemur@intel.com>
|
|
|
|
* gdb-sigmask.h: Fix typo (pthead_sigmask -> pthread_sigmask).
|
|
|
|
2020-04-27 Simon Marchi <simon.marchi@polymtl.ca>
|
|
|
|
* common-defs.h: Include cstdlib.h.
|
|
|
|
2020-04-20 Tom Tromey <tromey@adacore.com>
|
|
|
|
* scoped_mmap.h (scoped_mmap): Mark move constructor as noexcept.
|
|
Use initialization style. Don't call destroy.
|
|
* scoped_fd.h (class scoped_fd): Mark move constructor as
|
|
noexcept.
|
|
* gdb_ref_ptr.h (class ref_ptr): Mark move constructor as
|
|
noexcept.
|
|
|
|
2020-04-13 Tom Tromey <tom@tromey.com>
|
|
|
|
* event-loop.c: Move comment. Remove obsolete comment.
|
|
|
|
2020-04-13 Tom Tromey <tom@tromey.com>
|
|
|
|
* event-loop.h: Move from ../gdb/.
|
|
* event-loop.cc: Move from ../gdb/.
|
|
|
|
2020-04-13 Tom Tromey <tom@tromey.com>
|
|
|
|
* errors.h (flush_streams): Declare.
|
|
|
|
2020-04-13 Tom Tromey <tom@tromey.com>
|
|
|
|
* gdb_select.h: Move from ../gdb/.
|
|
|
|
2020-04-13 Tom Tromey <tom@tromey.com>
|
|
|
|
* config.in, configure: Rebuild.
|
|
* common.m4 (GDB_AC_COMMON): Check for poll.h, sys/poll.h,
|
|
sys/select.h, and poll.
|
|
|
|
2020-03-31 Tom Tromey <tromey@adacore.com>
|
|
|
|
* btrace-common.cc (btrace_data_append): Conditionally call
|
|
memcpy.
|
|
|
|
2020-03-27 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
* create-version.sh: Resolve issues highlighted by shellcheck.
|
|
|
|
2020-03-20 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* config.in: Re-generate.
|
|
* configure: Re-generate.
|
|
|
|
2020-03-17 Kamil Rytarowski <n54@gmx.com>
|
|
|
|
* common-defs.h: Include alloca.h if HAVE_ALLOCA_H is defined.
|
|
|
|
2020-03-12 Tom Tromey <tom@tromey.com>
|
|
|
|
* common-types.h: Remove GDBSERVER code.
|
|
(gdb_byte, CORE_ADDR, LONGEST, ULONGEST): Redefine.
|
|
* common-defs.h: Remove GDBSERVER code.
|
|
|
|
2020-03-12 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* selftest.m4: Moved from gdb/.
|
|
* acinclude.m4: Update path to selftest.m4.
|
|
|
|
2020-03-12 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* configure.ac: Don't source bfd/development.sh.
|
|
* common.m4: Source bfd/development.sh.
|
|
* configure: Re-generate.
|
|
|
|
2020-03-12 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* configure: Re-generate.
|
|
|
|
2020-03-11 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* configure: Re-generate.
|
|
* warning.m4: Enable -Wmissing-prototypes.
|
|
|
|
2020-03-08 Tom Tromey <tom@tromey.com>
|
|
|
|
* gdb_binary_search.h: Fix two typos.
|
|
|
|
2020-03-06 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
* .dir-locals.el: New file.
|
|
|
|
2020-03-05 Vyacheslav Petrishchev <vyachemail@gmail.com>
|
|
|
|
* configure.ac: Added call development.sh.
|
|
* configure: Regenerate.
|
|
|
|
2020-03-05 Tankut Baris Aktemur <tankut.baris.aktemur@intel.com>
|
|
|
|
* .gitattributes: New file.
|
|
|
|
2020-03-03 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* Makefile.in: Re-generate.
|
|
|
|
2020-02-28 Sergio Durigan Junior <sergiodj@redhat.com>
|
|
|
|
* gdb-dlfcn.h (gdb_dlopen): Update comment.
|
|
|
|
2020-02-19 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
* configure: Regenerate.
|
|
|
|
2020-02-14 Tom Tromey <tom@tromey.com>
|
|
|
|
* common-defs.h: Change path to gnulib/config.h.
|
|
|
|
2020-02-13 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* Makefile.am: Rename source files from .c to .cc.
|
|
(CC, CFLAGS): Don't override.
|
|
(AM_CFLAGS): Rename to ...
|
|
(AM_CXXFLAGS): ... this.
|
|
* Makefile.in: Re-generate.
|
|
* %.c: Rename to %.cc.
|
|
|
|
2020-02-11 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* configure: Re-generate.
|
|
|
|
2020-02-11 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* warning.m4: Add -Wstrict-null-sentinel.
|
|
* configure: Re-generate.
|
|
|
|
2020-02-11 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* warning.m4: Move here, from gdb/warning.m4.
|
|
* acinclude.m4: Update warning.m4 path.
|
|
* Makefile.in: Re-generate.
|
|
|
|
2020-02-11 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* acinclude.m4: Include ../gdb/warning.m4.
|
|
* configure.ac: Use AM_GDB_WARNINGS.
|
|
* Makefile.am: Set AM_CFLAGS to WARN_CFLAGS and WERROR_CFLAGS.
|
|
* Makefile.in: Re-generate.
|
|
* configure: Re-generate.
|
|
|
|
2020-02-10 Tom de Vries <tdevries@suse.de>
|
|
|
|
* environ.c (gdb_environ::set): Cast concat NULL sentinel to char *.
|
|
|
|
2020-01-24 Christian Biesinger <cbiesinger@google.com>
|
|
|
|
* thread-pool.c (set_thread_name): Add an overload for the NetBSD
|
|
version of pthread_setname_np.
|
|
|
|
2020-01-17 Pedro Alves <palves@redhat.com>
|
|
|
|
* Makefile.am: Append CXX_DIALECT to CXX.
|
|
* Makefile.in: Regenerate.
|
|
|
|
2020-01-17 Pedro Alves <palves@redhat.com>
|
|
|
|
* configure.ac: Generate config.h instead of support-config.h.
|
|
* common-defs.h: Include <gdbsupport/config.h> instead of
|
|
<gdbsupport/support-config.h>.
|
|
* Makefile.in: Regenerate.
|
|
* configure: Regenerate.
|
|
|
|
2020-01-14 Tom Tromey <tom@tromey.com>
|
|
|
|
* Makefile.in: Rebuild.
|
|
* Makefile.am (check-defines): New target.
|
|
* check-defines.el: New file.
|
|
|
|
2020-01-14 Tom Tromey <tom@tromey.com>
|
|
|
|
* configure, Makefile.in, aclocal.m4, common.m4, config.in:
|
|
Rebuild.
|
|
* common.m4 (GDB_AC_COMMON): Move many checks from
|
|
gdb/configure.ac.
|
|
* acinclude.m4: Include bfd.m4, ptrace.m4.
|
|
|
|
2020-01-14 Tom Tromey <tom@tromey.com>
|
|
|
|
* common-defs.h: Add GDBSERVER case. Update includes.
|
|
* acinclude.m4, aclocal.m4, config.in, configure, configure.ac,
|
|
Makefile.am, Makefile.in, README: New files.
|
|
* Moved from ../gdb/gdbsupport/
|
|
|