OpenCores
URL https://opencores.org/ocsvn/openrisc_me/openrisc_me/trunk

Subversion Repositories openrisc_me

[/] [openrisc/] [trunk/] [gnu-src/] [gdb-7.1/] [gdb/] [cli/] [cli-logging.c] - Blame information for rev 401

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 227 jeremybenn
/* Command-line output logging for GDB, the GNU debugger.
2
 
3
   Copyright (c) 2003, 2004, 2007, 2008, 2009, 2010
4
   Free Software Foundation, Inc.
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 3 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, see <http://www.gnu.org/licenses/>.  */
20
 
21
#include "defs.h"
22
#include "gdbcmd.h"
23
#include "ui-out.h"
24
 
25
#include "gdb_string.h"
26
 
27
/* These hold the pushed copies of the gdb output files.
28
   If NULL then nothing has yet been pushed.  */
29
struct saved_output_files
30
{
31
  struct ui_file *out;
32
  struct ui_file *err;
33
  struct ui_file *log;
34
  struct ui_file *targ;
35
};
36
static struct saved_output_files saved_output;
37
static char *saved_filename;
38
 
39
static char *logging_filename;
40
static void
41
show_logging_filename (struct ui_file *file, int from_tty,
42
                       struct cmd_list_element *c, const char *value)
43
{
44
  fprintf_filtered (file, _("The current logfile is \"%s\".\n"),
45
                    value);
46
}
47
 
48
int logging_overwrite;
49
static void
50
show_logging_overwrite (struct ui_file *file, int from_tty,
51
                        struct cmd_list_element *c, const char *value)
