This is the mail archive of the gdb-patches@sourceware.org mailing list for the GDB project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

Re: [PATCH] [Ada] Add support for subprogram renamings


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


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]