This is the mail archive of the
gdb-patches@sourceware.org
mailing list for the GDB project.
Re: [PATCH] [Ada] Add support for subprogram renamings
- From: Doug Evans <xdje42 at gmail dot com>
- To: Pierre-Marie de Rodat <derodat at adacore dot com>
- Cc: gdb-patches at sourceware dot org
- Date: Wed, 12 Aug 2015 20:55:06 -0700
- Subject: Re: [PATCH] [Ada] Add support for subprogram renamings
- Authentication-results: sourceware.org; auth=none
- References: <1437854144-31928-1-git-send-email-derodat at adacore dot com> <m3h9orz2pe dot fsf at sspiff dot org> <55C225E1 dot 6020109 at adacore dot com>
Pierre-Marie de Rodat <derodat@adacore.com> writes:
> Hi Doug,
>
> Thanks again for reviewing my patches!
>
> ...
> Quoting myself on IRC:
>> xdje: hello! in
>> https://sourceware.org/ml/gdb-patches/2015-07/msg00768.html you
>> suggested to move namespace bits in a new file
>>
>> I think that makes sense too, but lang-support.* does not
>>
>> I meanâ symtab, block, etc. all are about source debuggingâ and thus
>> languages support
>>
>> so Iâm tempted to create instead namespace.* or else to move this to
>> block.*
>>
>> what do you think?
>
> So I created namespace.[ch]. Please tell me if that's fine, otherwise
> I can switch to the names you suggested.
Fine by me.
>...
>
> gdb/ChangeLog:
>
> * ada-lang.c: Include namespace.h
> (aux_add_nonlocal_symbols): Fix a function name in comment.
> (ada_add_block_renamings): New.
> (add_nonlocal_symbols): Add global renamings handling.
> (ada_lookup_symbol_list_worker): Move the symbol lookup part
> to...
> (ada_add_all_symbols): ... this new function.
> (ada_add_block_symbols): Try to match the input name against the
> "using directives list", perform a recursive symbol lookup on
> the matched declarations.
> * block.h (struct block): Move the_namespace to top-level as
> namespace_info. Remove the language_specific field.
> (BLOCK_NAMESPACE): Update access to the namespace_info field.
> * buildsym.h (using_directives): Rename into...
> (local_using_directives): ... this.
> (global_using_directives): New.
> (struct context_stack): Rename the using_directives field into
> local_using_directives.
> * buildsym.c (finish_block_internal): Deal with the proper
> using directives repository (local or global).
> (prepare_for_building): Reset local_using_directives. Assert
> that there is no pending global using directive.
> (reset_symtab_globals): Reset global_using_directives and
> local_using_directives.
> (end_symtab_get_static_block): Don't ignore symtabs that have
> only using directives.
> (push_context): Update references to local_using_directives.
> (buildsym_init): Do not reset using_directives.
> * cp-support.c: Include namespace.h.
> * cp-support.h (struct using_direct): Move to namespace.h.
> (cp_add_using_directives): Move to namespace.h.
> * cp-namespace.c: Include namespace.h
> (cp_add_using_directive): Move to namespace.c, rename it to
> add_using_directive, add a "using_directives" argument and use
> it as the pending using directives repository. All callers
> updated.
> * dwarf2read.c (using_directives): New.
> (read_import_statement): Call using_directives.
> (read_func_scope): Update references to local_using_directives.
> (read_lexical_block_scope): Likewise.
> (read_namespace): Update the heading comment, call
> using_directives.
> * namespace.h: New file.
> * namespace.c: New file.
> * Makefile.in (SFILES): Add namespace.c.
> (COMMON_OBS): Add namespace.o
>
> gdb/testsuite/ChangeLog:
>
> * gdb.ada/fun_renaming.exp: New testcase.
> * gdb.ada/fun_renaming/fun_renaming.adb: New file.
> * gdb.ada/fun_renaming/pack.adb: New file.
> * gdb.ada/fun_renaming/pack.ads: New file.
LGTM