diff options
author | Michael J. Spencer <bigcheesegs@gmail.com> | 2011-01-16 21:13:51 +0000 |
---|---|---|
committer | Michael J. Spencer <bigcheesegs@gmail.com> | 2011-01-16 21:13:51 +0000 |
commit | 405e958ac3a43ff553245aea39c1cee88506b2f2 (patch) | |
tree | 906f8f89f3006f2c4dceddcc010655fb8d194021 /llvm/lib/Archive | |
parent | 12a620fd587a6bd9eb686e08c5820e0ecfe01586 (diff) | |
download | bcm5719-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.cpp | 5 | ||||
-rw-r--r-- | llvm/lib/Archive/ArchiveWriter.cpp | 8 |
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; |