[llvm-objcopy] Improve error message for unrecognised archive member

Prior to this patch, llvm-objcopy's error messages for archives with
unsupported members only mentioned the archive name, not the member
name, making them unhelpful. This change improves it by approximately
following GNU objcopy's error message syntax of
"<archive name>(<member name>): <problem>".

Reviewed by: grimar

Differential Revision: https://reviews.llvm.org/D61674

llvm-svn: 360251
This commit is contained in:
James Henderson 2019-05-08 13:28:58 +00:00
parent 6de5576af7
commit 5a2b5ca7d2
2 changed files with 51 additions and 6 deletions

View File

@ -0,0 +1,45 @@
## Show that llvm-objcopy and llvm-strip emit errors when attempting to modify
## archives containing unrecognized files, and do not modify anything. We use
## --strip-debug so that the section should be removed, and a difference
## detectable, if the file were modified.
# RUN: yaml2obj %s -o %t.o
# RUN: rm -f %t.a
# RUN: llvm-ar rc %t.a %t.o %s
# RUN: cp %t.a %t1.a
# RUN: cp %t.a %t2.a
# RUN: not llvm-objcopy --strip-debug %t1.a 2>&1 | FileCheck %s -DARCHIVE=%t1.a
# RUN: not llvm-strip --strip-debug %t2.a 2>&1 | FileCheck %s -DARCHIVE=%t2.a
## Verify that the archive was not modified, if any member couldn't be recognised.
# RUN: cmp %t.a %t1.a
# RUN: cmp %t.a %t2.a
# CHECK: error: '[[ARCHIVE]](archive-unknown-members.test)': The file was not recognized as a valid object file
# RUN: rm -f %t.thin1.a %t.thin2.a
# RUN: cp %t.o %t1.o
# RUN: cp %t.o %t2.o
# RUN: llvm-ar rcT %t.thin1.a %t1.o %s
# RUN: llvm-ar rcT %t.thin2.a %t2.o %s
# RUN: not llvm-objcopy --strip-debug %t.thin1.a 2>&1 \
# RUN: | FileCheck %s --check-prefix=THIN -DARCHIVE=%t.thin1.a -DMEMBER=%s
# RUN: not llvm-strip --strip-debug %t.thin2.a 2>&1 \
# RUN: | FileCheck %s --check-prefix=THIN -DARCHIVE=%t.thin2.a -DMEMBER=%s
## Verify that the first member was not modified, if a later member could not
## be recognised.
# RUN: cmp %t.o %t1.o
# RUN: cmp %t.o %t2.o
# THIN: error: '[[ARCHIVE]]([[MEMBER]])': The file was not recognized as a valid object file
--- !ELF
FileHeader:
Class: ELFCLASS64
Data: ELFDATA2LSB
Type: ET_EXEC
Machine: EM_X86_64
Sections:
- Name: .debug_foo
Type: SHT_PROGBITS

View File

@ -154,17 +154,17 @@ static Error executeObjcopyOnArchive(const CopyConfig &Config,
std::vector<NewArchiveMember> NewArchiveMembers;
Error Err = Error::success();
for (const Archive::Child &Child : Ar.children(Err)) {
Expected<std::unique_ptr<Binary>> ChildOrErr = Child.getAsBinary();
if (!ChildOrErr)
return createFileError(Ar.getFileName(), ChildOrErr.takeError());
Binary *Bin = ChildOrErr->get();
Expected<StringRef> ChildNameOrErr = Child.getName();
if (!ChildNameOrErr)
return createFileError(Ar.getFileName(), ChildNameOrErr.takeError());
Expected<std::unique_ptr<Binary>> ChildOrErr = Child.getAsBinary();
if (!ChildOrErr)
return createFileError(Ar.getFileName() + "(" + *ChildNameOrErr + ")",
ChildOrErr.takeError());
MemBuffer MB(ChildNameOrErr.get());
if (Error E = executeObjcopyOnBinary(Config, *Bin, MB))
if (Error E = executeObjcopyOnBinary(Config, *ChildOrErr->get(), MB))
return E;
Expected<NewArchiveMember> Member =