summaryrefslogtreecommitdiff
path: root/bfd/dwarf2.c
diff options
context:
space:
mode:
authorNick Clifton <nickc@redhat.com>2003-04-01 10:18:54 +0000
committerNick Clifton <nickc@redhat.com>2003-04-01 10:18:54 +0000
commitaf3ef9fe5c1b25265c6c6188a48020b5e6512b75 (patch)
tree8246c62e7a96224f04427a763f4d7ea1fe3d2c9a /bfd/dwarf2.c
parenta6e028719aaa327ac9d4f22cb5da4716f55de60a (diff)
downloadbinutils-gdb-af3ef9fe5c1b25265c6c6188a48020b5e6512b75.tar.gz
Remove use of concat() inside concat_filename()
Diffstat (limited to 'bfd/dwarf2.c')
-rw-r--r--bfd/dwarf2.c45
1 files changed, 27 insertions, 18 deletions
diff --git a/bfd/dwarf2.c b/bfd/dwarf2.c
index 0bc94b64135..e8ebd6215fe 100644
--- a/bfd/dwarf2.c
+++ b/bfd/dwarf2.c
@@ -817,11 +817,11 @@ struct funcinfo
bfd_vma high;
};
-/* add_line_info: adds a new entry to the line_info list in the
- line_info_table, ensuring that the list is sorted. Note that the
- line_info list is sorted from highest to lowest VMA (with possible
- duplicates); that is, line_info->prev_line always accesses an equal
- or smaller VMA. */
+/* Adds a new entry to the line_info list in the line_info_table, ensuring
+ that the list is sorted. Note that the line_info list is sorted from
+ highest to lowest VMA (with possible duplicates); that is,
+ line_info->prev_line always accesses an equal or smaller VMA. */
+
static void
add_line_info (table, address, filename, line, column, end_sequence)
struct line_info_table* table;
@@ -908,7 +908,8 @@ add_line_info (table, address, filename, line, column, end_sequence)
}
/* Extract a fully qualified filename from a line info table.
- The returned string has been xmalloc'ed. */
+ The returned string has been malloc'ed and it is the caller's
+ responsibility to free it. */
static char *
concat_filename (table, file)
@@ -921,26 +922,32 @@ concat_filename (table, file)
{
(*_bfd_error_handler)
(_("Dwarf Error: mangled line number section (bad file number)."));
- return concat ("<unknown>");
+ return strdup ("<unknown>");
}
filename = table->files[file - 1].name;
- if (IS_ABSOLUTE_PATH (filename))
- return concat (filename);
- else
+ if (! IS_ABSOLUTE_PATH (filename))
{
char* dirname = (table->files[file - 1].dir
? table->dirs[table->files[file - 1].dir - 1]
: table->comp_dir);
- /* Not all tools set DW_AT_comp_dir, so dirname may be unknown. The
- best we can do is return the filename part. */
- if (dirname == NULL)
- return concat (filename);
- else
- return concat (dirname, "/", filename, NULL);
+ /* Not all tools set DW_AT_comp_dir, so dirname may be unknown.
+ The best we can do is return the filename part. */
+ if (dirname != NULL)
+ {
+ unsigned int len = strlen (dirname) + strlen (filename) + 2;
+ char * name;
+
+ name = bfd_malloc (len);
+ if (name)
+ sprintf (name, "%s/%s", dirname, filename);
+ return name;
+ }
}
+
+ return strdup (filename);
}
static void
@@ -1266,7 +1273,8 @@ decode_line_info (unit, stash)
based, the references are 1 based. */
file = read_unsigned_leb128 (abfd, line_ptr, &bytes_read);
line_ptr += bytes_read;
- free (filename);
+ if (filename)
+ free (filename);
filename = concat_filename (table, file);
break;
}
@@ -1302,7 +1310,8 @@ decode_line_info (unit, stash)
}
}
- free (filename);
+ if (filename)
+ free (filename);
}
return table;