1 /* MI Command Set - breakpoint and watchpoint commands.
2 Copyright (C) 2000, 2001, 2002, 2007 Free Software Foundation, Inc.
3 Contributed by Cygnus Solutions (a Red Hat company).
5 This file is part of GDB.
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3 of the License, or
10 (at your option) any later version.
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with this program. If not, see <http://www.gnu.org/licenses/>. */
22 #include "mi-getopt.h"
28 /* Return to the client the absolute path and line number of the
29 current file being executed. */
32 mi_cmd_file_list_exec_source_file(char *command, char **argv, int argc)
34 struct symtab_and_line st;
38 if ( !mi_valid_noargs("mi_cmd_file_list_exec_source_file", argc, argv) )
39 error (_("mi_cmd_file_list_exec_source_file: Usage: No args"));
41 /* Set the default file and line, also get them */
42 set_default_source_symtab_and_line();
43 st = get_current_source_symtab_and_line();
45 /* We should always get a symtab.
46 Apparently, filename does not need to be tested for NULL.
47 The documentation in symtab.h suggests it will always be correct */
49 error (_("mi_cmd_file_list_exec_source_file: No symtab"));
51 /* Extract the fullname if it is not known yet */
52 symtab_to_fullname (st.symtab);
54 /* Print to the user the line, filename and fullname */
55 ui_out_field_int (uiout, "line", st.line);
56 ui_out_field_string (uiout, "file", st.symtab->filename);
58 /* We may not be able to open the file (not available). */
59 if (st.symtab->fullname)
60 ui_out_field_string (uiout, "fullname", st.symtab->fullname);
66 mi_cmd_file_list_exec_source_files (char *command, char **argv, int argc)
69 struct partial_symtab *ps;
70 struct objfile *objfile;
72 if (!mi_valid_noargs ("mi_cmd_file_list_exec_source_files", argc, argv))
73 error (_("mi_cmd_file_list_exec_source_files: Usage: No args"));
75 /* Print the table header */
76 ui_out_begin (uiout, ui_out_type_list, "files");
78 /* Look at all of the symtabs */
79 ALL_SYMTABS (objfile, s)
81 ui_out_begin (uiout, ui_out_type_tuple, NULL);
83 ui_out_field_string (uiout, "file", s->filename);
85 /* Extract the fullname if it is not known yet */
86 symtab_to_fullname (s);
89 ui_out_field_string (uiout, "fullname", s->fullname);
91 ui_out_end (uiout, ui_out_type_tuple);
94 /* Look at all of the psymtabs */
95 ALL_PSYMTABS (objfile, ps)
99 ui_out_begin (uiout, ui_out_type_tuple, NULL);
101 ui_out_field_string (uiout, "file", ps->filename);
103 /* Extract the fullname if it is not known yet */
104 psymtab_to_fullname (ps);
107 ui_out_field_string (uiout, "fullname", ps->fullname);
109 ui_out_end (uiout, ui_out_type_tuple);
113 ui_out_end (uiout, ui_out_type_list);