Fix redefinition errors in C++ mode
In C, we can forward declare static structure instances. That doesn't work in C++ though. C++ treats these as definitions. So then the compiler complains about symbol redefinition, like: src/gdb/elfread.c:1569:29: error: redefinition of ‘const sym_fns elf_sym_fns_lazy_psyms’ src/gdb/elfread.c:53:29: error: ‘const sym_fns elf_sym_fns_lazy_psyms’ previously declared here The intent of static here is naturally to avoid making these objects visible outside the compilation unit. The equivalent in C++ would be to instead define the objects in the anonymous namespace. But given that it's desirable to leave the codebase compiling as both C and C++ for a while, this just makes the objects extern. (base_breakpoint_ops is already declared in breakpoint.h, so we can just remove the forward declare from breakpoint.c) gdb/ChangeLog: 2015-02-11 Tom Tromey <tromey@redhat.com> Pedro Alves <palves@redhat.com> * breakpoint.c (base_breakpoint_ops): Delete. * dwarf2loc.c (dwarf_expr_ctx_funcs): Make extern. * elfread.c (elf_sym_fns_gdb_index, elf_sym_fns_lazy_psyms): Make extern. * guile/guile.c (guile_extension_script_ops, guile_extension_ops): Make extern. * ppcnbsd-tdep.c (ppcnbsd2_sigtramp): Make extern. * python/py-arch.c (arch_object_type): Make extern. * python/py-block.c (block_syms_iterator_object_type): Make extern. * python/py-bpevent.c (breakpoint_event_object_type): Make extern. * python/py-cmd.c (cmdpy_object_type): Make extern. * python/py-continueevent.c (continue_event_object_type) * python/py-event.h (GDBPY_NEW_EVENT_TYPE): Remove 'qual' parameter. Update all callers. * python/py-evtregistry.c (eventregistry_object_type): Make extern. * python/py-exitedevent.c (exited_event_object_type): Make extern. * python/py-finishbreakpoint.c (finish_breakpoint_object_type): Make extern. * python/py-function.c (fnpy_object_type): Make extern. * python/py-inferior.c (inferior_object_type, membuf_object_type): Make extern. * python/py-infevents.c (call_pre_event_object_type) (inferior_call_post_event_object_type). (memory_changed_event_object_type): Make extern. * python/py-infthread.c (thread_object_type): Make extern. * python/py-lazy-string.c (lazy_string_object_type): Make extern. * python/py-linetable.c (linetable_entry_object_type) (linetable_object_type, ltpy_iterator_object_type): Make extern. * python/py-newobjfileevent.c (new_objfile_event_object_type) (clear_objfiles_event_object_type): Make extern. * python/py-objfile.c (objfile_object_type): Make extern. * python/py-param.c (parmpy_object_type): Make extern. * python/py-progspace.c (pspace_object_type): Make extern. * python/py-signalevent.c (signal_event_object_type): Make extern. * python/py-symtab.c (symtab_object_type, sal_object_type): Make extern. * python/py-type.c (type_object_type, field_object_type) (type_iterator_object_type): Make extern. * python/python.c (python_extension_script_ops) (python_extension_ops): Make extern. * stap-probe.c (stap_probe_ops): Make extern.
This commit is contained in:
parent
b19f47add0
commit
e36122e9d7
32 changed files with 124 additions and 101 deletions
|
@ -28,7 +28,7 @@ typedef struct {
|
|||
CORE_ADDR pc;
|
||||
} linetable_entry_object;
|
||||
|
||||
static PyTypeObject linetable_entry_object_type
|
||||
extern PyTypeObject linetable_entry_object_type
|
||||
CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF ("linetable_entry_object");
|
||||
|
||||
typedef struct {
|
||||
|
@ -39,7 +39,7 @@ typedef struct {
|
|||
PyObject *symtab;
|
||||
} linetable_object;
|
||||
|
||||
static PyTypeObject linetable_object_type
|
||||
extern PyTypeObject linetable_object_type
|
||||
CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF ("linetable_object");
|
||||
|
||||
typedef struct {
|
||||
|
@ -52,7 +52,7 @@ typedef struct {
|
|||
PyObject *source;
|
||||
} ltpy_iterator_object;
|
||||
|
||||
static PyTypeObject ltpy_iterator_object_type
|
||||
extern PyTypeObject ltpy_iterator_object_type
|
||||
CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF ("ltpy_iterator_object");
|
||||
|
||||
/* Internal helper function to extract gdb.Symtab from a gdb.Linetable
|
||||
|
@ -493,7 +493,7 @@ Return True if this Linetable is valid, False if not." },
|
|||
{NULL} /* Sentinel */
|
||||
};
|
||||
|
||||
static PyTypeObject linetable_object_type = {
|
||||
PyTypeObject linetable_object_type = {
|
||||
PyVarObject_HEAD_INIT (NULL, 0)
|
||||
"gdb.LineTable", /*tp_name*/
|
||||
sizeof (linetable_object), /*tp_basicsize*/
|
||||
|
@ -540,7 +540,7 @@ Return True if this Linetable iterator is valid, False if not." },
|
|||
{NULL} /* Sentinel */
|
||||
};
|
||||
|
||||
static PyTypeObject ltpy_iterator_object_type = {
|
||||
PyTypeObject ltpy_iterator_object_type = {
|
||||
PyVarObject_HEAD_INIT (NULL, 0)
|
||||
"gdb.LineTableIterator", /*tp_name*/
|
||||
sizeof (ltpy_iterator_object), /*tp_basicsize*/
|
||||
|
@ -580,7 +580,7 @@ static PyGetSetDef linetable_entry_object_getset[] = {
|
|||
{ NULL } /* Sentinel */
|
||||
};
|
||||
|
||||
static PyTypeObject linetable_entry_object_type = {
|
||||
PyTypeObject linetable_entry_object_type = {
|
||||
PyVarObject_HEAD_INIT (NULL, 0)
|
||||
"gdb.LineTableEntry", /*tp_name*/
|
||||
sizeof (linetable_entry_object), /*tp_basicsize*/
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue