PR binutils/14444
[deliverable/binutils-gdb.git] / gdb / defs.h
1 /* *INDENT-OFF* */ /* ATTRIBUTE_PRINTF confuses indent, avoid running it
2 for now. */
3 /* Basic, host-specific, and target-specific definitions for GDB.
4 Copyright (C) 1986, 1988-2005, 2007-2012 Free Software Foundation,
5 Inc.
6
7 This file is part of GDB.
8
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 3 of the License, or
12 (at your option) any later version.
13
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.
18
19 You should have received a copy of the GNU General Public License
20 along with this program. If not, see <http://www.gnu.org/licenses/>. */
21
22 #ifndef DEFS_H
23 #define DEFS_H
24
25 #ifdef GDBSERVER
26 # error gdbserver should not include gdb/defs.h
27 #endif
28
29 #include "config.h" /* Generated by configure. */
30
31 #include <sys/types.h>
32 #include <stdio.h>
33 #include <errno.h> /* System call error return status. */
34 #include <limits.h>
35 #include <stdint.h>
36
37 /* The libdecnumber library, on which GDB depends, includes a header file
38 called gstdint.h instead of relying directly on stdint.h. GDB, on the
39 other hand, includes stdint.h directly, relying on the fact that gnulib
40 generates a copy if the system doesn't provide one or if it is missing
41 some features. Unfortunately, gstdint.h and stdint.h cannot be included
42 at the same time, which may happen when we include a file from
43 libdecnumber.
44
45 The following macro definition effectively prevents the inclusion of
46 gstdint.h, as all the definitions it provides are guarded against
47 the GCC_GENERATED_STDINT_H macro. We already have gnulib/stdint.h
48 included, so it's ok to blank out gstdint.h. */
49 #define GCC_GENERATED_STDINT_H 1
50
51 #ifdef HAVE_STDDEF_H
52 #include <stddef.h>
53 #endif
54
55 #ifdef HAVE_UNISTD_H
56 #include <unistd.h>
57 #endif
58
59 #include <fcntl.h>
60
61 /* First include ansidecl.h so we can use the various macro definitions
62 here and in all subsequent file inclusions. */
63
64 #include "ansidecl.h"
65
66 #include "gdb_locale.h"
67
68 #include "gdb_wchar.h"
69
70 /* For ``enum gdb_signal''. */
71 #include "gdb/signals.h"
72
73 #include "ui-file.h"
74
75 #include "host-defs.h"
76
77 /* Just in case they're not defined in stdio.h. */
78
79 #ifndef SEEK_SET
80 #define SEEK_SET 0
81 #endif
82 #ifndef SEEK_CUR
83 #define SEEK_CUR 1
84 #endif
85
86 /* The O_BINARY flag is defined in fcntl.h on some non-Posix platforms.
87 It is used as an access modifier in calls to open(), where it acts
88 similarly to the "b" character in fopen()'s MODE argument. On Posix
89 platforms it should be a no-op, so it is defined as 0 here. This
90 ensures that the symbol may be used freely elsewhere in gdb. */
91
92 #ifndef O_BINARY
93 #define O_BINARY 0
94 #endif
95
96 #include <stdarg.h> /* For va_list. */
97
98 #include "libiberty.h"
99 #include "hashtab.h"
100
101 /* Rather than duplicate all the logic in BFD for figuring out what
102 types to use (which can be pretty complicated), symply define them
103 in terms of the corresponding type from BFD. */
104
105 #include "bfd.h"
106
107 /* A byte from the program being debugged. */
108 typedef bfd_byte gdb_byte;
109
110 /* An address in the program being debugged. Host byte order. */
111 typedef bfd_vma CORE_ADDR;
112
113 /* The largest CORE_ADDR value. */
114 #define CORE_ADDR_MAX (~ (CORE_ADDR) 0)
115
116 /* This is to make sure that LONGEST is at least as big as CORE_ADDR. */
117
118 #ifndef LONGEST
119
120 #ifdef BFD64
121
122 #define LONGEST BFD_HOST_64_BIT
123 #define ULONGEST BFD_HOST_U_64_BIT
124
125 #else /* No BFD64 */
126
127 #ifdef CC_HAS_LONG_LONG
128 #define LONGEST long long
129 #define ULONGEST unsigned long long
130 #else
131 #ifdef BFD_HOST_64_BIT
132 /* BFD_HOST_64_BIT is defined for some hosts that don't have long long
133 (e.g. i386-windows) so try it. */
134 #define LONGEST BFD_HOST_64_BIT
135 #define ULONGEST BFD_HOST_U_64_BIT
136 #else
137 #define LONGEST long
138 #define ULONGEST unsigned long
139 #endif
140 #endif
141
142 #endif /* No BFD64 */
143
144 #endif /* ! LONGEST */
145
146 #ifndef min
147 #define min(a, b) ((a) < (b) ? (a) : (b))
148 #endif
149 #ifndef max
150 #define max(a, b) ((a) > (b) ? (a) : (b))
151 #endif
152
153 #include "ptid.h"
154
155 /* Enable xdb commands if set. */
156 extern int xdb_commands;
157
158 /* Enable dbx commands if set. */
159 extern int dbx_commands;
160
161 /* System root path, used to find libraries etc. */
162 extern char *gdb_sysroot;
163
164 /* GDB datadir, used to store data files. */
165 extern char *gdb_datadir;
166
167 /* If non-NULL, the possibly relocated path to python's "lib" directory
168 specified with --with-python. */
169 extern char *python_libdir;
170
171 /* Search path for separate debug files. */
172 extern char *debug_file_directory;
173
174 extern int quit_flag;
175 extern int immediate_quit;
176
177 extern void quit (void);
178
179 /* FIXME: cagney/2000-03-13: It has been suggested that the peformance
180 benefits of having a ``QUIT'' macro rather than a function are
181 marginal. If the overhead of a QUIT function call is proving
182 significant then its calling frequency should probably be reduced
183 [kingdon]. A profile analyzing the current situtation is
184 needed. */
185
186 #define QUIT { \
187 if (quit_flag) quit (); \
188 if (deprecated_interactive_hook) deprecated_interactive_hook (); \
189 }
190
191 /* Languages represented in the symbol table and elsewhere.
192 This should probably be in language.h, but since enum's can't
193 be forward declared to satisfy opaque references before their
194 actual definition, needs to be here. */
195
196 enum language
197 {
198 language_unknown, /* Language not known */
199 language_auto, /* Placeholder for automatic setting */
200 language_c, /* C */
201 language_cplus, /* C++ */
202 language_d, /* D */
203 language_go, /* Go */
204 language_objc, /* Objective-C */
205 language_java, /* Java */
206 language_fortran, /* Fortran */
207 language_m2, /* Modula-2 */
208 language_asm, /* Assembly language */
209 language_pascal, /* Pascal */
210 language_ada, /* Ada */
211 language_opencl, /* OpenCL */
212 language_minimal, /* All other languages, minimal support only */
213 nr_languages
214 };
215
216 enum precision_type
217 {
218 single_precision,
219 double_precision,
220 unspecified_precision
221 };
222
223 /* A generic, not quite boolean, enumeration. */
224 enum auto_boolean
225 {
226 AUTO_BOOLEAN_TRUE,
227 AUTO_BOOLEAN_FALSE,
228 AUTO_BOOLEAN_AUTO
229 };
230
231 /* Potential ways that a function can return a value of a given type. */
232 enum return_value_convention
233 {
234 /* Where the return value has been squeezed into one or more
235 registers. */
236 RETURN_VALUE_REGISTER_CONVENTION,
237 /* Commonly known as the "struct return convention". The caller
238 passes an additional hidden first parameter to the caller. That
239 parameter contains the address at which the value being returned
240 should be stored. While typically, and historically, used for
241 large structs, this is convention is applied to values of many
242 different types. */
243 RETURN_VALUE_STRUCT_CONVENTION,
244 /* Like the "struct return convention" above, but where the ABI
245 guarantees that the called function stores the address at which
246 the value being returned is stored in a well-defined location,
247 such as a register or memory slot in the stack frame. Don't use
248 this if the ABI doesn't explicitly guarantees this. */
249 RETURN_VALUE_ABI_RETURNS_ADDRESS,
250 /* Like the "struct return convention" above, but where the ABI
251 guarantees that the address at which the value being returned is
252 stored will be available in a well-defined location, such as a
253 register or memory slot in the stack frame. Don't use this if
254 the ABI doesn't explicitly guarantees this. */
255 RETURN_VALUE_ABI_PRESERVES_ADDRESS,
256 };
257
258 /* Needed for various prototypes */
259
260 struct symtab;
261 struct breakpoint;
262 struct frame_info;
263 struct gdbarch;
264 struct value;
265
266 /* From main.c. */
267
268 /* This really belong in utils.c (path-utils.c?), but it references some
269 globals that are currently only available to main.c. */
270 extern char *relocate_gdb_directory (const char *initial, int flag);
271
272 \f
273 /* Annotation stuff. */
274
275 extern int annotation_level; /* in stack.c */
276 \f
277
278 /* From regex.c or libc. BSD 4.4 declares this with the argument type as
279 "const char *" in unistd.h, so we can't declare the argument
280 as "char *". */
281
282 extern char *re_comp (const char *);
283
284 /* From symfile.c */
285
286 extern void symbol_file_command (char *, int);
287
288 /* Remote targets may wish to use this as their load function. */
289 extern void generic_load (char *name, int from_tty);
290
291 /* Report on STREAM the performance of memory transfer operation,
292 such as 'load'.
293 DATA_COUNT is the number of bytes transferred.
294 WRITE_COUNT is the number of separate write operations, or 0,
295 if that information is not available.
296 START_TIME is the time at which an operation was started.
297 END_TIME is the time at which an operation ended. */
298 struct timeval;
299 extern void print_transfer_performance (struct ui_file *stream,
300 unsigned long data_count,
301 unsigned long write_count,
302 const struct timeval *start_time,
303 const struct timeval *end_time);
304
305 /* From top.c */
306
307 typedef void initialize_file_ftype (void);
308
309 extern char *skip_quoted (char *);
310
311 extern char *gdb_readline (char *);
312
313 extern char *gdb_readline_wrapper (char *);
314
315 extern char *command_line_input (char *, int, char *);
316
317 extern void print_prompt (void);
318
319 extern int input_from_terminal_p (void);
320
321 extern int info_verbose;
322
323 /* From printcmd.c */
324
325 extern void set_next_address (struct gdbarch *, CORE_ADDR);
326
327 extern int print_address_symbolic (struct gdbarch *, CORE_ADDR,
328 struct ui_file *, int, char *);
329
330 extern int build_address_symbolic (struct gdbarch *,
331 CORE_ADDR addr,
332 int do_demangle,
333 char **name,
334 int *offset,
335 char **filename,
336 int *line,
337 int *unmapped);
338
339 extern void print_address (struct gdbarch *, CORE_ADDR, struct ui_file *);
340 extern const char *pc_prefix (CORE_ADDR);
341
342 /* From source.c */
343
344 #define OPF_TRY_CWD_FIRST 0x01
345 #define OPF_SEARCH_IN_PATH 0x02
346
347 extern int openp (const char *, int, const char *, int, char **);
348
349 extern int source_full_path_of (const char *, char **);
350
351 extern void mod_path (char *, char **);
352
353 extern void add_path (char *, char **, int);
354
355 extern void directory_command (char *, int);
356
357 extern void directory_switch (char *, int);
358
359 extern char *source_path;
360
361 extern void init_source_path (void);
362
363 /* From exec.c */
364
365 /* Process memory area starting at ADDR with length SIZE. Area is readable iff
366 READ is non-zero, writable if WRITE is non-zero, executable if EXEC is
367 non-zero. Area is possibly changed against its original file based copy if
368 MODIFIED is non-zero. DATA is passed without changes from a caller. */
369
370 typedef int (*find_memory_region_ftype) (CORE_ADDR addr, unsigned long size,
371 int read, int write, int exec,
372 int modified, void *data);
373
374 /* Take over the 'find_mapped_memory' vector from exec.c. */
375 extern void exec_set_find_memory_regions
376 (int (*func) (find_memory_region_ftype func, void *data));
377
378 /* Possible lvalue types. Like enum language, this should be in
379 value.h, but needs to be here for the same reason. */
380
381 enum lval_type
382 {
383 /* Not an lval. */
384 not_lval,
385 /* In memory. */
386 lval_memory,
387 /* In a register. Registers are relative to a frame. */
388 lval_register,
389 /* In a gdb internal variable. */
390 lval_internalvar,
391 /* Part of a gdb internal variable (structure field). */
392 lval_internalvar_component,
393 /* Value's bits are fetched and stored using functions provided by
394 its creator. */
395 lval_computed
396 };
397
398 /* Control types for commands */
399
400 enum misc_command_type
401 {
402 ok_command,
403 end_command,
404 else_command,
405 nop_command
406 };
407
408 enum command_control_type
409 {
410 simple_control,
411 break_control,
412 continue_control,
413 while_control,
414 if_control,
415 commands_control,
416 python_control,
417 while_stepping_control,
418 invalid_control
419 };
420
421 /* Structure for saved commands lines
422 (for breakpoints, defined commands, etc). */
423
424 struct command_line
425 {
426 struct command_line *next;
427 char *line;
428 enum command_control_type control_type;
429 /* The number of elements in body_list. */
430 int body_count;
431 /* For composite commands, the nested lists of commands. For
432 example, for "if" command this will contain the then branch and
433 the else branch, if that is available. */
434 struct command_line **body_list;
435 };
436
437 extern struct command_line *read_command_lines (char *, int, int,
438 void (*)(char *, void *),
439 void *);
440 extern struct command_line *read_command_lines_1 (char * (*) (void), int,
441 void (*)(char *, void *),
442 void *);
443
444 extern void free_command_lines (struct command_line **);
445
446 /* Parameters of the "info proc" command. */
447
448 enum info_proc_what
449 {
450 /* Display the default cmdline, cwd and exe outputs. */
451 IP_MINIMAL,
452
453 /* Display `info proc mappings'. */
454 IP_MAPPINGS,
455
456 /* Display `info proc status'. */
457 IP_STATUS,
458
459 /* Display `info proc stat'. */
460 IP_STAT,
461
462 /* Display `info proc cmdline'. */
463 IP_CMDLINE,
464
465 /* Display `info proc exe'. */
466 IP_EXE,
467
468 /* Display `info proc cwd'. */
469 IP_CWD,
470
471 /* Display all of the above. */
472 IP_ALL
473 };
474
475 /* String containing the current directory (what getwd would return). */
476
477 extern char *current_directory;
478
479 /* Default radixes for input and output. Only some values supported. */
480 extern unsigned input_radix;
481 extern unsigned output_radix;
482
483 /* Possibilities for prettyprint parameters to routines which print
484 things. Like enum language, this should be in value.h, but needs
485 to be here for the same reason. FIXME: If we can eliminate this
486 as an arg to LA_VAL_PRINT, then we can probably move it back to
487 value.h. */
488
489 enum val_prettyprint
490 {
491 Val_no_prettyprint = 0,
492 Val_prettyprint,
493 /* Use the default setting which the user has specified. */
494 Val_pretty_default
495 };
496
497 /* Optional native machine support. Non-native (and possibly pure
498 multi-arch) targets do not need a "nm.h" file. This will be a
499 symlink to one of the nm-*.h files, built by the `configure'
500 script. */
501
502 #ifdef GDB_NM_FILE
503 #include "nm.h"
504 #endif
505
506 /* Assume that fopen accepts the letter "b" in the mode string.
507 It is demanded by ISO C9X, and should be supported on all
508 platforms that claim to have a standard-conforming C library. On
509 true POSIX systems it will be ignored and have no effect. There
510 may still be systems without a standard-conforming C library where
511 an ISO C9X compiler (GCC) is available. Known examples are SunOS
512 4.x and 4.3BSD. This assumption means these systems are no longer
513 supported. */
514 #ifndef FOPEN_RB
515 # include "fopen-bin.h"
516 #endif
517
518 /* Defaults for system-wide constants (if not defined by xm.h, we fake it).
519 FIXME: Assumes 2's complement arithmetic. */
520
521 #if !defined (UINT_MAX)
522 #define UINT_MAX ((unsigned int)(~0)) /* 0xFFFFFFFF for 32-bits */
523 #endif
524
525 #if !defined (INT_MAX)
526 #define INT_MAX ((int)(UINT_MAX >> 1)) /* 0x7FFFFFFF for 32-bits */
527 #endif
528
529 #if !defined (INT_MIN)
530 #define INT_MIN ((int)((int) ~0 ^ INT_MAX)) /* 0x80000000 for 32-bits */
531 #endif
532
533 #if !defined (ULONG_MAX)
534 #define ULONG_MAX ((unsigned long)(~0L)) /* 0xFFFFFFFF for 32-bits */
535 #endif
536
537 #if !defined (LONG_MAX)
538 #define LONG_MAX ((long)(ULONG_MAX >> 1)) /* 0x7FFFFFFF for 32-bits */
539 #endif
540
541 #if !defined (ULONGEST_MAX)
542 #define ULONGEST_MAX (~(ULONGEST)0) /* 0xFFFFFFFFFFFFFFFF for 64-bits */
543 #endif
544
545 #if !defined (LONGEST_MAX) /* 0x7FFFFFFFFFFFFFFF for 64-bits */
546 #define LONGEST_MAX ((LONGEST)(ULONGEST_MAX >> 1))
547 #endif
548
549 /* Convert a LONGEST to an int. This is used in contexts (e.g. number of
550 arguments to a function, number in a value history, register number, etc.)
551 where the value must not be larger than can fit in an int. */
552
553 extern int longest_to_int (LONGEST);
554
555 /* Utility macros to allocate typed memory. Avoids errors like:
556 struct foo *foo = xmalloc (sizeof struct bar); and memset (foo,
557 sizeof (struct foo), 0). */
558 #define XZALLOC(TYPE) ((TYPE*) xzalloc (sizeof (TYPE)))
559 #define XMALLOC(TYPE) ((TYPE*) xmalloc (sizeof (TYPE)))
560 #define XCALLOC(NMEMB, TYPE) ((TYPE*) xcalloc ((NMEMB), sizeof (TYPE)))
561
562 #include "common-utils.h"
563
564 /* List of known OS ABIs. If you change this, make sure to update the
565 table in osabi.c. */
566 enum gdb_osabi
567 {
568 GDB_OSABI_UNINITIALIZED = -1, /* For struct gdbarch_info. */
569
570 GDB_OSABI_UNKNOWN = 0, /* keep this zero */
571
572 GDB_OSABI_SVR4,
573 GDB_OSABI_HURD,
574 GDB_OSABI_SOLARIS,
575 GDB_OSABI_OSF1,
576 GDB_OSABI_LINUX,
577 GDB_OSABI_FREEBSD_AOUT,
578 GDB_OSABI_FREEBSD_ELF,
579 GDB_OSABI_NETBSD_AOUT,
580 GDB_OSABI_NETBSD_ELF,
581 GDB_OSABI_OPENBSD_ELF,
582 GDB_OSABI_WINCE,
583 GDB_OSABI_GO32,
584 GDB_OSABI_IRIX,
585 GDB_OSABI_INTERIX,
586 GDB_OSABI_HPUX_ELF,
587 GDB_OSABI_HPUX_SOM,
588 GDB_OSABI_QNXNTO,
589 GDB_OSABI_CYGWIN,
590 GDB_OSABI_AIX,
591 GDB_OSABI_DICOS,
592 GDB_OSABI_DARWIN,
593 GDB_OSABI_SYMBIAN,
594 GDB_OSABI_OPENVMS,
595
596 GDB_OSABI_INVALID /* keep this last */
597 };
598
599 /* Global functions from other, non-gdb GNU thingies.
600 Libiberty thingies are no longer declared here. We include libiberty.h
601 above, instead. */
602
603 /* From other system libraries */
604
605 #ifdef HAVE_STDDEF_H
606 #include <stddef.h>
607 #endif
608
609 #ifdef HAVE_STDLIB_H
610 #include <stdlib.h>
611 #endif
612 #ifndef min
613 #define min(a, b) ((a) < (b) ? (a) : (b))
614 #endif
615 #ifndef max
616 #define max(a, b) ((a) > (b) ? (a) : (b))
617 #endif
618
619
620 #ifndef atof
621 extern double atof (const char *); /* X3.159-1989 4.10.1.1 */
622 #endif
623
624 /* Various possibilities for alloca. */
625 #ifndef alloca
626 #ifdef __GNUC__
627 #define alloca __builtin_alloca
628 #else /* Not GNU C */
629 #ifdef HAVE_ALLOCA_H
630 #include <alloca.h>
631 #else
632 #ifdef _AIX
633 #pragma alloca
634 #else
635
636 /* We need to be careful not to declare this in a way which conflicts with
637 bison. Bison never declares it as char *, but under various circumstances
638 (like __hpux) we need to use void *. */
639 extern void *alloca ();
640 #endif /* Not _AIX */
641 #endif /* Not HAVE_ALLOCA_H */
642 #endif /* Not GNU C */
643 #endif /* alloca not defined */
644
645 /* Dynamic target-system-dependent parameters for GDB. */
646 #include "gdbarch.h"
647
648 /* Maximum size of a register. Something small, but large enough for
649 all known ISAs. If it turns out to be too small, make it bigger. */
650
651 enum { MAX_REGISTER_SIZE = 64 };
652
653 /* Static target-system-dependent parameters for GDB. */
654
655 /* Number of bits in a char or unsigned char for the target machine.
656 Just like CHAR_BIT in <limits.h> but describes the target machine. */
657 #if !defined (TARGET_CHAR_BIT)
658 #define TARGET_CHAR_BIT 8
659 #endif
660
661 /* If we picked up a copy of CHAR_BIT from a configuration file
662 (which may get it by including <limits.h>) then use it to set
663 the number of bits in a host char. If not, use the same size
664 as the target. */
665
666 #if defined (CHAR_BIT)
667 #define HOST_CHAR_BIT CHAR_BIT
668 #else
669 #define HOST_CHAR_BIT TARGET_CHAR_BIT
670 #endif
671
672 /* In findvar.c. */
673
674 extern LONGEST extract_signed_integer (const gdb_byte *, int,
675 enum bfd_endian);
676
677 extern ULONGEST extract_unsigned_integer (const gdb_byte *, int,
678 enum bfd_endian);
679
680 extern int extract_long_unsigned_integer (const gdb_byte *, int,
681 enum bfd_endian, LONGEST *);
682
683 extern CORE_ADDR extract_typed_address (const gdb_byte *buf,
684 struct type *type);
685
686 extern void store_signed_integer (gdb_byte *, int,
687 enum bfd_endian, LONGEST);
688
689 extern void store_unsigned_integer (gdb_byte *, int,
690 enum bfd_endian, ULONGEST);
691
692 extern void store_typed_address (gdb_byte *buf, struct type *type,
693 CORE_ADDR addr);
694
695 \f
696 /* From valops.c */
697
698 extern int watchdog;
699
700 /* Hooks for alternate command interfaces. */
701
702 /* The name of the interpreter if specified on the command line. */
703 extern char *interpreter_p;
704
705 /* If a given interpreter matches INTERPRETER_P then it should update
706 deprecated_command_loop_hook and deprecated_init_ui_hook with the
707 per-interpreter implementation. */
708 /* FIXME: deprecated_command_loop_hook and deprecated_init_ui_hook
709 should be moved here. */
710
711 struct target_waitstatus;
712 struct cmd_list_element;
713
714 extern void (*deprecated_pre_add_symbol_hook) (const char *);
715 extern void (*deprecated_post_add_symbol_hook) (void);
716 extern void (*selected_frame_level_changed_hook) (int);
717 extern int (*deprecated_ui_loop_hook) (int signo);
718 extern void (*deprecated_init_ui_hook) (char *argv0);
719 extern void (*deprecated_command_loop_hook) (void);
720 extern void (*deprecated_show_load_progress) (const char *section,
721 unsigned long section_sent,
722 unsigned long section_size,
723 unsigned long total_sent,
724 unsigned long total_size);
725 extern void (*deprecated_print_frame_info_listing_hook) (struct symtab * s,
726 int line,
727 int stopline,
728 int noerror);
729 extern int (*deprecated_query_hook) (const char *, va_list)
730 ATTRIBUTE_FPTR_PRINTF(1,0);
731 extern void (*deprecated_warning_hook) (const char *, va_list)
732 ATTRIBUTE_FPTR_PRINTF(1,0);
733 extern void (*deprecated_flush_hook) (struct ui_file * stream);
734 extern void (*deprecated_interactive_hook) (void);
735 extern void (*deprecated_readline_begin_hook) (char *, ...)
736 ATTRIBUTE_FPTR_PRINTF_1;
737 extern char *(*deprecated_readline_hook) (char *);
738 extern void (*deprecated_readline_end_hook) (void);
739 extern void (*deprecated_register_changed_hook) (int regno);
740 extern void (*deprecated_context_hook) (int);
741 extern ptid_t (*deprecated_target_wait_hook) (ptid_t ptid,
742 struct target_waitstatus *status,
743 int options);
744
745 extern void (*deprecated_attach_hook) (void);
746 extern void (*deprecated_detach_hook) (void);
747 extern void (*deprecated_call_command_hook) (struct cmd_list_element * c,
748 char *cmd, int from_tty);
749
750 extern void (*deprecated_set_hook) (struct cmd_list_element * c);
751
752 extern int (*deprecated_ui_load_progress_hook) (const char *section,
753 unsigned long num);
754
755 /* Inhibit window interface if non-zero. */
756
757 extern int use_windows;
758
759 /* Provide default definitions of PIDGET, TIDGET, and MERGEPID.
760 The name ``TIDGET'' is a historical accident. Many uses of TIDGET
761 in the code actually refer to a lightweight process id, i.e,
762 something that can be considered a process id in its own right for
763 certain purposes. */
764
765 #ifndef PIDGET
766 #define PIDGET(PTID) (ptid_get_pid (PTID))
767 #define TIDGET(PTID) (ptid_get_lwp (PTID))
768 #define MERGEPID(PID, TID) ptid_build (PID, TID, 0)
769 #endif
770
771 /* Define well known filenos if the system does not define them. */
772 #ifndef STDIN_FILENO
773 #define STDIN_FILENO 0
774 #endif
775 #ifndef STDOUT_FILENO
776 #define STDOUT_FILENO 1
777 #endif
778 #ifndef STDERR_FILENO
779 #define STDERR_FILENO 2
780 #endif
781
782 /* If this definition isn't overridden by the header files, assume
783 that isatty and fileno exist on this system. */
784 #ifndef ISATTY
785 #define ISATTY(FP) (isatty (fileno (FP)))
786 #endif
787
788 /* A width that can achieve a better legibility for GDB MI mode. */
789 #define GDB_MI_MSG_WIDTH 80
790
791 /* From progspace.c */
792
793 extern void initialize_progspace (void);
794 extern void initialize_inferiors (void);
795
796 /* Special block numbers */
797
798 enum block_enum
799 {
800 GLOBAL_BLOCK = 0,
801 STATIC_BLOCK = 1,
802 FIRST_LOCAL_BLOCK = 2
803 };
804
805 #include "utils.h"
806
807 #endif /* #ifndef DEFS_H */
This page took 0.055271 seconds and 4 git commands to generate.