projects
/
deliverable
/
binutils-gdb.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
include/opcode/
[deliverable/binutils-gdb.git]
/
gdb
/
buildsym.h
diff --git
a/gdb/buildsym.h
b/gdb/buildsym.h
index f559b4b04b5284a535194010b8c882c77372671f..4bde17a44c70e73658907a4294177947503f6f3c 100644
(file)
--- a/
gdb/buildsym.h
+++ b/
gdb/buildsym.h
@@
-1,7
+1,5
@@
/* Build symbol tables in GDB's internal format.
/* Build symbol tables in GDB's internal format.
- Copyright (C) 1986, 1987, 1988, 1989, 1990, 1991, 1992, 1993, 1995, 1996,
- 1997, 1998, 1999, 2000, 2002, 2003, 2007, 2008, 2009, 2010
- Free Software Foundation, Inc.
+ Copyright (C) 1986-2013 Free Software Foundation, Inc.
This file is part of GDB.
This file is part of GDB.
@@
-38,19
+36,14
@@
struct addrmap;
this technique. */
struct block;
this technique. */
struct block;
+struct pending_block;
#ifndef EXTERN
#define EXTERN extern
#endif
#define HASHSIZE 127 /* Size of things hashed via
#ifndef EXTERN
#define EXTERN extern
#endif
#define HASHSIZE 127 /* Size of things hashed via
- hashname() */
-
-/* Name of source file whose symbol data we are now processing. This
- comes from a symbol of type N_SO for stabs. For Dwarf it comes from the
- DW_AT_name attribute of a DW_TAG_compile_unit DIE. */
-
-EXTERN char *last_source_file;
+ hashname(). */
/* Core address of start of text of current source file. This too
comes from the N_SO symbol. For Dwarf it typically comes from the
/* Core address of start of text of current source file. This too
comes from the N_SO symbol. For Dwarf it typically comes from the
@@
-70,8
+63,8
@@
struct subfile
struct linetable *line_vector;
int line_vector_length;
enum language language;
struct linetable *line_vector;
int line_vector_length;
enum language language;
- char *producer;
- char *debugformat;
+ c
onst c
har *producer;
+ c
onst c
har *debugformat;
struct symtab *symtab;
};
struct symtab *symtab;
};
@@
-121,10
+114,6
@@
EXTERN struct pending *global_symbols;
EXTERN struct pending *local_symbols;
EXTERN struct pending *local_symbols;
-/* func params local to lexical context */
-
-EXTERN struct pending *param_symbols;
-
/* "using" directives local to lexical context. */
EXTERN struct using_direct *using_directives;
/* "using" directives local to lexical context. */
EXTERN struct using_direct *using_directives;
@@
-138,10
+127,6
@@
struct context_stack
struct pending *locals;
struct pending *locals;
- /* Pending func params at the time we entered */
-
- struct pending *params;
-
/* Pending using directives at the time we entered. */
struct using_direct *using_directives;
/* Pending using directives at the time we entered. */
struct using_direct *using_directives;
@@
-158,7
+143,7
@@
struct context_stack
CORE_ADDR start_addr;
CORE_ADDR start_addr;
- /* Temp slot for exception handling. */
+ /* Temp slot for exception handling.
*/
CORE_ADDR end_addr;
CORE_ADDR end_addr;
@@
-186,21
+171,6
@@
EXTERN int context_stack_size;
EXTERN int within_function;
EXTERN int within_function;
-/* List of blocks already made (lexical contexts already closed).
- This is used at the end to make the blockvector. */
-
-struct pending_block
- {
- struct pending_block *next;
- struct block *block;
- };
-
-/* Pointer to the head of a linked list of symbol blocks which have
- already been finalized (lexical contexts already closed) and which
- are just waiting to be built into a blockvector when finalizing the
- associated symtab. */
-
-EXTERN struct pending_block *pending_blocks;
\f
struct subfile_stack
\f
struct subfile_stack
@@
-213,7
+183,7
@@
EXTERN struct subfile_stack *subfile_stack;
#define next_symbol_text(objfile) (*next_symbol_text_func)(objfile)
#define next_symbol_text(objfile) (*next_symbol_text_func)(objfile)
-/* Function to invoke get the next symbol. Return the symbol name. */
+/* Function to invoke get the next symbol. Return the symbol name.
*/
EXTERN char *(*next_symbol_text_func) (struct objfile *);
EXTERN char *(*next_symbol_text_func) (struct objfile *);
@@
-234,8
+204,6
@@
EXTERN int type_vector_length;
#define INITIAL_TYPE_VECTOR_LENGTH 160
#define INITIAL_TYPE_VECTOR_LENGTH 160
-extern void add_free_pendings (struct pending *list);
-
extern void add_symbol_to_list (struct symbol *symbol,
struct pending **listhead);
extern void add_symbol_to_list (struct symbol *symbol,
struct pending **listhead);
@@
-253,7
+221,7
@@
extern void record_block_range (struct block *,
extern void really_free_pendings (void *dummy);
extern void really_free_pendings (void *dummy);
-extern void start_subfile (c
har *name,
char *dirname);
+extern void start_subfile (c
onst char *name, const
char *dirname);
extern void patch_subfile_names (struct subfile *subfile, char *name);
extern void patch_subfile_names (struct subfile *subfile, char *name);
@@
-261,9
+229,26
@@
extern void push_subfile (void);
extern char *pop_subfile (void);
extern char *pop_subfile (void);
+extern struct block *end_symtab_get_static_block (CORE_ADDR end_addr,
+ struct objfile *objfile,
+ int expandable,
+ int required);
+
+extern struct symtab *end_symtab_from_static_block (struct block *static_block,
+ struct objfile *objfile,
+ int section,
+ int expandable);
+
extern struct symtab *end_symtab (CORE_ADDR end_addr,
struct objfile *objfile, int section);
extern struct symtab *end_symtab (CORE_ADDR end_addr,
struct objfile *objfile, int section);
+extern struct symtab *end_expandable_symtab (CORE_ADDR end_addr,
+ struct objfile *objfile,
+ int section);
+
+extern void augment_type_symtab (struct objfile *objfile,
+ struct symtab *primary_symtab);
+
/* Defined in stabsread.c. */
extern void scan_file_globals (struct objfile *objfile);
/* Defined in stabsread.c. */
extern void scan_file_globals (struct objfile *objfile);
@@
-278,29
+263,42
@@
extern struct context_stack *pop_context (void);
extern void record_line (struct subfile *subfile, int line, CORE_ADDR pc);
extern void record_line (struct subfile *subfile, int line, CORE_ADDR pc);
-extern void start_symtab (char *name, char *dirname, CORE_ADDR start_addr);
+extern void start_symtab (const char *name, const char *dirname,
+ CORE_ADDR start_addr);
-extern int hashname (char *name);
+extern void restart_symtab (CORE_ADDR start_addr);
+
+extern int hashname (const char *name);
extern void free_pending_blocks (void);
extern void free_pending_blocks (void);
-/*
FIXME: Note that this is used only in buildsym.c and dstread.c,
- which should be fixed to not need direct access to
-
record_pending_block.
*/
+/*
Record the name of the debug format in the current pending symbol
+ table. FORMAT must be a string with a lifetime at least as long as
+
the symtab's objfile.
*/
-extern void record_pending_block (struct objfile *objfile,
- struct block *block,
- struct pending_block *opblock);
+extern void record_debugformat (const char *format);
-extern void record_debugformat (char *format);
+/* Record the name of the debuginfo producer (usually the compiler) in
+ the current pending symbol table. PRODUCER must be a string with a
+ lifetime at least as long as the symtab's objfile. */
extern void record_producer (const char *producer);
extern void merge_symbol_lists (struct pending **srclist,
struct pending **targetlist);
extern void record_producer (const char *producer);
extern void merge_symbol_lists (struct pending **srclist,
struct pending **targetlist);
+/* Set the name of the last source file. NAME is copied by this
+ function. */
+
+extern void set_last_source_file (const char *name);
+
+/* Fetch the name of the last source file. */
+
+extern const char *get_last_source_file (void);
+
/* The macro table for the compilation unit whose symbols we're
/* The macro table for the compilation unit whose symbols we're
- currently reading. All the symtabs for this CU will point to this. */
+ currently reading. All the symtabs for this CU will point to
+ this. */
EXTERN struct macro_table *pending_macros;
#undef EXTERN
EXTERN struct macro_table *pending_macros;
#undef EXTERN
This page took
0.025853 seconds
and
4
git commands to generate.