From: Simon Marchi <simon.marchi@polymtl.ca>
To: Tom Tromey <tom@tromey.com>
Cc: gdb-patches@sourceware.org
Subject: Re: [RFA 05/13] Remove directive-searched cleanups
Date: Fri, 03 Nov 2017 01:09:00 -0000 [thread overview]
Message-ID: <b46db8010bce8310cdc8ad566e5e0631@polymtl.ca> (raw)
In-Reply-To: <20171102223612.3642-6-tom@tromey.com>
On 2017-11-02 18:36, Tom Tromey wrote:
> This removes a few cleanups related to the "searched" field in
> struct using_direct, replacing these with scoped_restore.
>
> gdb/ChangeLog
> 2017-11-02 Tom Tromey <tom@tromey.com>
>
> * cp-namespace.c (reset_directive_searched): Remove.
> (cp_lookup_symbol_via_imports): Use scoped_restore.
> * cp-support.c (reset_directive_searched): Remove.
> (make_symbol_overload_list_using): Use scoped_restore.
> * d-namespace.c (d_lookup_symbol_imports): Use scoped_restore.
> (reset_directive_searched): Remove.
> ---
> gdb/ChangeLog | 9 +++++++++
> gdb/cp-namespace.c | 25 +++----------------------
> gdb/cp-support.c | 19 ++-----------------
> gdb/d-namespace.c | 26 +++-----------------------
> 4 files changed, 17 insertions(+), 62 deletions(-)
>
> diff --git a/gdb/cp-namespace.c b/gdb/cp-namespace.c
> index 214b7e1cf4..d8817c0372 100644
> --- a/gdb/cp-namespace.c
> +++ b/gdb/cp-namespace.c
> @@ -338,15 +338,6 @@ cp_lookup_symbol_in_namespace (const char
> *the_namespace, const char *name,
> return sym;
> }
>
> -/* Used for cleanups to reset the "searched" flag in case of an error.
> */
> -
> -static void
> -reset_directive_searched (void *data)
> -{
> - struct using_direct *direct = (struct using_direct *) data;
> - direct->searched = 0;
> -}
> -
> /* Search for NAME by applying all import statements belonging to
> BLOCK which are applicable in SCOPE. If DECLARATION_ONLY the
> search is restricted to using declarations.
> @@ -388,7 +379,6 @@ cp_lookup_symbol_via_imports (const char *scope,
> struct block_symbol sym;
> int len;
> int directive_match;
> - struct cleanup *searched_cleanup;
>
> sym.symbol = NULL;
> sym.block = NULL;
> @@ -425,9 +415,8 @@ cp_lookup_symbol_via_imports (const char *scope,
> {
> /* Mark this import as searched so that the recursive call
> does not search it again. */
> - current->searched = 1;
> - searched_cleanup = make_cleanup (reset_directive_searched,
> - current);
> + scoped_restore reset_directive_searched
> + = make_scoped_restore (¤t->searched, 1);
>
> /* If there is an import of a single declaration, compare the
> imported declaration (after optional renaming by its alias)
> @@ -446,9 +435,6 @@ cp_lookup_symbol_via_imports (const char *scope,
> search of this import is complete. */
> if (declaration_only || sym.symbol != NULL || current->declaration)
> {
> - current->searched = 0;
> - discard_cleanups (searched_cleanup);
> -
> if (sym.symbol != NULL)
> return sym;
>
> @@ -460,10 +446,7 @@ cp_lookup_symbol_via_imports (const char *scope,
> if (strcmp (name, *excludep) == 0)
> break;
> if (*excludep)
> - {
> - discard_cleanups (searched_cleanup);
> - continue;
> - }
> + continue;
In this case, the cleanup is discarded. Shouldn't the same thing happen
with the scoped_restore? Or was it an error in the original code, and
we always want to reset searched?
There's the same case in d-namespace.c.
Simon
next prev parent reply other threads:[~2017-11-03 1:09 UTC|newest]
Thread overview: 35+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-11-02 22:36 [RFA 00/13] more cleanup removal Tom Tromey
2017-11-02 22:36 ` [RFA 06/13] Replace start_rbreak_breakpoints and end_rbreak_breakpoints Tom Tromey
2017-11-03 1:21 ` Simon Marchi
2017-11-03 16:58 ` Tom Tromey
2017-11-03 17:20 ` Simon Marchi
2017-11-04 16:25 ` Tom Tromey
2017-11-02 22:36 ` [RFA 01/13] Replace really_free_pendings with a scoped_ class Tom Tromey
2017-11-02 22:36 ` [RFA 13/13] Use std::vector in h8300-tdep.c Tom Tromey
2017-11-03 1:59 ` Simon Marchi
2017-11-04 16:25 ` Tom Tromey
2017-11-02 22:36 ` [RFA 09/13] Use gdb::def_vector in ppc-linux-tdep.c Tom Tromey
2017-11-03 1:31 ` Simon Marchi
2017-11-03 17:07 ` Tom Tromey
2017-11-02 22:36 ` [RFA 03/13] Use std::vector in compile-loc2c.c Tom Tromey
2017-11-02 22:36 ` [RFA 07/13] Use gdb::def_vector in sparc64-tdep.c Tom Tromey
2017-11-03 1:25 ` Simon Marchi
2017-11-03 17:05 ` Tom Tromey
2017-11-02 22:36 ` [RFA 05/13] Remove directive-searched cleanups Tom Tromey
2017-11-03 1:09 ` Simon Marchi [this message]
2017-11-03 16:42 ` Tom Tromey
2017-11-03 16:46 ` Simon Marchi
2017-11-02 22:36 ` [RFA 12/13] Introduce gdb_breakpoint_up Tom Tromey
2017-11-03 1:56 ` Simon Marchi
2017-11-03 17:28 ` Tom Tromey
2017-11-02 22:36 ` [RFA 11/13] Use unique_xmalloc_ptr in c_type_print_base Tom Tromey
2017-11-02 22:36 ` [RFA 08/13] Remove make_cleanup_free_objfile Tom Tromey
2017-11-02 22:36 ` [RFA 10/13] Remove cleanups from linux-tdep.c Tom Tromey
2017-11-03 1:43 ` Simon Marchi
2017-11-04 16:25 ` Tom Tromey
2017-11-02 22:36 ` [RFA 02/13] Remove cleanups from link_callbacks_einfo Tom Tromey
2017-11-02 22:38 ` [RFA 04/13] Use unique_xmalloc_ptr in find_separate_debug_file_by_debuglink Tom Tromey
2017-11-03 1:02 ` Simon Marchi
2017-11-03 16:39 ` Tom Tromey
2017-11-03 1:59 ` [RFA 00/13] more cleanup removal Simon Marchi
2017-11-04 16:28 ` Tom Tromey
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=b46db8010bce8310cdc8ad566e5e0631@polymtl.ca \
--to=simon.marchi@polymtl.ca \
--cc=gdb-patches@sourceware.org \
--cc=tom@tromey.com \
/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