X-Git-Url: http://drtracing.org/?a=blobdiff_plain;f=gprof%2Futils.c;h=4fc2db6038e94c91965a0120c37dbd5190503489;hb=83d4d556e29da05aa7aec28ae53be7524c05bedd;hp=19ea34b0ac29a8ccc6f8c96af6c4ac89edd2ba87;hpb=12516a373c27abe4516c2a3c84cfe9d94f02e18f;p=deliverable%2Fbinutils-gdb.git diff --git a/gprof/utils.c b/gprof/utils.c index 19ea34b0ac..4fc2db6038 100644 --- a/gprof/utils.c +++ b/gprof/utils.c @@ -1,32 +1,46 @@ /* - * Copyright (c) 1983 Regents of the University of California. - * All rights reserved. + * Copyright (c) 1983, 1993, 2001 + * The Regents of the University of California. All rights reserved. * - * Redistribution and use in source and binary forms are permitted - * provided that: (1) source distributions retain this entire copyright - * notice and comment, and (2) distributions including binaries display - * the following acknowledgement: ``This product includes software - * developed by the University of California, Berkeley and its contributors'' - * in the documentation or other materials provided with the distribution - * and in all advertising materials mentioning features or use of this - * software. Neither the name of the University nor the names of its - * contributors may be used to endorse or promote products derived - * from this software without specific prior written permission. - * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED - * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. Neither the name of the University nor the names of its contributors + * may be used to endorse or promote products derived from this software + * without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. */ -#include #include "gprof.h" -#include "cg_arcs.h" +#include "demangle.h" +#include "search_list.h" +#include "source.h" #include "symtab.h" +#include "cg_arcs.h" +#include "utils.h" +#include "corefile.h" /* * Print name of symbol. Return number of characters printed. */ int -DEFUN (print_name_only, (self), Sym * self) +print_name_only (Sym *self) { const char *name = self->name; const char *filename; @@ -36,21 +50,15 @@ DEFUN (print_name_only, (self), Sym * self) if (name) { - if (!bsd_style_output) + if (!bsd_style_output && demangle) { - if (name[0] == '_' && name[1] && discard_underscores) - { - name++; - } /* if */ - demangled = cplus_demangle (name, DMGL_ANSI | DMGL_PARAMS); + demangled = bfd_demangle (core_bfd, name, DMGL_ANSI | DMGL_PARAMS); if (demangled) - { - name = demangled; - } /* if */ - } /* if */ + name = demangled; + } printf ("%s", name); size = strlen (name); - if (line_granularity && self->file) + if ((line_granularity || inline_file_names) && self->file) { filename = self->file->name; if (!print_path) @@ -63,32 +71,40 @@ DEFUN (print_name_only, (self), Sym * self) else { filename = self->file->name; - } /* if */ - } /* if */ - sprintf (buf, " (%s:%d)", filename, self->line_num); - printf (buf); + } + } + if (line_granularity) + { + sprintf (buf, " (%s:%d @ %lx)", filename, self->line_num, + (unsigned long) self->addr); + } + else + { + sprintf (buf, " (%s:%d)", filename, self->line_num); + } + printf ("%s", buf); size += strlen (buf); - } /* if */ + } if (demangled) { free (demangled); - } /* if */ + } DBG (DFNDEBUG, printf ("{%d} ", self->cg.top_order)); DBG (PROPDEBUG, printf ("%4.0f%% ", 100.0 * self->cg.prop.fract)); - } /* if */ + } return size; -} /* print_name_only */ +} void -DEFUN (print_name, (self), Sym * self) +print_name (Sym *self) { print_name_only (self); if (self->cg.cyc.num != 0) { - printf (" ", self->cg.cyc.num); - } /* if */ + printf (_(" "), self->cg.cyc.num); + } if (self->cg.index != 0) { if (self->cg.print_flag) @@ -98,8 +114,6 @@ DEFUN (print_name, (self), Sym * self) else { printf (" (%d)", self->cg.index); - } /* if */ - } /* if */ -} /* print_name */ - -/*** end of utils.c ***/ + } + } +}