mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-21 07:23:38 +08:00
34eaf5422c
PR c++/9946: * symfile.c (reread_symbols): Clear template_symbols. * symtab.h (struct symbol) <is_cplus_template_function>: New field. (SYMBOL_IS_CPLUS_TEMPLATE_FUNCTION): New macro. (struct template_symbol): New. * symtab.c (lookup_symbol_aux_local): Use cp_lookup_symbol_imports_or_template. * objfiles.h (struct objfile) <template_symbols>: New field. * objfiles.c (relocate_one_symbol): New function. (objfile_relocate1): Use it. Relocate isolated symbols. * gdbtypes.h (struct cplus_struct_type) <n_template_arguments, template_arguments>: New fields. (TYPE_N_TEMPLATE_ARGUMENTS): New macro. (TYPE_TEMPLATE_ARGUMENTS): Likewise. (TYPE_TEMPLATE_ARGUMENT): Likewise. (lookup_typename): Update. * gdbtypes.c (lookup_typename): Constify "block" argument. * dwarf2read.c: Include vec.h. (symbolp): New typedef. (read_func_scope): Read template arguments. Allocate a template_symbol when needed. (read_structure_type): Read template arguments. (new_symbol_full): New function, from new_symbol. Handle DW_TAG_template_type_param and DW_TAG_template_value_param. (new_symbol): Rewrite as wrapper. * cp-support.h (cp_lookup_symbol_imports_or_template): Declare. * cp-namespace.c: Include language.h. (search_symbol_list): New function. (cp_lookup_symbol_imports_or_template): Likewise. gdb/testsuite PR c++/9946: * gdb.cp/temargs.exp: New file. * gdb.cp/temargs.cc: New file.
189 lines
6.2 KiB
C
189 lines
6.2 KiB
C
/* Helper routines for C++ support in GDB.
|
|
Copyright (C) 2002, 2003, 2004, 2005, 2007, 2008, 2009, 2010
|
|
Free Software Foundation, Inc.
|
|
|
|
Contributed by MontaVista Software.
|
|
Namespace support contributed by David Carlton.
|
|
|
|
This file is part of GDB.
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
|
|
|
#ifndef CP_SUPPORT_H
|
|
#define CP_SUPPORT_H
|
|
|
|
/* We need this for 'domain_enum', alas... */
|
|
|
|
#include "symtab.h"
|
|
|
|
/* Opaque declarations. */
|
|
|
|
struct symbol;
|
|
struct obstack;
|
|
struct block;
|
|
struct objfile;
|
|
struct type;
|
|
struct demangle_component;
|
|
|
|
/* This struct is designed to store data from using directives. It
|
|
says that names from namespace IMPORT_SRC should be visible within namespace
|
|
IMPORT_DEST. These form a linked list; NEXT is the next element of the
|
|
list. If the imported namespace or declaration has been aliased within the
|
|
IMPORT_DEST namespace, ALIAS is set to a string representing the alias.
|
|
Otherwise, ALIAS is NULL. DECLARATION is the name of the imported
|
|
declaration, if this import statement represents one. Otherwise DECLARATION
|
|
is NULL and this import statement represents a namespace.
|
|
|
|
C++: using namespace A;
|
|
Fortran: use A
|
|
import_src = "A"
|
|
import_dest = local scope of the import statement even such as ""
|
|
alias = NULL
|
|
declaration = NULL
|
|
|
|
C++: using A::x;
|
|
Fortran: use A, only: x
|
|
import_src = "A"
|
|
import_dest = local scope of the import statement even such as ""
|
|
alias = NULL
|
|
declaration = "x"
|
|
The declaration will get imported as import_dest::x.
|
|
|
|
C++: namespace LOCALNS = A;
|
|
Fortran has no way to address non-local namespace/module.
|
|
import_src = "A"
|
|
import_dest = local scope of the import statement even such as ""
|
|
alias = "LOCALNS"
|
|
declaration = NULL
|
|
The namespace will get imported as the import_dest::LOCALNS namespace.
|
|
|
|
C++ cannot express it, it would be something like: using localname = A::x;
|
|
Fortran: use A, only localname => x
|
|
import_src = "A"
|
|
import_dest = local scope of the import statement even such as ""
|
|
alias = "localname"
|
|
declaration = "x"
|
|
The declaration will get imported as localname or `import_dest`localname. */
|
|
|
|
struct using_direct
|
|
{
|
|
char *import_src;
|
|
char *import_dest;
|
|
|
|
char *alias;
|
|
char *declaration;
|
|
|
|
struct using_direct *next;
|
|
|
|
/* Used during import search to temporarily mark this node as searched. */
|
|
int searched;
|
|
};
|
|
|
|
|
|
/* Functions from cp-support.c. */
|
|
|
|
extern char *cp_canonicalize_string (const char *string);
|
|
|
|
extern char *cp_class_name_from_physname (const char *physname);
|
|
|
|
extern char *method_name_from_physname (const char *physname);
|
|
|
|
extern unsigned int cp_find_first_component (const char *name);
|
|
|
|
extern unsigned int cp_entire_prefix_len (const char *name);
|
|
|
|
extern char *cp_func_name (const char *full_name);
|
|
|
|
extern char *cp_remove_params (const char *demangled_name);
|
|
|
|
extern struct symbol **make_symbol_overload_list (const char *,
|
|
const char *);
|
|
|
|
extern struct symbol **make_symbol_overload_list_adl (struct type **arg_types,
|
|
int nargs,
|
|
const char *func_name);
|
|
|
|
extern struct type *cp_lookup_rtti_type (const char *name,
|
|
struct block *block);
|
|
|
|
extern int cp_validate_operator (const char *input);
|
|
|
|
/* Functions/variables from cp-namespace.c. */
|
|
|
|
extern int cp_is_anonymous (const char *namespace);
|
|
|
|
extern void cp_add_using_directive (const char *dest,
|
|
const char *src,
|
|
const char *alias,
|
|
const char *declaration,
|
|
struct obstack *obstack);
|
|
|
|
extern void cp_initialize_namespace (void);
|
|
|
|
extern void cp_finalize_namespace (struct block *static_block,
|
|
struct obstack *obstack);
|
|
|
|
extern void cp_set_block_scope (const struct symbol *symbol,
|
|
struct block *block,
|
|
struct obstack *obstack,
|
|
const char *processing_current_prefix,
|
|
int processing_has_namespace_info);
|
|
|
|
extern void cp_scan_for_anonymous_namespaces (const struct symbol *symbol);
|
|
|
|
extern struct symbol *cp_lookup_symbol_nonlocal (const char *name,
|
|
const struct block *block,
|
|
const domain_enum domain);
|
|
|
|
extern struct symbol *cp_lookup_symbol_namespace (const char *namespace,
|
|
const char *name,
|
|
const struct block *block,
|
|
const domain_enum domain);
|
|
|
|
extern struct symbol *cp_lookup_symbol_imports (const char *scope,
|
|
const char *name,
|
|
const struct block *block,
|
|
const domain_enum domain,
|
|
const int declaration_only,
|
|
const int search_parents);
|
|
|
|
extern struct symbol *cp_lookup_symbol_imports_or_template
|
|
(const char *scope,
|
|
const char *name,
|
|
const struct block *block,
|
|
const domain_enum domain);
|
|
|
|
extern struct type *cp_lookup_nested_type (struct type *parent_type,
|
|
const char *nested_name,
|
|
const struct block *block);
|
|
|
|
extern void cp_check_possible_namespace_symbols (const char *name,
|
|
struct objfile *objfile);
|
|
|
|
struct type *cp_lookup_transparent_type (const char *name);
|
|
|
|
/* Functions from cp-name-parser.y. */
|
|
|
|
extern struct demangle_component *cp_demangled_name_to_comp
|
|
(const char *demangled_name, const char **errmsg);
|
|
|
|
extern char *cp_comp_to_string (struct demangle_component *result,
|
|
int estimated_len);
|
|
|
|
/* The list of "maint cplus" commands. */
|
|
|
|
extern struct cmd_list_element *maint_cplus_cmd_list;
|
|
|
|
#endif /* CP_SUPPORT_H */
|