diff options
author | Daniel Jacobowitz <dan@debian.org> | 2004-02-09 22:19:26 +0000 |
---|---|---|
committer | Daniel Jacobowitz <dan@debian.org> | 2004-02-09 22:19:26 +0000 |
commit | d57422619d6f411cec4eb31484ef129f07d6aadb (patch) | |
tree | 8548220e3e8a625c51a801bc54832c31664b5897 /gdb/cp-namespace.c | |
parent | be0a34b132ff3c403bc64a5c895e3f9c24afb326 (diff) | |
download | gdb-d57422619d6f411cec4eb31484ef129f07d6aadb.tar.gz |
* cp-namespace.c (check_one_possible_namespace_symbol): Don't use
obstack_free.
Diffstat (limited to 'gdb/cp-namespace.c')
-rw-r--r-- | gdb/cp-namespace.c | 22 |
1 files changed, 12 insertions, 10 deletions
diff --git a/gdb/cp-namespace.c b/gdb/cp-namespace.c index 65d3ecc4746..a731352c6e4 100644 --- a/gdb/cp-namespace.c +++ b/gdb/cp-namespace.c @@ -783,14 +783,20 @@ check_one_possible_namespace_symbol (const char *name, int len, struct objfile *objfile) { struct block *block = get_possible_namespace_block (objfile); - char *name_copy = obsavestring (name, len, &objfile->objfile_obstack); - struct symbol *sym = lookup_block_symbol (block, name_copy, NULL, - VAR_DOMAIN); + char *name_copy = alloca (len + 1); + struct symbol *sym; + + memcpy (name_copy, name, len); + name_copy[len] = '\0'; + sym = lookup_block_symbol (block, name_copy, NULL, VAR_DOMAIN); if (sym == NULL) { - struct type *type = init_type (TYPE_CODE_NAMESPACE, 0, 0, - name_copy, objfile); + struct type *type; + name_copy = obsavestring (name, len, &objfile->objfile_obstack); + + type = init_type (TYPE_CODE_NAMESPACE, 0, 0, name_copy, objfile); + TYPE_TAG_NAME (type) = TYPE_NAME (type); sym = obstack_alloc (&objfile->objfile_obstack, sizeof (struct symbol)); @@ -806,11 +812,7 @@ check_one_possible_namespace_symbol (const char *name, int len, return 0; } else - { - obstack_free (&objfile->objfile_obstack, name_copy); - - return 1; - } + return 1; } /* Look for a symbol named NAME in all the possible namespace blocks. |