summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDan Gohman <gohman@apple.com>2010-05-27 17:12:23 +0000
committerDan Gohman <gohman@apple.com>2010-05-27 17:12:23 +0000
commit130de9c0b49d98983a5eb059fb5a89896f58d533 (patch)
treef88ddf20bad8ad48ac9269ec5ea6a3d6376babc9
parent55e9717e59165d15161991be56c75c3e80220ee8 (diff)
downloadllvm-130de9c0b49d98983a5eb059fb5a89896f58d533.tar.gz
llvm-130de9c0b49d98983a5eb059fb5a89896f58d533.tar.bz2
llvm-130de9c0b49d98983a5eb059fb5a89896f58d533.tar.xz
Don't bother checking canRead() before calling getMagicNumber();
getMagicNumber() does its own error checking. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@104851 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/System/Path.cpp29
1 files changed, 13 insertions, 16 deletions
diff --git a/lib/System/Path.cpp b/lib/System/Path.cpp
index 6844530ce9..1235257b27 100644
--- a/lib/System/Path.cpp
+++ b/lib/System/Path.cpp
@@ -136,26 +136,23 @@ sys::IdentifyFileType(const char *magic, unsigned length) {
bool
Path::isArchive() const {
- if (canRead())
- return hasMagicNumber("!<arch>\012");
- return false;
+ return hasMagicNumber("!<arch>\012");
}
bool
Path::isDynamicLibrary() const {
- if (canRead()) {
- std::string Magic;
- if (getMagicNumber(Magic, 64))
- switch (IdentifyFileType(Magic.c_str(),
- static_cast<unsigned>(Magic.length()))) {
- default: return false;
- case Mach_O_FixedVirtualMemorySharedLib_FileType:
- case Mach_O_DynamicallyLinkedSharedLib_FileType:
- case Mach_O_DynamicallyLinkedSharedLibStub_FileType:
- case ELF_SharedObject_FileType:
- case COFF_FileType: return true;
- }
- }
+ std::string Magic;
+ if (getMagicNumber(Magic, 64))
+ switch (IdentifyFileType(Magic.c_str(),
+ static_cast<unsigned>(Magic.length()))) {
+ default: return false;
+ case Mach_O_FixedVirtualMemorySharedLib_FileType:
+ case Mach_O_DynamicallyLinkedSharedLib_FileType:
+ case Mach_O_DynamicallyLinkedSharedLibStub_FileType:
+ case ELF_SharedObject_FileType:
+ case COFF_FileType: return true;
+ }
+
return false;
}