52
{
53
  fprintf_filtered (file, _("\
54
Whether logging overwrites or appends to the log file is %s.\n"),
55
                    value);
56
}
57
 
58
int logging_redirect;
59
static void
60
show_logging_redirect (struct ui_file *file, int from_tty,
61
                       struct cmd_list_element *c, const char *value)
62
{
63
  fprintf_filtered (file, _("The logging output mode is %s.\n"), value);
64
}
65
 
66
/* If we've pushed output files, close them and pop them.  */
67
static void
68
pop_output_files (void)
69
{
70
  /* Only delete one of the files -- they are all set to the same
71
     value.  */
72
  ui_file_delete (gdb_stdout);
73
  gdb_stdout = saved_output.out;
74
  gdb_stderr = saved_output.err;
75
  gdb_stdlog = saved_output.log;
76
  gdb_stdtarg = saved_output.targ;
77
  saved_output.out = NULL;
78
  saved_output.err = NULL;
79
  saved_output.log = NULL;
80
  saved_output.targ = NULL;
81
 
82
  ui_out_redirect (uiout, NULL);
83
}
84
 
85
/* This is a helper for the `set logging' command.  */
86
static void
87
handle_redirections (int from_tty)
88
{
89
  struct cleanup *cleanups;
90
  struct ui_file *output;
91
 
92
  if (saved_filename != NULL)
93
    {
94
      fprintf_unfiltered (gdb_stdout, "Already logging to %s.\n",
95
                          saved_filename);
96
      return;
97
    }
98
 
99
  output = gdb_fopen (logging_filename, logging_overwrite ? "w" : "a");
100
  if (output == NULL)
101
    perror_with_name (_("set logging"));
102
  cleanups = make_cleanup_ui_file_delete (output);
103
 
104
  /* Redirects everything to gdb_stdout while this is running.  */
105
  if (!logging_redirect)
106
    {
107
      output = tee_file_new (gdb_stdout, 0, output, 1);
108
      if (output == NULL)
109
        perror_with_name (_("set logging"));
110
      discard_cleanups (cleanups);
111
      cleanups = make_cleanup_ui_file_delete (output);
112
      if (from_tty)
113
        fprintf_unfiltered (gdb_stdout, "Copying output to %s.\n",
114
                            logging_filename);
115
    }
116
  else if (from_tty)
117
    fprintf_unfiltered (gdb_stdout, "Redirecting output to %s.\n",
118
                        logging_filename);
119
 
120
  discard_cleanups (cleanups);
121
 
122
  saved_filename = xstrdup (logging_filename);
123
  saved_output.out = gdb_stdout;
124
  saved_output.err = gdb_stderr;
125
  saved_output.log = gdb_stdlog;
126
  saved_output.targ = gdb_stdtarg;
127
 
128
  gdb_stdout = output;
129
  gdb_stderr = output;
130
  gdb_stdlog = output;
131
  gdb_stdtarg = output;
132
 
133
  if (ui_out_redirect (uiout, gdb_stdout) < 0)
134
    warning (_("Current output protocol does not support redirection"));
135
}
136
 
137
static void
138
set_logging_on (char *args, int from_tty)
139
{
140
  char *rest = args;
141
  if (rest && *rest)
142
    {
143
      xfree (logging_filename);
144
      logging_filename = xstrdup (rest);
145
    }
146
  handle_redirections (from_tty);
147
}
148
 
149
static void
150
set_logging_off (char *args, int from_tty)
151
{
152
  if (saved_filename == NULL)
153
    return;
154
 
155
  pop_output_files ();
156
  if (from_tty)
157
    fprintf_unfiltered (gdb_stdout, "Done logging to %s.\n", saved_filename);
158
  xfree (saved_filename);
159
  saved_filename = NULL;
160
}
161
 
162
static void
163
set_logging_command (char *args, int from_tty)
164
{
165
  printf_unfiltered (_("\
166
\"set logging\" lets you log output to a file.\n\
167
Usage: set logging on [FILENAME]\n\
168
       set logging off\n\
169
       set logging file FILENAME\n\
170
       set logging overwrite [on|off]\n\
171
       set logging redirect [on|off]\n"));
172
}
173
 
174
static void
175
show_logging_command (char *args, int from_tty)
176
{
177
  if (saved_filename)
178
    printf_unfiltered (_("Currently logging to \"%s\".\n"), saved_filename);
179
  if (saved_filename == NULL
180
      || strcmp (logging_filename, saved_filename) != 0)
181
    printf_unfiltered (_("Future logs will be written to %s.\n"),
182
                       logging_filename);
183
 
184
  if (logging_overwrite)
185
    printf_unfiltered (_("Logs will overwrite the log file.\n"));
186
  else
187
    printf_unfiltered (_("Logs will be appended to the log file.\n"));
188
 
189
  if (logging_redirect)
190
    printf_unfiltered (_("Output will be sent only to the log file.\n"));
191
  else
192
    printf_unfiltered (_("Output will be logged and displayed.\n"));
193
}
194
 
195
/* Provide a prototype to silence -Wmissing-prototypes.  */
196
extern initialize_file_ftype _initialize_cli_logging;
197
 
198
void
199
_initialize_cli_logging (void)
200
{
201
  static struct cmd_list_element *set_logging_cmdlist, *show_logging_cmdlist;
202
 
203
 
204
  add_prefix_cmd ("logging", class_support, set_logging_command,
205
                  _("Set logging options"), &set_logging_cmdlist,
206
                  "set logging ", 0, &setlist);
207
  add_prefix_cmd ("logging", class_support, show_logging_command,
208
                  _("Show logging options"), &show_logging_cmdlist,
209
                  "show logging ", 0, &showlist);
210
  add_setshow_boolean_cmd ("overwrite", class_support, &logging_overwrite, _("\
211
Set whether logging overwrites or appends to the log file."), _("\
212
Show whether logging overwrites or appends to the log file."), _("\
213
If set, logging overrides the log file."),
214
                           NULL,
215
                           show_logging_overwrite,
216
                           &set_logging_cmdlist, &show_logging_cmdlist);
217
  add_setshow_boolean_cmd ("redirect", class_support, &logging_redirect, _("\
218
Set the logging output mode."), _("\
219
Show the logging output mode."), _("\
220
If redirect is off, output will go to both the screen and the log file.\n\
221
If redirect is on, output will go only to the log file."),
222
                           NULL,
223
                           show_logging_redirect,
224
                           &set_logging_cmdlist, &show_logging_cmdlist);
225
  add_setshow_filename_cmd ("file", class_support, &logging_filename, _("\
226
Set the current logfile."), _("\
227
Show the current logfile."), _("\
228
The logfile is used when directing GDB's output."),
229
                            NULL,
230
                            show_logging_filename,
231
                            &set_logging_cmdlist, &show_logging_cmdlist);
232
  add_cmd ("on", class_support, set_logging_on,
233
           _("Enable logging."), &set_logging_cmdlist);
234
  add_cmd ("off", class_support, set_logging_off,
235
           _("Disable logging."), &set_logging_cmdlist);
236
 
237
  logging_filename = xstrdup ("gdb.txt");
238
}

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.