From: Rafael Espindola Date: Sat, 13 Jul 2013 05:07:22 +0000 (+0000) Subject: Try to open the file before use data from stat. X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=718af7892033aa965efafbf63c7636d91728662b;p=oota-llvm.git Try to open the file before use data from stat. Looks like on mingw we get bogus last modification times on directories. Should fix the mingw bots. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@186240 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/tools/llvm-ar/llvm-ar.cpp b/tools/llvm-ar/llvm-ar.cpp index 5f47654b246..7632b00f916 100644 --- a/tools/llvm-ar/llvm-ar.cpp +++ b/tools/llvm-ar/llvm-ar.cpp @@ -560,6 +560,9 @@ static void performWriteOperation(ArchiveOperation Operation, sys::fs::file_status Status; failIfError(sys::fs::status(FileName, Status), FileName); + OwningPtr File; + failIfError(MemoryBuffer::getFile(FileName, File), FileName); + uint64_t secondsSinceEpoch = Status.getLastModificationTime().toEpochTime(); printWithSpacePadding(Out, secondsSinceEpoch, 12); @@ -570,8 +573,6 @@ static void performWriteOperation(ArchiveOperation Operation, printWithSpacePadding(Out, Status.getSize(), 10); Out << "`\n"; - OwningPtr File; - failIfError(MemoryBuffer::getFile(FileName, File), FileName); Out << File->getBuffer(); } else { object::Archive::child_iterator OldMember = I->getOld();