1 /* MI Command Set - breakpoint and watchpoint commands.
2 Copyright (C) 2000, 2001, 2002 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 2 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, write to the Free Software
19 Foundation, Inc., 51 Franklin Street, Fifth Floor,
20 Boston, MA 02110-1301, USA. */
24 #include "mi-getopt.h"
30 /* Return to the client the absolute path and line number of the
31 current file being executed. */
34 mi_cmd_file_list_exec_source_file(char *command
, char **argv
, int argc
)
36 struct symtab_and_line st
;
40 if ( !mi_valid_noargs("mi_cmd_file_list_exec_source_file", argc
, argv
) )
41 error (_("mi_cmd_file_list_exec_source_file: Usage: No args"));
43 /* Set the default file and line, also get them */
44 set_default_source_symtab_and_line();
45 st
= get_current_source_symtab_and_line();
47 /* We should always get a symtab.
48 Apparently, filename does not need to be tested for NULL.
49 The documentation in symtab.h suggests it will always be correct */
51 error (_("mi_cmd_file_list_exec_source_file: No symtab"));
53 /* Extract the fullname if it is not known yet */
54 symtab_to_fullname (st
.symtab
);
56 /* Print to the user the line, filename and fullname */
57 ui_out_field_int (uiout
, "line", st
.line
);
58 ui_out_field_string (uiout
, "file", st
.symtab
->filename
);
60 /* We may not be able to open the file (not available). */
61 if (st
.symtab
->fullname
)
62 ui_out_field_string (uiout
, "fullname", st
.symtab
->fullname
);
68 mi_cmd_file_list_exec_source_files (char *command
, char **argv
, int argc
)
71 struct partial_symtab
*ps
;
72 struct objfile
*objfile
;
74 if (!mi_valid_noargs ("mi_cmd_file_list_exec_source_files", argc
, argv
))
75 error (_("mi_cmd_file_list_exec_source_files: Usage: No args"));
77 /* Print the table header */
78 ui_out_begin (uiout
, ui_out_type_list
, "files");
80 /* Look at all of the symtabs */
81 ALL_SYMTABS (objfile
, s
)
83 ui_out_begin (uiout
, ui_out_type_tuple
, NULL
);
85 ui_out_field_string (uiout
, "file", s
->filename
);
87 /* Extract the fullname if it is not known yet */
88 symtab_to_fullname (s
);
91 ui_out_field_string (uiout
, "fullname", s
->fullname
);
93 ui_out_end (uiout
, ui_out_type_tuple
);
96 /* Look at all of the psymtabs */
97 ALL_PSYMTABS (objfile
, ps
)
101 ui_out_begin (uiout
, ui_out_type_tuple
, NULL
);
103 ui_out_field_string (uiout
, "file", ps
->filename
);
105 /* Extract the fullname if it is not known yet */
106 psymtab_to_fullname (ps
);
109 ui_out_field_string (uiout
, "fullname", ps
->fullname
);
111 ui_out_end (uiout
, ui_out_type_tuple
);
115 ui_out_end (uiout
, ui_out_type_list
);