diff options
author | Marc-Andre Laperle <marc-andre.laperle@ericsson.com> | 2017-03-20 14:57:51 -0400 |
---|---|---|
committer | Marc-Andre Laperle <marc-andre.laperle@ericsson.com> | 2017-03-20 14:57:51 -0400 |
commit | 51457a05780da82b5321a1574caed95ac0e6923e (patch) | |
tree | 99ed97a890a2c02782516153d7c2a82f9718bc04 /gdb/mi/mi-cmd-file.c | |
parent | 5b291c049658614196197e4ea4bb42bcc176b876 (diff) | |
download | gdb-51457a05780da82b5321a1574caed95ac0e6923e.zip gdb-51457a05780da82b5321a1574caed95ac0e6923e.tar.gz gdb-51457a05780da82b5321a1574caed95ac0e6923e.tar.bz2 |
Add -file-list-shared-libraries MI command
This change adds the MI equivalent for the "info sharedlibrary"
command. The command was already partially documented but ignored as
it was not implemented. The new MI command works similarly to the CLI
command, taking an optional regular expression as an argument and
outputting the library information.
I included a test for the new command in mi-solib.exp.
gdb/doc/ChangeLog:
* gdb.texinfo (gdb/mi Symbol Query Commands): Document new MI
command file-list-shared-libraries
(GDB/MI Async Records): Update documentation of library-loaded with new
field.
gdb/ChangeLog:
* NEWS: Add an entry about new '-file-list-shared-libraries' command.
* mi/mi-cmd-file.c (mi_cmd_file_list_shared_libraries):
New function definition.
* mi/mi-cmds.c (mi_cmds): Add -file-list-shared-libraries command.
* mi/mi-cmds.h (mi_cmd_file_list_shared_libraries):
New function declaration.
* mi/mi-interp.c (mi_output_solib_attribs): New Function.
* mi/mi-interp.h: New file.
* solib.c (info_sharedlibrary_command): Replace for loop with
ALL_SO_LIBS macro
* solib.h (update_solib_list): New function declaration.
(so_list_head): Move macro.
* solist.h (ALL_SO_LIBS): New macro.
gdb/testsuite/ChangeLog:
* gdb.mi/mi-solib.exp (test_file_list_shared_libraries):
New procedure.
Signed-off-by: Marc-Andre Laperle <marc-andre.laperle@ericsson.com>
Diffstat (limited to 'gdb/mi/mi-cmd-file.c')
-rw-r--r-- | gdb/mi/mi-cmd-file.c | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/gdb/mi/mi-cmd-file.c b/gdb/mi/mi-cmd-file.c index 71e2845..a2ad392 100644 --- a/gdb/mi/mi-cmd-file.c +++ b/gdb/mi/mi-cmd-file.c @@ -20,11 +20,15 @@ #include "defs.h" #include "mi-cmds.h" #include "mi-getopt.h" +#include "mi-interp.h" #include "ui-out.h" #include "symtab.h" #include "source.h" #include "objfiles.h" #include "psymtab.h" +#include "solib.h" +#include "solist.h" +#include "gdb_regex.h" /* Return to the client the absolute path and line number of the current file being executed. */ @@ -106,3 +110,56 @@ mi_cmd_file_list_exec_source_files (char *command, char **argv, int argc) uiout->end (ui_out_type_list); } + +/* See mi-cmds.h. */ + +void +mi_cmd_file_list_shared_libraries (char *command, char **argv, int argc) +{ + struct ui_out *uiout = current_uiout; + const char *pattern; + struct so_list *so = NULL; + struct gdbarch *gdbarch = target_gdbarch (); + + switch (argc) + { + case 0: + pattern = NULL; + break; + case 1: + pattern = argv[0]; + break; + default: + error (_("Usage: -file-list-shared-libraries [REGEXP]")); + } + + if (pattern != NULL) + { + const char *re_err = re_comp (pattern); + + if (re_err != NULL) + error (_("Invalid regexp: %s"), re_err); + } + + update_solib_list (1); + + /* Print the table header. */ + struct cleanup *cleanup + = make_cleanup_ui_out_list_begin_end (uiout, "shared-libraries"); + + ALL_SO_LIBS (so) + { + if (so->so_name[0] == '\0') + continue; + if (pattern != NULL && !re_exec (so->so_name)) + continue; + + struct cleanup *tuple_clean_up + = make_cleanup_ui_out_tuple_begin_end (uiout, NULL); + mi_output_solib_attribs (uiout, so); + + do_cleanups (tuple_clean_up); + } + + do_cleanups (cleanup); +} |