summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Archive
diff options
context:
space:
mode:
authorMichael J. Spencer <bigcheesegs@gmail.com>2011-01-16 21:13:51 +0000
committerMichael J. Spencer <bigcheesegs@gmail.com>2011-01-16 21:13:51 +0000
commit405e958ac3a43ff553245aea39c1cee88506b2f2 (patch)
tree906f8f89f3006f2c4dceddcc010655fb8d194021 /llvm/lib/Archive
parent12a620fd587a6bd9eb686e08c5820e0ecfe01586 (diff)
downloadbcm5719-llvm-405e958ac3a43ff553245aea39c1cee88506b2f2.tar.gz
bcm5719-llvm-405e958ac3a43ff553245aea39c1cee88506b2f2.zip
UnRevert "Revert the archive part of "Support/PathV2: Add identify_magic.""
This reverts commit dd103021a889a986a181ce36ed7b0e8dc9b645e1. llvm-svn: 123595
Diffstat (limited to 'llvm/lib/Archive')
-rw-r--r--llvm/lib/Archive/Archive.cpp5
-rw-r--r--llvm/lib/Archive/ArchiveWriter.cpp8
2 files changed, 7 insertions, 6 deletions
diff --git a/llvm/lib/Archive/Archive.cpp b/llvm/lib/Archive/Archive.cpp
index 3ee3cb25c5a..1eab27d3eba 100644
--- a/llvm/lib/Archive/Archive.cpp
+++ b/llvm/lib/Archive/Archive.cpp
@@ -116,11 +116,10 @@ bool ArchiveMember::replaceWith(const sys::Path& newFile, std::string* ErrMsg) {
// Get the signature and status info
const char* signature = (const char*) data;
- std::string magic;
+ SmallString<4> magic;
if (!signature) {
- path.getMagicNumber(magic,4);
+ sys::fs::get_magic(path.str(), magic.capacity(), magic);
signature = magic.c_str();
- std::string err;
const sys::FileStatus *FSinfo = path.getFileStatus(false, ErrMsg);
if (FSinfo)
info = *FSinfo;
diff --git a/llvm/lib/Archive/ArchiveWriter.cpp b/llvm/lib/Archive/ArchiveWriter.cpp
index 07a9aaf4fdb..8fcc7aa29cc 100644
--- a/llvm/lib/Archive/ArchiveWriter.cpp
+++ b/llvm/lib/Archive/ArchiveWriter.cpp
@@ -181,9 +181,11 @@ Archive::addFileBefore(const sys::Path& filePath, iterator where,
flags |= ArchiveMember::HasPathFlag;
if (hasSlash || filePath.str().length() > 15)
flags |= ArchiveMember::HasLongFilenameFlag;
- std::string magic;
- mbr->path.getMagicNumber(magic,4);
- switch (sys::IdentifyFileType(magic.c_str(),4)) {
+
+ sys::LLVMFileType type;
+ if (sys::fs::identify_magic(mbr->path.str(), type))
+ type = sys::Unknown_FileType;
+ switch (type) {
case sys::Bitcode_FileType:
flags |= ArchiveMember::BitcodeFlag;
break;
OpenPOWER on IntegriCloud