From 85593c239873f5743cc748a85446d6d25de9ed1c Mon Sep 17 00:00:00 2001 From: Rafael Espindola Date: Wed, 8 Nov 2017 21:15:21 +0000 Subject: [PATCH] Make sure an error is always handled. llvm-svn: 317724 --- .../tools/llvm-objcopy/fail-no-output-directory.test | 11 +++++++++++ llvm/tools/llvm-objcopy/llvm-objcopy.cpp | 7 ++++--- 2 files changed, 15 insertions(+), 3 deletions(-) create mode 100644 llvm/test/tools/llvm-objcopy/fail-no-output-directory.test diff --git a/llvm/test/tools/llvm-objcopy/fail-no-output-directory.test b/llvm/test/tools/llvm-objcopy/fail-no-output-directory.test new file mode 100644 index 000000000000..89bf62d3556e --- /dev/null +++ b/llvm/test/tools/llvm-objcopy/fail-no-output-directory.test @@ -0,0 +1,11 @@ +# RUN: yaml2obj %s > %t +# RUN: not llvm-objcopy %t no/such/dir 2>&1 | FileCheck %s +# CHECK: failed to open no/such/dir + +!ELF +FileHeader: + Class: ELFCLASS64 + Data: ELFDATA2LSB + Type: ET_EXEC + Machine: EM_X86_64 + diff --git a/llvm/tools/llvm-objcopy/llvm-objcopy.cpp b/llvm/tools/llvm-objcopy/llvm-objcopy.cpp index c923f902db82..54186f63c07e 100644 --- a/llvm/tools/llvm-objcopy/llvm-objcopy.cpp +++ b/llvm/tools/llvm-objcopy/llvm-objcopy.cpp @@ -116,10 +116,11 @@ void WriteObjectFile(const Object &Obj, StringRef File) { Expected> BufferOrErr = FileOutputBuffer::create(File, Obj.totalSize(), FileOutputBuffer::F_executable); - if (BufferOrErr.takeError()) + handleAllErrors(BufferOrErr.takeError(), [](const ErrorInfoBase &) { error("failed to open " + OutputFilename); - else - Buffer = std::move(*BufferOrErr); + }); + Buffer = std::move(*BufferOrErr); + Obj.write(*Buffer); if (auto E = Buffer->commit()) reportError(File, errorToErrorCode(std::move(E)));