* configure.ac (DEBUGDIR_RELOCATABLE): Define for debugdir inside
[deliverable/binutils-gdb.git] / gdb / main.c
CommitLineData
c906108c 1/* Top level stuff for GDB, the GNU debugger.
4389a95a 2
6aba47ca
DJ
3 Copyright (C) 1986, 1987, 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1995,
4 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2007
7509373f 5 Free Software Foundation, Inc.
c906108c 6
c5aa993b 7 This file is part of GDB.
c906108c 8
c5aa993b
JM
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 2 of the License, or
12 (at your option) any later version.
c906108c 13
c5aa993b
JM
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
c906108c 18
c5aa993b
JM
19 You should have received a copy of the GNU General Public License
20 along with this program; if not, write to the Free Software
197e01b6
EZ
21 Foundation, Inc., 51 Franklin Street, Fifth Floor,
22 Boston, MA 02110-1301, USA. */
c906108c
SS
23
24#include "defs.h"
c906108c
SS
25#include "top.h"
26#include "target.h"
27#include "inferior.h"
1adeb98a
FN
28#include "symfile.h"
29#include "gdbcore.h"
c906108c 30
60250e8b 31#include "exceptions.h"
c906108c
SS
32#include "getopt.h"
33
34#include <sys/types.h>
35#include "gdb_stat.h"
36#include <ctype.h>
37
38#include "gdb_string.h"
9e0b60a8 39#include "event-loop.h"
8b93c638 40#include "ui-out.h"
6457bd47 41
4389a95a 42#include "interps.h"
f15ab4a7
AC
43#include "main.h"
44
c906108c
SS
45/* If nonzero, display time usage both at startup and for each command. */
46
47int display_time;
48
49/* If nonzero, display space usage both at startup and for each command. */
50
51int display_space;
52
4389a95a
AC
53/* The selected interpreter. This will be used as a set command
54 variable, so it should always be malloc'ed - since
55 do_setshow_command will free it. */
fb40c209 56char *interpreter_p;
fb40c209 57
c906108c
SS
58/* Whether xdb commands will be handled */
59int xdb_commands = 0;
60
61/* Whether dbx commands will be handled */
62int dbx_commands = 0;
63
030292b7
DJ
64/* System root path, used to find libraries etc. */
65char *gdb_sysroot = 0;
66
d9fcf2fb
JM
67struct ui_file *gdb_stdout;
68struct ui_file *gdb_stderr;
69struct ui_file *gdb_stdlog;
449092f6
CV
70struct ui_file *gdb_stdin;
71/* target IO streams */
72struct ui_file *gdb_stdtargin;
22e8e3c7 73struct ui_file *gdb_stdtarg;
449092f6 74struct ui_file *gdb_stdtargerr;
c906108c 75
1a088d06
AS
76/* Support for the --batch-silent option. */
77int batch_silent = 0;
78
4b0ad762
AS
79/* Support for --return-child-result option.
80 Set the default to -1 to return error in the case
81 that the program does not run or does not complete. */
82int return_child_result = 0;
83int return_child_result_value = -1;
84
c906108c
SS
85/* Whether to enable writing into executable and core files */
86extern int write_files;
87
d9fcf2fb 88static void print_gdb_help (struct ui_file *);
c906108c
SS
89
90/* These two are used to set the external editor commands when gdb is farming
91 out files to be edited by another program. */
92
c5aa993b 93extern char *external_editor_command;
c906108c 94
11cf8741
JM
95/* Call command_loop. If it happens to return, pass that through as a
96 non-zero return status. */
97
98static int
99captured_command_loop (void *data)
c906108c 100{
4389a95a 101 current_interp_command_loop ();
11cf8741
JM
102 /* FIXME: cagney/1999-11-05: A correct command_loop() implementaton
103 would clean things up (restoring the cleanup chain) to the state
104 they were just prior to the call. Technically, this means that
e26cc349 105 the do_cleanups() below is redundant. Unfortunately, many FUNCs
11cf8741
JM
106 are not that well behaved. do_cleanups should either be replaced
107 with a do_cleanups call (to cover the problem) or an assertion
108 check to detect bad FUNCs code. */
109 do_cleanups (ALL_CLEANUPS);
110 /* If the command_loop returned, normally (rather than threw an
111 error) we try to quit. If the quit is aborted, catch_errors()
112 which called this catch the signal and restart the command
113 loop. */
114 quit_command (NULL, instream == stdin);
115 return 1;
116}
117
11cf8741
JM
118static int
119captured_main (void *data)
120{
121 struct captured_main_args *context = data;
122 int argc = context->argc;
123 char **argv = context->argv;
c906108c
SS
124 int count;
125 static int quiet = 0;
126 static int batch = 0;
552c04a7 127 static int set_args = 0;
c906108c
SS
128
129 /* Pointers to various arguments from command line. */
130 char *symarg = NULL;
131 char *execarg = NULL;
132 char *corearg = NULL;
133 char *cdarg = NULL;
134 char *ttyarg = NULL;
135
136 /* These are static so that we can take their address in an initializer. */
137 static int print_help;
138 static int print_version;
139
140 /* Pointers to all arguments of --command option. */
8a5a3c82
AS
141 struct cmdarg {
142 enum {
143 CMDARG_FILE,
144 CMDARG_COMMAND
145 } type;
146 char *string;
147 } *cmdarg;
c906108c
SS
148 /* Allocated size of cmdarg. */
149 int cmdsize;
150 /* Number of elements of cmdarg used. */
151 int ncmd;
152
153 /* Indices of all arguments of --directory option. */
154 char **dirarg;
155 /* Allocated size. */
156 int dirsize;
157 /* Number of elements used. */
158 int ndir;
c5aa993b 159
c906108c 160 struct stat homebuf, cwdbuf;
7509373f 161 char *homedir;
c906108c 162
52f0bd74 163 int i;
c906108c
SS
164
165 long time_at_startup = get_run_time ();
166
0fbb3da7
TT
167#if defined (HAVE_SETLOCALE) && defined (HAVE_LC_MESSAGES)
168 setlocale (LC_MESSAGES, "");
169#endif
170#if defined (HAVE_SETLOCALE)
171 setlocale (LC_CTYPE, "");
172#endif
173 bindtextdomain (PACKAGE, LOCALEDIR);
174 textdomain (PACKAGE);
175
6dd77b81
RH
176#ifdef HAVE_SBRK
177 lim_at_start = (char *) sbrk (0);
178#endif
179
c906108c
SS
180#if defined (ALIGN_STACK_ON_STARTUP)
181 i = (int) &count & 0x3;
182 if (i != 0)
183 alloca (4 - i);
184#endif
185
c906108c 186 cmdsize = 1;
8a5a3c82 187 cmdarg = (struct cmdarg *) xmalloc (cmdsize * sizeof (*cmdarg));
c906108c
SS
188 ncmd = 0;
189 dirsize = 1;
190 dirarg = (char **) xmalloc (dirsize * sizeof (*dirarg));
191 ndir = 0;
192
193 quit_flag = 0;
194 line = (char *) xmalloc (linesize);
195 line[0] = '\0'; /* Terminate saved (now empty) cmd line */
196 instream = stdin;
197
198 getcwd (gdb_dirbuf, sizeof (gdb_dirbuf));
199 current_directory = gdb_dirbuf;
200
da59e081
JM
201 gdb_stdout = stdio_fileopen (stdout);
202 gdb_stderr = stdio_fileopen (stderr);
203 gdb_stdlog = gdb_stderr; /* for moment */
204 gdb_stdtarg = gdb_stderr; /* for moment */
449092f6
CV
205 gdb_stdin = stdio_fileopen (stdin);
206 gdb_stdtargerr = gdb_stderr; /* for moment */
207 gdb_stdtargin = gdb_stdin; /* for moment */
c906108c 208
030292b7
DJ
209 /* Set the sysroot path. */
210#ifdef TARGET_SYSTEM_ROOT_RELOCATABLE
211 gdb_sysroot = make_relative_prefix (argv[0], BINDIR, TARGET_SYSTEM_ROOT);
212 if (gdb_sysroot)
213 {
214 struct stat s;
215 int res = 0;
216
217 if (stat (gdb_sysroot, &s) == 0)
218 if (S_ISDIR (s.st_mode))
219 res = 1;
220
221 if (res == 0)
222 {
a84d24ee 223 xfree (gdb_sysroot);
aa28a74e 224 gdb_sysroot = xstrdup (TARGET_SYSTEM_ROOT);
030292b7
DJ
225 }
226 }
227 else
aa28a74e 228 gdb_sysroot = xstrdup (TARGET_SYSTEM_ROOT);
030292b7 229#else
aa28a74e 230 gdb_sysroot = xstrdup (TARGET_SYSTEM_ROOT);
030292b7 231#endif
aa28a74e
DJ
232
233 /* Canonicalize the sysroot path. */
234 if (*gdb_sysroot)
235 {
236 char *canon_sysroot = lrealpath (gdb_sysroot);
237 if (canon_sysroot)
238 {
239 xfree (gdb_sysroot);
240 gdb_sysroot = canon_sysroot;
241 }
242 }
243
244#ifdef DEBUGDIR_RELOCATABLE
245 debug_file_directory = make_relative_prefix (argv[0], BINDIR, DEBUGDIR);
246 if (debug_file_directory)
247 {
248 struct stat s;
249 int res = 0;
250
251 if (stat (debug_file_directory, &s) == 0)
252 if (S_ISDIR (s.st_mode))
253 res = 1;
254
255 if (res == 0)
256 {
257 xfree (debug_file_directory);
258 debug_file_directory = xstrdup (DEBUGDIR);
259 }
260 }
261 else
262 debug_file_directory = xstrdup (DEBUGDIR);
263#else
264 debug_file_directory = xstrdup (DEBUGDIR);
030292b7
DJ
265#endif
266
aa28a74e
DJ
267 /* Canonicalize the debugfile path. */
268 if (*debug_file_directory)
269 {
270 char *canon_debug = lrealpath (debug_file_directory);
271 if (canon_debug)
272 {
273 xfree (debug_file_directory);
274 debug_file_directory = canon_debug;
275 }
276 }
277
4389a95a 278 /* There will always be an interpreter. Either the one passed into
e46e5ccd
KS
279 this captured main, or one specified by the user at start up, or
280 the console. Initialize the interpreter to the one requested by
281 the application. */
282 interpreter_p = xstrdup (context->interpreter_p);
4389a95a 283
c906108c
SS
284 /* Parse arguments and options. */
285 {
286 int c;
287 /* When var field is 0, use flag field to record the equivalent
288 short option (or arbitrary numbers starting at 10 for those
289 with no equivalent). */
49c7e338
AC
290 enum {
291 OPT_SE = 10,
292 OPT_CD,
293 OPT_ANNOTATE,
294 OPT_STATISTICS,
42fa7c0f
AC
295 OPT_TUI,
296 OPT_NOWINDOWS,
297 OPT_WINDOWS
49c7e338 298 };
c906108c 299 static struct option long_options[] =
c5aa993b 300 {
c906108c 301#if defined(TUI)
49c7e338 302 {"tui", no_argument, 0, OPT_TUI},
c906108c 303#endif
c5aa993b
JM
304 {"xdb", no_argument, &xdb_commands, 1},
305 {"dbx", no_argument, &dbx_commands, 1},
306 {"readnow", no_argument, &readnow_symbol_files, 1},
307 {"r", no_argument, &readnow_symbol_files, 1},
c5aa993b
JM
308 {"quiet", no_argument, &quiet, 1},
309 {"q", no_argument, &quiet, 1},
310 {"silent", no_argument, &quiet, 1},
311 {"nx", no_argument, &inhibit_gdbinit, 1},
312 {"n", no_argument, &inhibit_gdbinit, 1},
1a088d06 313 {"batch-silent", no_argument, 0, 'B'},
c5aa993b
JM
314 {"batch", no_argument, &batch, 1},
315 {"epoch", no_argument, &epoch_interface, 1},
316
317 /* This is a synonym for "--annotate=1". --annotate is now preferred,
318 but keep this here for a long time because people will be running
319 emacses which use --fullname. */
320 {"fullname", no_argument, 0, 'f'},
321 {"f", no_argument, 0, 'f'},
322
49c7e338 323 {"annotate", required_argument, 0, OPT_ANNOTATE},
c5aa993b 324 {"help", no_argument, &print_help, 1},
49c7e338 325 {"se", required_argument, 0, OPT_SE},
c5aa993b
JM
326 {"symbols", required_argument, 0, 's'},
327 {"s", required_argument, 0, 's'},
328 {"exec", required_argument, 0, 'e'},
329 {"e", required_argument, 0, 'e'},
330 {"core", required_argument, 0, 'c'},
331 {"c", required_argument, 0, 'c'},
00546b04
MS
332 {"pid", required_argument, 0, 'p'},
333 {"p", required_argument, 0, 'p'},
c5aa993b 334 {"command", required_argument, 0, 'x'},
8a5a3c82 335 {"eval-command", required_argument, 0, 'X'},
c5aa993b
JM
336 {"version", no_argument, &print_version, 1},
337 {"x", required_argument, 0, 'x'},
8a5a3c82 338 {"ex", required_argument, 0, 'X'},
3fc11d3e
JM
339#ifdef GDBTK
340 {"tclcommand", required_argument, 0, 'z'},
341 {"enable-external-editor", no_argument, 0, 'y'},
342 {"editor-command", required_argument, 0, 'w'},
343#endif
8b93c638
JM
344 {"ui", required_argument, 0, 'i'},
345 {"interpreter", required_argument, 0, 'i'},
346 {"i", required_argument, 0, 'i'},
c5aa993b 347 {"directory", required_argument, 0, 'd'},
c4093a6a 348 {"d", required_argument, 0, 'd'},
49c7e338 349 {"cd", required_argument, 0, OPT_CD},
c5aa993b
JM
350 {"tty", required_argument, 0, 't'},
351 {"baud", required_argument, 0, 'b'},
352 {"b", required_argument, 0, 'b'},
42fa7c0f
AC
353 {"nw", no_argument, NULL, OPT_NOWINDOWS},
354 {"nowindows", no_argument, NULL, OPT_NOWINDOWS},
355 {"w", no_argument, NULL, OPT_WINDOWS},
356 {"windows", no_argument, NULL, OPT_WINDOWS},
49c7e338 357 {"statistics", no_argument, 0, OPT_STATISTICS},
c5aa993b 358 {"write", no_argument, &write_files, 1},
552c04a7 359 {"args", no_argument, &set_args, 1},
f47b1503 360 {"l", required_argument, 0, 'l'},
4b0ad762 361 {"return-child-result", no_argument, &return_child_result, 1},
c5aa993b
JM
362 {0, no_argument, 0, 0}
363 };
c906108c
SS
364
365 while (1)
366 {
367 int option_index;
368
369 c = getopt_long_only (argc, argv, "",
370 long_options, &option_index);
552c04a7 371 if (c == EOF || set_args)
c906108c
SS
372 break;
373
374 /* Long option that takes an argument. */
375 if (c == 0 && long_options[option_index].flag == 0)
376 c = long_options[option_index].val;
377
378 switch (c)
379 {
380 case 0:
381 /* Long option that just sets a flag. */
382 break;
49c7e338 383 case OPT_SE:
c906108c
SS
384 symarg = optarg;
385 execarg = optarg;
386 break;
49c7e338 387 case OPT_CD:
c906108c
SS
388 cdarg = optarg;
389 break;
49c7e338 390 case OPT_ANNOTATE:
c906108c
SS
391 /* FIXME: what if the syntax is wrong (e.g. not digits)? */
392 annotation_level = atoi (optarg);
393 break;
49c7e338 394 case OPT_STATISTICS:
c906108c
SS
395 /* Enable the display of both time and space usage. */
396 display_time = 1;
397 display_space = 1;
398 break;
49c7e338 399 case OPT_TUI:
021e7609
AC
400 /* --tui is equivalent to -i=tui. */
401 xfree (interpreter_p);
cc4349ed 402 interpreter_p = xstrdup (INTERP_TUI);
021e7609 403 break;
42fa7c0f
AC
404 case OPT_WINDOWS:
405 /* FIXME: cagney/2003-03-01: Not sure if this option is
406 actually useful, and if it is, what it should do. */
cc4349ed
AS
407#ifdef GDBTK
408 /* --windows is equivalent to -i=insight. */
409 xfree (interpreter_p);
410 interpreter_p = xstrdup (INTERP_INSIGHT);
411#endif
42fa7c0f
AC
412 use_windows = 1;
413 break;
414 case OPT_NOWINDOWS:
415 /* -nw is equivalent to -i=console. */
416 xfree (interpreter_p);
417 interpreter_p = xstrdup (INTERP_CONSOLE);
418 use_windows = 0;
419 break;
c906108c
SS
420 case 'f':
421 annotation_level = 1;
422/* We have probably been invoked from emacs. Disable window interface. */
423 use_windows = 0;
424 break;
425 case 's':
426 symarg = optarg;
427 break;
428 case 'e':
429 execarg = optarg;
430 break;
431 case 'c':
432 corearg = optarg;
433 break;
00546b04
MS
434 case 'p':
435 /* "corearg" is shared by "--core" and "--pid" */
436 corearg = optarg;
437 break;
c906108c 438 case 'x':
8a5a3c82
AS
439 cmdarg[ncmd].type = CMDARG_FILE;
440 cmdarg[ncmd++].string = optarg;
441 if (ncmd >= cmdsize)
442 {
443 cmdsize *= 2;
444 cmdarg = xrealloc ((char *) cmdarg,
445 cmdsize * sizeof (*cmdarg));
446 }
447 break;
448 case 'X':
449 cmdarg[ncmd].type = CMDARG_COMMAND;
450 cmdarg[ncmd++].string = optarg;
c906108c
SS
451 if (ncmd >= cmdsize)
452 {
453 cmdsize *= 2;
8a5a3c82
AS
454 cmdarg = xrealloc ((char *) cmdarg,
455 cmdsize * sizeof (*cmdarg));
c906108c
SS
456 }
457 break;
1a088d06
AS
458 case 'B':
459 batch = batch_silent = 1;
460 gdb_stdout = ui_file_new();
461 break;
3fc11d3e
JM
462#ifdef GDBTK
463 case 'z':
464 {
a14ed312 465extern int gdbtk_test (char *);
3fc11d3e
JM
466 if (!gdbtk_test (optarg))
467 {
defc6f8c 468 fprintf_unfiltered (gdb_stderr, _("%s: unable to load tclcommand file \"%s\""),
3fc11d3e
JM
469 argv[0], optarg);
470 exit (1);
471 }
472 break;
473 }
474 case 'y':
78f49586
TT
475 /* Backwards compatibility only. */
476 break;
3fc11d3e
JM
477 case 'w':
478 {
3fc11d3e
JM
479 external_editor_command = xstrdup (optarg);
480 break;
481 }
482#endif /* GDBTK */
fb40c209 483 case 'i':
4389a95a
AC
484 xfree (interpreter_p);
485 interpreter_p = xstrdup (optarg);
fb40c209 486 break;
c906108c
SS
487 case 'd':
488 dirarg[ndir++] = optarg;
489 if (ndir >= dirsize)
490 {
491 dirsize *= 2;
c5aa993b 492 dirarg = (char **) xrealloc ((char *) dirarg,
c906108c
SS
493 dirsize * sizeof (*dirarg));
494 }
495 break;
496 case 't':
497 ttyarg = optarg;
498 break;
499 case 'q':
500 quiet = 1;
501 break;
502 case 'b':
503 {
504 int i;
505 char *p;
506
507 i = strtol (optarg, &p, 0);
508 if (i == 0 && p == optarg)
509
510 /* Don't use *_filtered or warning() (which relies on
c5aa993b 511 current_target) until after initialize_all_files(). */
c906108c
SS
512
513 fprintf_unfiltered
514 (gdb_stderr,
defc6f8c 515 _("warning: could not set baud rate to `%s'.\n"), optarg);
c906108c
SS
516 else
517 baud_rate = i;
518 }
046ca86a 519 break;
c906108c
SS
520 case 'l':
521 {
522 int i;
523 char *p;
524
525 i = strtol (optarg, &p, 0);
526 if (i == 0 && p == optarg)
527
528 /* Don't use *_filtered or warning() (which relies on
c5aa993b 529 current_target) until after initialize_all_files(). */
c906108c
SS
530
531 fprintf_unfiltered
532 (gdb_stderr,
defc6f8c 533 _("warning: could not set timeout limit to `%s'.\n"), optarg);
c906108c
SS
534 else
535 remote_timeout = i;
536 }
537 break;
538
c906108c
SS
539 case '?':
540 fprintf_unfiltered (gdb_stderr,
defc6f8c 541 _("Use `%s --help' for a complete list of options.\n"),
c5aa993b 542 argv[0]);
c906108c
SS
543 exit (1);
544 }
545 }
546
547 /* If --help or --version, disable window interface. */
548 if (print_help || print_version)
549 {
550 use_windows = 0;
c906108c
SS
551 }
552
552c04a7
TT
553 if (set_args)
554 {
555 /* The remaining options are the command-line options for the
556 inferior. The first one is the sym/exec file, and the rest
557 are arguments. */
558 if (optind >= argc)
559 {
560 fprintf_unfiltered (gdb_stderr,
defc6f8c 561 _("%s: `--args' specified but no program specified\n"),
552c04a7
TT
562 argv[0]);
563 exit (1);
564 }
565 symarg = argv[optind];
566 execarg = argv[optind];
567 ++optind;
568 set_inferior_args_vector (argc - optind, &argv[optind]);
569 }
570 else
571 {
572 /* OK, that's all the options. The other arguments are filenames. */
573 count = 0;
574 for (; optind < argc; optind++)
575 switch (++count)
576 {
577 case 1:
578 symarg = argv[optind];
579 execarg = argv[optind];
580 break;
581 case 2:
00546b04
MS
582 /* The documentation says this can be a "ProcID" as well.
583 We will try it as both a corefile and a pid. */
552c04a7
TT
584 corearg = argv[optind];
585 break;
586 case 3:
587 fprintf_unfiltered (gdb_stderr,
defc6f8c 588 _("Excess command line arguments ignored. (%s%s)\n"),
552c04a7
TT
589 argv[optind], (optind == argc - 1) ? "" : " ...");
590 break;
591 }
592 }
c906108c
SS
593 if (batch)
594 quiet = 1;
595 }
596
0f71a2f6 597 /* Initialize all files. Give the interpreter a chance to take
ba5e7e8d 598 control of the console via the deprecated_init_ui_hook (). */
c906108c
SS
599 gdb_init (argv[0]);
600
601 /* Do these (and anything which might call wrap_here or *_filtered)
4389a95a
AC
602 after initialize_all_files() but before the interpreter has been
603 installed. Otherwize the help/version messages will be eaten by
604 the interpreter's output handler. */
605
c906108c
SS
606 if (print_version)
607 {
608 print_gdb_version (gdb_stdout);
609 wrap_here ("");
610 printf_filtered ("\n");
611 exit (0);
612 }
613
614 if (print_help)
615 {
616 print_gdb_help (gdb_stdout);
617 fputs_unfiltered ("\n", gdb_stdout);
618 exit (0);
619 }
620
4389a95a
AC
621 /* FIXME: cagney/2003-02-03: The big hack (part 1 of 2) that lets
622 GDB retain the old MI1 interpreter startup behavior. Output the
623 copyright message before the interpreter is installed. That way
624 it isn't encapsulated in MI output. */
625 if (!quiet && strcmp (interpreter_p, INTERP_MI1) == 0)
626 {
627 /* Print all the junk at the top, with trailing "..." if we are about
628 to read a symbol file (possibly slowly). */
629 print_gdb_version (gdb_stdout);
630 if (symarg)
631 printf_filtered ("..");
632 wrap_here ("");
e896d70e 633 printf_filtered ("\n");
4389a95a
AC
634 gdb_flush (gdb_stdout); /* Force to screen during slow operations */
635 }
636
637
638 /* Install the default UI. All the interpreters should have had a
639 look at things by now. Initialize the default interpreter. */
640
641 {
642 /* Find it. */
643 struct interp *interp = interp_lookup (interpreter_p);
644 if (interp == NULL)
8a3fe4f8 645 error (_("Interpreter `%s' unrecognized"), interpreter_p);
4389a95a
AC
646 /* Install it. */
647 if (!interp_set (interp))
648 {
649 fprintf_unfiltered (gdb_stderr,
650 "Interpreter `%s' failed to initialize.\n",
651 interpreter_p);
652 exit (1);
653 }
654 }
655
656 /* FIXME: cagney/2003-02-03: The big hack (part 2 of 2) that lets
657 GDB retain the old MI1 interpreter startup behavior. Output the
658 copyright message after the interpreter is installed when it is
659 any sane interpreter. */
660 if (!quiet && !current_interp_named_p (INTERP_MI1))
c906108c
SS
661 {
662 /* Print all the junk at the top, with trailing "..." if we are about
c5aa993b 663 to read a symbol file (possibly slowly). */
c906108c
SS
664 print_gdb_version (gdb_stdout);
665 if (symarg)
666 printf_filtered ("..");
c5aa993b 667 wrap_here ("");
e896d70e 668 printf_filtered ("\n");
c5aa993b 669 gdb_flush (gdb_stdout); /* Force to screen during slow operations */
c906108c
SS
670 }
671
e896d70e
DJ
672 /* Set off error and warning messages with a blank line. */
673 error_pre_print = "\n";
c906108c 674 quit_pre_print = error_pre_print;
defc6f8c 675 warning_pre_print = _("\nwarning: ");
c906108c
SS
676
677 /* Read and execute $HOME/.gdbinit file, if it exists. This is done
678 *before* all the command line arguments are processed; it sets
679 global parameters, which are independent of what file you are
680 debugging or what directory you are in. */
c5aa993b 681 homedir = getenv ("HOME");
c906108c
SS
682 if (homedir)
683 {
7509373f 684 char *homeinit = xstrprintf ("%s/%s", homedir, gdbinit);
c906108c
SS
685
686 if (!inhibit_gdbinit)
687 {
16026cd7 688 catch_command_errors (source_script, homeinit, 0, RETURN_MASK_ALL);
c906108c 689 }
c906108c
SS
690
691 /* Do stats; no need to do them elsewhere since we'll only
c5aa993b
JM
692 need them if homedir is set. Make sure that they are
693 zero in case one of them fails (this guarantees that they
694 won't match if either exists). */
695
c906108c
SS
696 memset (&homebuf, 0, sizeof (struct stat));
697 memset (&cwdbuf, 0, sizeof (struct stat));
c5aa993b 698
c906108c 699 stat (homeinit, &homebuf);
c5aa993b
JM
700 stat (gdbinit, &cwdbuf); /* We'll only need this if
701 homedir was set. */
7509373f 702 xfree (homeinit);
c906108c
SS
703 }
704
705 /* Now perform all the actions indicated by the arguments. */
706 if (cdarg != NULL)
707 {
11cf8741 708 catch_command_errors (cd_command, cdarg, 0, RETURN_MASK_ALL);
c906108c 709 }
c906108c
SS
710
711 for (i = 0; i < ndir; i++)
13d35ae5 712 catch_command_errors (directory_switch, dirarg[i], 0, RETURN_MASK_ALL);
b8c9b27d 713 xfree (dirarg);
c906108c
SS
714
715 if (execarg != NULL
716 && symarg != NULL
5cb316ef 717 && strcmp (execarg, symarg) == 0)
c906108c 718 {
11cf8741
JM
719 /* The exec file and the symbol-file are the same. If we can't
720 open it, better only print one error message.
721 catch_command_errors returns non-zero on success! */
1adeb98a
FN
722 if (catch_command_errors (exec_file_attach, execarg, !batch, RETURN_MASK_ALL))
723 catch_command_errors (symbol_file_add_main, symarg, 0, RETURN_MASK_ALL);
c906108c
SS
724 }
725 else
726 {
727 if (execarg != NULL)
1adeb98a 728 catch_command_errors (exec_file_attach, execarg, !batch, RETURN_MASK_ALL);
c906108c 729 if (symarg != NULL)
1adeb98a 730 catch_command_errors (symbol_file_add_main, symarg, 0, RETURN_MASK_ALL);
c906108c 731 }
c906108c 732
c906108c
SS
733 if (corearg != NULL)
734 {
00546b04
MS
735 /* corearg may be either a corefile or a pid.
736 If its first character is a digit, try attach first
737 and then corefile. Otherwise try corefile first. */
738
739 if (isdigit (corearg[0]))
11cf8741 740 {
00546b04
MS
741 if (catch_command_errors (attach_command, corearg,
742 !batch, RETURN_MASK_ALL) == 0)
743 catch_command_errors (core_file_command, corearg,
744 !batch, RETURN_MASK_ALL);
11cf8741 745 }
00546b04
MS
746 else /* Can't be a pid, better be a corefile. */
747 catch_command_errors (core_file_command, corearg,
748 !batch, RETURN_MASK_ALL);
c906108c 749 }
c906108c
SS
750
751 if (ttyarg != NULL)
11cf8741 752 catch_command_errors (tty_command, ttyarg, !batch, RETURN_MASK_ALL);
c906108c 753
c906108c
SS
754 /* Error messages should no longer be distinguished with extra output. */
755 error_pre_print = NULL;
756 quit_pre_print = NULL;
defc6f8c 757 warning_pre_print = _("warning: ");
c906108c
SS
758
759 /* Read the .gdbinit file in the current directory, *if* it isn't
760 the same as the $HOME/.gdbinit file (it should exist, also). */
c5aa993b 761
c906108c
SS
762 if (!homedir
763 || memcmp ((char *) &homebuf, (char *) &cwdbuf, sizeof (struct stat)))
764 if (!inhibit_gdbinit)
765 {
16026cd7 766 catch_command_errors (source_script, gdbinit, 0, RETURN_MASK_ALL);
c906108c 767 }
c906108c
SS
768
769 for (i = 0; i < ncmd; i++)
770 {
11cf8741
JM
771#if 0
772 /* NOTE: cagney/1999-11-03: SET_TOP_LEVEL() was a macro that
773 expanded into a call to setjmp(). */
774 if (!SET_TOP_LEVEL ()) /* NB: This is #if 0'd out */
c906108c 775 {
b83266a0
SS
776 /* NOTE: I am commenting this out, because it is not clear
777 where this feature is used. It is very old and
c5aa993b 778 undocumented. ezannoni: 1999-05-04 */
b83266a0 779#if 0
c906108c
SS
780 if (cmdarg[i][0] == '-' && cmdarg[i][1] == '\0')
781 read_command_file (stdin);
782 else
b83266a0 783#endif
16026cd7 784 source_script (cmdarg[i], !batch);
c906108c
SS
785 do_cleanups (ALL_CLEANUPS);
786 }
11cf8741 787#endif
8a5a3c82 788 if (cmdarg[i].type == CMDARG_FILE)
16026cd7 789 catch_command_errors (source_script, cmdarg[i].string,
8a5a3c82
AS
790 !batch, RETURN_MASK_ALL);
791 else /* cmdarg[i].type == CMDARG_COMMAND */
792 catch_command_errors (execute_command, cmdarg[i].string,
793 !batch, RETURN_MASK_ALL);
c906108c 794 }
b8c9b27d 795 xfree (cmdarg);
c906108c
SS
796
797 /* Read in the old history after all the command files have been read. */
c5aa993b 798 init_history ();
c906108c
SS
799
800 if (batch)
801 {
802 /* We have hit the end of the batch file. */
4b0ad762 803 quit_force (NULL, 0);
c906108c
SS
804 }
805
806 /* Do any host- or target-specific hacks. This is used for i960 targets
807 to force the user to set a nindy target and spec its parameters. */
808
809#ifdef BEFORE_MAIN_LOOP_HOOK
810 BEFORE_MAIN_LOOP_HOOK;
811#endif
812
c906108c
SS
813 /* Show time and/or space usage. */
814
815 if (display_time)
816 {
817 long init_time = get_run_time () - time_at_startup;
818
defc6f8c 819 printf_unfiltered (_("Startup time: %ld.%06ld\n"),
c906108c
SS
820 init_time / 1000000, init_time % 1000000);
821 }
822
823 if (display_space)
824 {
825#ifdef HAVE_SBRK
826 extern char **environ;
827 char *lim = (char *) sbrk (0);
828
defc6f8c 829 printf_unfiltered (_("Startup size: data size %ld\n"),
c906108c
SS
830 (long) (lim - (char *) &environ));
831#endif
832 }
833
11cf8741
JM
834#if 0
835 /* FIXME: cagney/1999-11-06: The original main loop was like: */
c906108c
SS
836 while (1)
837 {
838 if (!SET_TOP_LEVEL ())
839 {
c5aa993b 840 do_cleanups (ALL_CLEANUPS); /* Do complete cleanup */
ba5e7e8d
MS
841 /* GUIs generally have their own command loop, mainloop, or
842 whatever. This is a good place to gain control because
843 many error conditions will end up here via longjmp(). */
9a4105ab
AC
844 if (deprecated_command_loop_hook)
845 deprecated_command_loop_hook ();
c906108c 846 else
9a4105ab 847 deprecated_command_loop ();
c5aa993b 848 quit_command ((char *) 0, instream == stdin);
c906108c
SS
849 }
850 }
11cf8741
JM
851 /* NOTE: If the command_loop() returned normally, the loop would
852 attempt to exit by calling the function quit_command(). That
853 function would either call exit() or throw an error returning
854 control to SET_TOP_LEVEL. */
855 /* NOTE: The function do_cleanups() was called once each time round
856 the loop. The usefulness of the call isn't clear. If an error
857 was thrown, everything would have already been cleaned up. If
858 command_loop() returned normally and quit_command() was called,
859 either exit() or error() (again cleaning up) would be called. */
860#endif
861 /* NOTE: cagney/1999-11-07: There is probably no reason for not
862 moving this loop and the code found in captured_command_loop()
863 into the command_loop() proper. The main thing holding back that
864 change - SET_TOP_LEVEL() - has been eliminated. */
865 while (1)
866 {
867 catch_errors (captured_command_loop, 0, "", RETURN_MASK_ALL);
868 }
11cf8741
JM
869 /* No exit -- exit is through quit_command. */
870}
c906108c 871
11cf8741 872int
f15ab4a7 873gdb_main (struct captured_main_args *args)
11cf8741 874{
f15ab4a7
AC
875 use_windows = args->use_windows;
876 catch_errors (captured_main, args, "", RETURN_MASK_ALL);
864dbc90
AC
877 /* The only way to end up here is by an error (normal exit is
878 handled by quit_force()), hence always return an error status. */
879 return 1;
c906108c
SS
880}
881
11cf8741 882
c906108c
SS
883/* Don't use *_filtered for printing help. We don't want to prompt
884 for continue no matter how small the screen or how much we're going
885 to print. */
886
887static void
d9fcf2fb 888print_gdb_help (struct ui_file *stream)
c906108c 889{
defc6f8c 890 fputs_unfiltered (_("\
c906108c 891This is the GNU debugger. Usage:\n\n\
552c04a7
TT
892 gdb [options] [executable-file [core-file or process-id]]\n\
893 gdb [options] --args executable-file [inferior-arguments ...]\n\n\
c906108c 894Options:\n\n\
defc6f8c
TT
895"), stream);
896 fputs_unfiltered (_("\
552c04a7 897 --args Arguments after executable-file are passed to inferior\n\
defc6f8c
TT
898"), stream);
899 fputs_unfiltered (_("\
c906108c
SS
900 -b BAUDRATE Set serial port baud rate used for remote debugging.\n\
901 --batch Exit after processing options.\n\
1a088d06 902 --batch-silent As for --batch, but suppress all gdb stdout output.\n\
4b0ad762
AS
903 --return-child-result\n\
904 GDB exit code will be the child's exit code.\n\
c906108c 905 --cd=DIR Change current directory to DIR.\n\
8a5a3c82
AS
906 --command=FILE, -x Execute GDB commands from FILE.\n\
907 --eval-command=COMMAND, -ex\n\
908 Execute a single GDB command.\n\
909 May be used multiple times and in conjunction\n\
910 with --command.\n\
c906108c 911 --core=COREFILE Analyze the core dump COREFILE.\n\
00546b04 912 --pid=PID Attach to running process PID.\n\
defc6f8c
TT
913"), stream);
914 fputs_unfiltered (_("\
c906108c
SS
915 --dbx DBX compatibility mode.\n\
916 --directory=DIR Search for source files in DIR.\n\
917 --epoch Output information used by epoch emacs-GDB interface.\n\
918 --exec=EXECFILE Use EXECFILE as the executable.\n\
919 --fullname Output information used by emacs-GDB interface.\n\
920 --help Print this message.\n\
defc6f8c
TT
921"), stream);
922 fputs_unfiltered (_("\
8b93c638
JM
923 --interpreter=INTERP\n\
924 Select a specific interpreter / user interface\n\
defc6f8c
TT
925"), stream);
926 fputs_unfiltered (_("\
f47b1503 927 -l TIMEOUT Set timeout in seconds for remote debugging.\n\
c906108c 928 --nw Do not use a window interface.\n\
defc6f8c 929 --nx Do not read "), stream);
96baa820 930 fputs_unfiltered (gdbinit, stream);
defc6f8c 931 fputs_unfiltered (_(" file.\n\
c906108c
SS
932 --quiet Do not print version number on startup.\n\
933 --readnow Fully read symbol files on first access.\n\
defc6f8c
TT
934"), stream);
935 fputs_unfiltered (_("\
c906108c
SS
936 --se=FILE Use FILE as symbol file and executable file.\n\
937 --symbols=SYMFILE Read symbols from SYMFILE.\n\
938 --tty=TTY Use TTY for input/output by the program being debugged.\n\
defc6f8c 939"), stream);
c906108c 940#if defined(TUI)
defc6f8c 941 fputs_unfiltered (_("\
c906108c 942 --tui Use a terminal user interface.\n\
defc6f8c 943"), stream);
c906108c 944#endif
defc6f8c 945 fputs_unfiltered (_("\
c906108c
SS
946 --version Print version information and then exit.\n\
947 -w Use a window interface.\n\
948 --write Set writing into executable and core files.\n\
949 --xdb XDB compatibility mode.\n\
defc6f8c 950"), stream);
defc6f8c 951 fputs_unfiltered (_("\n\
c906108c
SS
952For more information, type \"help\" from within GDB, or consult the\n\
953GDB manual (available as on-line info or a printed manual).\n\
2df3850c 954Report bugs to \"bug-gdb@gnu.org\".\
defc6f8c 955"), stream);
c906108c 956}
This page took 0.594016 seconds and 4 git commands to generate.