Commit | Line | Data |
---|---|---|
8b93c638 | 1 | /* Output generating routines for GDB. |
b6ba6518 | 2 | Copyright 1999, 2000, 2001 Free Software Foundation, Inc. |
8b93c638 JM |
3 | Contributed by Cygnus Solutions. |
4 | Written by Fernando Nasser for Cygnus. | |
5 | ||
6 | This file is part of GDB. | |
7 | ||
8 | This program is free software; you can redistribute it and/or modify | |
9 | it under the terms of the GNU General Public License as published by | |
10 | the Free Software Foundation; either version 2 of the License, or | |
11 | (at your option) any later version. | |
12 | ||
13 | This program is distributed in the hope that it will be useful, | |
14 | but WITHOUT ANY WARRANTY; without even the implied warranty of | |
15 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
16 | GNU General Public License for more details. | |
17 | ||
18 | You should have received a copy of the GNU General Public License | |
19 | along with this program; if not, write to the Free Software | |
20 | Foundation, Inc., 59 Temple Place - Suite 330, | |
21 | Boston, MA 02111-1307, USA. */ | |
22 | ||
23 | #ifndef UI_OUT_H | |
24 | #define UI_OUT_H 1 | |
25 | ||
26 | /* The ui_out structure */ | |
27 | ||
8b93c638 JM |
28 | struct ui_out; |
29 | struct ui_out_data; | |
8b93c638 JM |
30 | |
31 | ||
32 | /* the current ui_out */ | |
33 | ||
34 | /* FIXME: This should not be a global but something passed down from main.c | |
35 | or top.c */ | |
36 | extern struct ui_out *uiout; | |
37 | ||
38 | /* alignment enum */ | |
39 | enum ui_align | |
40 | { | |
41 | ui_left = -1, | |
42 | ui_center, | |
43 | ui_right, | |
44 | ui_noalign | |
45 | }; | |
46 | ||
47 | /* flags enum */ | |
48 | enum ui_flags | |
49 | { | |
50 | ui_from_tty = 1, | |
51 | ui_source_list = 2 | |
52 | }; | |
53 | ||
54 | ||
55 | /* The ui_out stream structure. */ | |
56 | /* NOTE: cagney/2000-02-01: The ui_stream object can be subsumed by | |
57 | the more generic ui_file object. */ | |
58 | ||
59 | struct ui_stream | |
60 | { | |
61 | struct ui_out *uiout; | |
62 | struct ui_file *stream; | |
63 | }; | |
64 | ||
65 | ||
66 | /* Prototypes for ui-out API. */ | |
67 | ||
631ec795 | 68 | /* A result is a recursive data structure consisting of lists and |
666547aa | 69 | tuples. */ |
631ec795 AC |
70 | |
71 | enum ui_out_type | |
72 | { | |
666547aa | 73 | ui_out_type_tuple, |
631ec795 AC |
74 | ui_out_type_list |
75 | }; | |
76 | ||
77 | extern void ui_out_begin (struct ui_out *uiout, | |
78 | enum ui_out_type level_type, | |
79 | const char *id); | |
80 | ||
81 | extern void ui_out_end (struct ui_out *uiout, enum ui_out_type type); | |
82 | ||
127431f9 AC |
83 | extern struct cleanup *ui_out_begin_cleanup_end (struct ui_out *uiout, |
84 | enum ui_out_type level_type, | |
85 | const char *id); | |
86 | ||
666547aa | 87 | /* A table can be considered a special tuple/list combination with |
631ec795 AC |
88 | the implied structure: ``table = { hdr = { header, ... } , body = [ { |
89 | field, ... }, ... ] }'' */ | |
90 | ||
a14ed312 | 91 | extern void ui_out_table_begin (struct ui_out *uiout, int nbrofcols, |
88379baf | 92 | const char *tblid); |
8b93c638 | 93 | |
a14ed312 | 94 | extern void ui_out_table_header (struct ui_out *uiout, int width, |
88379baf | 95 | enum ui_align align, const char *colhdr); |
8b93c638 | 96 | |
a14ed312 | 97 | extern void ui_out_table_body (struct ui_out *uiout); |
8b93c638 | 98 | |
a14ed312 | 99 | extern void ui_out_table_end (struct ui_out *uiout); |
8b93c638 | 100 | |
631ec795 AC |
101 | /* Compatibility wrappers, new code should use ui_out_begin() and |
102 | ui_out_end(). */ | |
103 | ||
666547aa | 104 | extern void ui_out_list_begin (struct ui_out *uiout); |
8b93c638 | 105 | |
a14ed312 | 106 | extern void ui_out_list_end (struct ui_out *uiout); |
8b93c638 | 107 | |
666547aa AC |
108 | extern struct cleanup *make_cleanup_ui_out_list_begin_end (struct ui_out *uiout); |
109 | ||
110 | extern void ui_out_tuple_begin (struct ui_out *uiout, const char *id); | |
111 | ||
112 | extern void ui_out_tuple_end (struct ui_out *uiout); | |
113 | ||
114 | extern struct cleanup *make_cleanup_ui_out_tuple_begin_end (struct ui_out *uiout, | |
115 | const char *id); | |
e6e0bfab | 116 | |
88379baf AC |
117 | extern void ui_out_field_int (struct ui_out *uiout, const char *fldname, |
118 | int value); | |
8b93c638 | 119 | |
88379baf | 120 | extern void ui_out_field_core_addr (struct ui_out *uiout, const char *fldname, |
a14ed312 | 121 | CORE_ADDR address); |
8b93c638 | 122 | |
88379baf | 123 | extern void ui_out_field_string (struct ui_out * uiout, const char *fldname, |
8b93c638 JM |
124 | const char *string); |
125 | ||
88379baf | 126 | extern void ui_out_field_stream (struct ui_out *uiout, const char *fldname, |
a14ed312 | 127 | struct ui_stream *buf); |
8b93c638 | 128 | |
88379baf AC |
129 | extern void ui_out_field_fmt (struct ui_out *uiout, const char *fldname, |
130 | const char *format, ...); | |
8b93c638 | 131 | |
88379baf | 132 | extern void ui_out_field_skip (struct ui_out *uiout, const char *fldname); |
8b93c638 | 133 | |
a14ed312 | 134 | extern void ui_out_spaces (struct ui_out *uiout, int numspaces); |
8b93c638 | 135 | |
88379baf | 136 | extern void ui_out_text (struct ui_out *uiout, const char *string); |
8b93c638 | 137 | |
a14ed312 | 138 | extern void ui_out_message (struct ui_out *uiout, int verbosity, |
88379baf | 139 | const char *format, ...); |
8b93c638 | 140 | |
a14ed312 | 141 | extern struct ui_stream *ui_out_stream_new (struct ui_out *uiout); |
8b93c638 | 142 | |
a14ed312 | 143 | extern void ui_out_stream_delete (struct ui_stream *buf); |
8b93c638 JM |
144 | |
145 | struct cleanup *make_cleanup_ui_out_stream_delete (struct ui_stream *buf); | |
146 | ||
a14ed312 | 147 | extern void ui_out_wrap_hint (struct ui_out *uiout, char *identstring); |
8b93c638 | 148 | |
a14ed312 | 149 | extern void ui_out_flush (struct ui_out *uiout); |
8b93c638 | 150 | |
a14ed312 | 151 | extern void ui_out_get_field_separator (struct ui_out *uiout); |
8b93c638 | 152 | |
a14ed312 | 153 | extern int ui_out_set_flags (struct ui_out *uiout, int mask); |
8b93c638 | 154 | |
a14ed312 | 155 | extern int ui_out_clear_flags (struct ui_out *uiout, int mask); |
8b93c638 | 156 | |
a14ed312 | 157 | extern int ui_out_get_verblvl (struct ui_out *uiout); |
8b93c638 JM |
158 | |
159 | extern int ui_out_test_flags (struct ui_out *uiout, int mask); | |
160 | ||
161 | #if 0 | |
a14ed312 | 162 | extern void ui_out_result_begin (struct ui_out *uiout, char *class); |
8b93c638 | 163 | |
a14ed312 | 164 | extern void ui_out_result_end (struct ui_out *uiout); |
8b93c638 | 165 | |
a14ed312 | 166 | extern void ui_out_info_begin (struct ui_out *uiout, char *class); |
8b93c638 | 167 | |
a14ed312 | 168 | extern void ui_out_info_end (struct ui_out *uiout); |
8b93c638 | 169 | |
a14ed312 | 170 | extern void ui_out_notify_begin (struct ui_out *uiout, char *class); |
8b93c638 | 171 | |
a14ed312 | 172 | extern void ui_out_notify_end (struct ui_out *uiout); |
8b93c638 | 173 | |
a14ed312 | 174 | extern void ui_out_error_begin (struct ui_out *uiout, char *class); |
8b93c638 | 175 | |
a14ed312 | 176 | extern void ui_out_error_end (struct ui_out *uiout); |
8b93c638 JM |
177 | #endif |
178 | ||
179 | #if 0 | |
a14ed312 | 180 | extern void gdb_error (struct ui_out *uiout, int severity, char *format, ...); |
8b93c638 | 181 | |
a14ed312 | 182 | extern void gdb_query (struct ui_out *uiout, int qflags, char *qprompt); |
8b93c638 JM |
183 | #endif |
184 | ||
185 | /* From here on we have things that are only needed by implementation | |
186 | routines and main.c. We should pehaps have a separate file for that, | |
187 | like a ui-out-impl.h file */ | |
188 | ||
189 | /* User Interface Output Implementation Function Table */ | |
190 | ||
191 | /* Type definition of all implementation functions. */ | |
192 | ||
193 | typedef void (table_begin_ftype) (struct ui_out * uiout, | |
e2e11a41 | 194 | int nbrofcols, const char *tblid); |
8b93c638 JM |
195 | typedef void (table_body_ftype) (struct ui_out * uiout); |
196 | typedef void (table_end_ftype) (struct ui_out * uiout); | |
197 | typedef void (table_header_ftype) (struct ui_out * uiout, int width, | |
e2e11a41 AC |
198 | enum ui_align align, |
199 | const char *colhdr); | |
80f49b30 AC |
200 | /* Note: level 0 is the top-level so LEVEL is always greater than |
201 | zero. */ | |
631ec795 AC |
202 | typedef void (ui_out_begin_ftype) (struct ui_out *uiout, |
203 | enum ui_out_type type, | |
204 | int level, const char *id); | |
205 | typedef void (ui_out_end_ftype) (struct ui_out *uiout, | |
206 | enum ui_out_type type, | |
207 | int level); | |
8b93c638 | 208 | typedef void (field_int_ftype) (struct ui_out * uiout, int fldno, int width, |
e2e11a41 AC |
209 | enum ui_align align, |
210 | const char *fldname, int value); | |
8b93c638 | 211 | typedef void (field_skip_ftype) (struct ui_out * uiout, int fldno, int width, |
e2e11a41 AC |
212 | enum ui_align align, |
213 | const char *fldname); | |
8b93c638 | 214 | typedef void (field_string_ftype) (struct ui_out * uiout, int fldno, int width, |
e2e11a41 AC |
215 | enum ui_align align, |
216 | const char *fldname, | |
8b93c638 JM |
217 | const char *string); |
218 | typedef void (field_fmt_ftype) (struct ui_out * uiout, int fldno, int width, | |
e2e11a41 AC |
219 | enum ui_align align, |
220 | const char *fldname, | |
221 | const char *format, | |
222 | va_list args); | |
8b93c638 | 223 | typedef void (spaces_ftype) (struct ui_out * uiout, int numspaces); |
e2e11a41 AC |
224 | typedef void (text_ftype) (struct ui_out * uiout, |
225 | const char *string); | |
8b93c638 | 226 | typedef void (message_ftype) (struct ui_out * uiout, int verbosity, |
e2e11a41 | 227 | const char *format, va_list args); |
8b93c638 JM |
228 | typedef void (wrap_hint_ftype) (struct ui_out * uiout, char *identstring); |
229 | typedef void (flush_ftype) (struct ui_out * uiout); | |
230 | ||
231 | /* ui-out-impl */ | |
232 | ||
233 | /* IMPORTANT: If you change this structure, make sure to change the default | |
234 | initialization in ui-out.c */ | |
235 | ||
236 | struct ui_out_impl | |
237 | { | |
238 | table_begin_ftype *table_begin; | |
239 | table_body_ftype *table_body; | |
240 | table_end_ftype *table_end; | |
241 | table_header_ftype *table_header; | |
631ec795 AC |
242 | ui_out_begin_ftype *begin; |
243 | ui_out_end_ftype *end; | |
8b93c638 JM |
244 | field_int_ftype *field_int; |
245 | field_skip_ftype *field_skip; | |
246 | field_string_ftype *field_string; | |
247 | field_fmt_ftype *field_fmt; | |
248 | spaces_ftype *spaces; | |
249 | text_ftype *text; | |
250 | message_ftype *message; | |
251 | wrap_hint_ftype *wrap_hint; | |
252 | flush_ftype *flush; | |
253 | }; | |
254 | ||
255 | extern struct ui_out_data *ui_out_data (struct ui_out *uiout); | |
256 | ||
257 | ||
258 | /* Create a ui_out object */ | |
259 | ||
260 | extern struct ui_out *ui_out_new (struct ui_out_impl *impl, | |
261 | struct ui_out_data *data, | |
262 | int flags); | |
263 | ||
264 | #endif /* UI_OUT_H */ |