From da03bf4d5bf7cdf56a85d10b85b05028649f94f7 Mon Sep 17 00:00:00 2001 From: Tristan Gingold Date: Tue, 17 Apr 2012 10:51:07 +0000 Subject: [PATCH] 2012-04-17 Tristan Gingold * vms-lib.c (_bfd_vms_lib_get_module): Append .obj extension to member of an object archive.< --- bfd/ChangeLog | 5 +++++ bfd/vms-lib.c | 21 ++++++++++++++++++++- 2 files changed, 25 insertions(+), 1 deletion(-) diff --git a/bfd/ChangeLog b/bfd/ChangeLog index da0ebeed615..78710028100 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,8 @@ +2012-04-17 Tristan Gingold + + * vms-lib.c (_bfd_vms_lib_get_module): Append .obj extension to + member of an object archive.< + 2012-04-17 Tristan Gingold * vms-lib.c (MAX_EKEYLEN): Define. diff --git a/bfd/vms-lib.c b/bfd/vms-lib.c index 78696951f2f..a0649d0d984 100644 --- a/bfd/vms-lib.c +++ b/bfd/vms-lib.c @@ -1296,6 +1296,7 @@ _bfd_vms_lib_get_module (bfd *abfd, unsigned int modidx) struct lib_tdata *tdata = bfd_libdata (abfd); bfd *res; file_ptr file_off; + char *name; /* Sanity check. */ if (modidx >= tdata->nbr_modules) @@ -1357,7 +1358,25 @@ _bfd_vms_lib_get_module (bfd *abfd, unsigned int modidx) res->origin = file_off + tdata->mhd_size; } - res->filename = tdata->modules[modidx].name; + /* Set filename. */ + name = tdata->modules[modidx].name; + switch (tdata->type) + { + case LBR__C_TYP_IOBJ: + case LBR__C_TYP_EOBJ: + /* For object archives, append .obj to mimic standard behaviour. */ + { + size_t namelen = strlen (name); + char *name1 = bfd_alloc (res, namelen + 4 + 1); + memcpy (name1, name, namelen); + strcpy (name1 + namelen, ".obj"); + name = name1; + } + break; + default: + break; + } + res->filename = name; tdata->cache[modidx] = res; -- 2.34.1