-/* MI Command Set - breakpoint and watchpoint commands.
- Copyright (C) 2000, 2001, 2002, 2007 Free Software Foundation, Inc.
+/* MI Command Set - file commands.
+ Copyright (C) 2000-2015 Free Software Foundation, Inc.
Contributed by Cygnus Solutions (a Red Hat company).
This file is part of GDB.
#include "symtab.h"
#include "source.h"
#include "objfiles.h"
+#include "psymtab.h"
/* Return to the client the absolute path and line number of the
- current file being executed. */
+ current file being executed. */
-enum mi_cmd_result
-mi_cmd_file_list_exec_source_file(char *command, char **argv, int argc)
+void
+mi_cmd_file_list_exec_source_file (char *command, char **argv, int argc)
{
struct symtab_and_line st;
- int optind = 0;
- char *optarg;
+ struct ui_out *uiout = current_uiout;
- if ( !mi_valid_noargs("mi_cmd_file_list_exec_source_file", argc, argv) )
- error (_("mi_cmd_file_list_exec_source_file: Usage: No args"));
+ if (!mi_valid_noargs ("-file-list-exec-source-file", argc, argv))
+ error (_("-file-list-exec-source-file: Usage: No args"));
- /* Set the default file and line, also get them */
- set_default_source_symtab_and_line();
- st = get_current_source_symtab_and_line();
+ /* Set the default file and line, also get them. */
+ set_default_source_symtab_and_line ();
+ st = get_current_source_symtab_and_line ();
- /* We should always get a symtab.
- Apparently, filename does not need to be tested for NULL.
- The documentation in symtab.h suggests it will always be correct */
+ /* We should always get a symtab. Apparently, filename does not
+ need to be tested for NULL. The documentation in symtab.h
+ suggests it will always be correct. */
if (!st.symtab)
- error (_("mi_cmd_file_list_exec_source_file: No symtab"));
+ error (_("-file-list-exec-source-file: No symtab"));
- /* Extract the fullname if it is not known yet */
- symtab_to_fullname (st.symtab);
-
- /* Print to the user the line, filename and fullname */
+ /* Print to the user the line, filename and fullname. */
ui_out_field_int (uiout, "line", st.line);
- ui_out_field_string (uiout, "file", st.symtab->filename);
+ ui_out_field_string (uiout, "file",
+ symtab_to_filename_for_display (st.symtab));
+
+ ui_out_field_string (uiout, "fullname", symtab_to_fullname (st.symtab));
+
+ ui_out_field_int (uiout, "macro-info",
+ COMPUNIT_MACRO_TABLE
+ (SYMTAB_COMPUNIT (st.symtab)) != NULL);
+}
+
+/* A callback for map_partial_symbol_filenames. */
+
+static void
+print_partial_file_name (const char *filename, const char *fullname,
+ void *ignore)
+{
+ struct ui_out *uiout = current_uiout;
+
+ ui_out_begin (uiout, ui_out_type_tuple, NULL);
+
+ ui_out_field_string (uiout, "file", filename);
- /* We may not be able to open the file (not available). */
- if (st.symtab->fullname)
- ui_out_field_string (uiout, "fullname", st.symtab->fullname);
+ if (fullname)
+ ui_out_field_string (uiout, "fullname", fullname);
- return MI_CMD_DONE;
+ ui_out_end (uiout, ui_out_type_tuple);
}
-enum mi_cmd_result
+void
mi_cmd_file_list_exec_source_files (char *command, char **argv, int argc)
{
+ struct ui_out *uiout = current_uiout;
+ struct compunit_symtab *cu;
struct symtab *s;
- struct partial_symtab *ps;
struct objfile *objfile;
- if (!mi_valid_noargs ("mi_cmd_file_list_exec_source_files", argc, argv))
- error (_("mi_cmd_file_list_exec_source_files: Usage: No args"));
+ if (!mi_valid_noargs ("-file-list-exec-source-files", argc, argv))
+ error (_("-file-list-exec-source-files: Usage: No args"));
- /* Print the table header */
+ /* Print the table header. */
ui_out_begin (uiout, ui_out_type_list, "files");
- /* Look at all of the symtabs */
- ALL_SYMTABS (objfile, s)
+ /* Look at all of the file symtabs. */
+ ALL_FILETABS (objfile, cu, s)
{
ui_out_begin (uiout, ui_out_type_tuple, NULL);
- ui_out_field_string (uiout, "file", s->filename);
-
- /* Extract the fullname if it is not known yet */
- symtab_to_fullname (s);
-
- if (s->fullname)
- ui_out_field_string (uiout, "fullname", s->fullname);
+ ui_out_field_string (uiout, "file", symtab_to_filename_for_display (s));
+ ui_out_field_string (uiout, "fullname", symtab_to_fullname (s));
ui_out_end (uiout, ui_out_type_tuple);
}
- /* Look at all of the psymtabs */
- ALL_PSYMTABS (objfile, ps)
- {
- if (!ps->readin)
- {
- ui_out_begin (uiout, ui_out_type_tuple, NULL);
-
- ui_out_field_string (uiout, "file", ps->filename);
-
- /* Extract the fullname if it is not known yet */
- psymtab_to_fullname (ps);
-
- if (ps->fullname)
- ui_out_field_string (uiout, "fullname", ps->fullname);
-
- ui_out_end (uiout, ui_out_type_tuple);
- }
- }
+ map_symbol_filenames (print_partial_file_name, NULL,
+ 1 /*need_fullname*/);
ui_out_end (uiout, ui_out_type_list);
-
- return MI_CMD_DONE;
}