X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=gdb%2Fmacroscope.c;h=c025eb7d24a3dd6ebe75a390a05787b9d515048c;hb=dadef93096fd397c3acf2078bcf6b526ff4e0da4;hp=c27785a9c99153abace4054cfcf3fd643092a970;hpb=0fb0cc7590113e9b459dfcc48dc71c9d419d9580;p=platform%2Fupstream%2Fbinutils.git diff --git a/gdb/macroscope.c b/gdb/macroscope.c index c27785a..c025eb7 100644 --- a/gdb/macroscope.c +++ b/gdb/macroscope.c @@ -1,5 +1,5 @@ /* Functions for deciding which macros are currently in scope. - Copyright (C) 2002, 2007, 2008, 2009 Free Software Foundation, Inc. + Copyright (C) 2002-2014 Free Software Foundation, Inc. Contributed by Red Hat, Inc. This file is part of GDB. @@ -77,7 +77,7 @@ sal_macro_scope (struct symtab_and_line sal) complaint (&symfile_complaints, _("symtab found for `%s', but that file\n" "is not covered in the compilation unit's macro information"), - sal.symtab->filename); + symtab_to_filename_for_display (sal.symtab)); } return ms; @@ -88,6 +88,7 @@ struct macro_scope * user_macro_scope (void) { struct macro_scope *ms; + ms = XNEW (struct macro_scope); ms->file = macro_main (macro_user_macros); ms->line = -1; @@ -100,12 +101,13 @@ default_macro_scope (void) struct symtab_and_line sal; struct macro_scope *ms; struct frame_info *frame; + CORE_ADDR pc; /* If there's a selected frame, use its PC. */ frame = deprecated_safe_get_selected_frame (); - if (frame) - sal = find_pc_line (get_frame_pc (frame), 0); - + if (frame && get_frame_pc_if_available (frame, &pc)) + sal = find_pc_line (pc, 0); + /* Fall back to the current listing position. */ else { @@ -151,11 +153,13 @@ standard_macro_lookup (const char *name, void *baton) return result; } +/* Provide a prototype to silence -Wmissing-prototypes. */ +extern initialize_file_ftype _initialize_macroscope; void _initialize_macroscope (void) { - macro_user_macros = new_macro_table (0, 0); + macro_user_macros = new_macro_table (NULL, NULL, NULL); macro_set_main (macro_user_macros, ""); macro_allow_redefinitions (macro_user_macros); }