mirror of
https://github.com/RPCS3/llvm.git
synced 2025-04-08 00:01:37 +00:00

This reverts r299062, which caused build failures on Windows. It also reverts the attempts to fix the windows builds in r299064 and r299065. The introduction of namespace llvm::sys::detail makes MSVC, and seemingly also mingw, complain about ambiguity with the existing namespace llvm::detail. E.g.: C:\b\slave\sanitizer-windows\llvm\include\llvm/Support/MathExtras.h(184): error C2872: 'detail': ambiguous symbol C:\b\slave\sanitizer-windows\llvm\include\llvm/Support/PointerLikeTypeTraits.h(31): note: could be 'llvm::detail' C:\b\slave\sanitizer-windows\llvm\include\llvm/Support/Host.h(80): note: or 'llvm::sys::detail' In r299064 and r299065 I tried to fix these ambiguities, based on the errors reported in the log files. It seems however that the build stops early when this kind of error is encountered, and many build-then-fix-iterations on Windows may be needed to fix this. Therefore reverting r299062 for now to get the build working again on Windows. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@299066 91177308-0d34-0410-b5e6-96231b3b80d8
55 lines
1.6 KiB
C++
55 lines
1.6 KiB
C++
//===- Support/Chrono.cpp - Utilities for Timing Manipulation ---*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "llvm/Support/Chrono.h"
|
|
#include "llvm/Config/config.h"
|
|
#include "llvm/Support/Format.h"
|
|
#include "llvm/Support/raw_ostream.h"
|
|
|
|
namespace llvm {
|
|
|
|
using namespace sys;
|
|
|
|
const char detail::unit<std::ratio<3600>>::value[] = "h";
|
|
const char detail::unit<std::ratio<60>>::value[] = "m";
|
|
const char detail::unit<std::ratio<1>>::value[] = "s";
|
|
const char detail::unit<std::milli>::value[] = "ms";
|
|
const char detail::unit<std::micro>::value[] = "us";
|
|
const char detail::unit<std::nano>::value[] = "ns";
|
|
|
|
static inline struct tm getStructTM(TimePoint<> TP) {
|
|
struct tm Storage;
|
|
std::time_t OurTime = toTimeT(TP);
|
|
|
|
#if defined(LLVM_ON_UNIX)
|
|
struct tm *LT = ::localtime_r(&OurTime, &Storage);
|
|
assert(LT);
|
|
(void)LT;
|
|
#endif
|
|
#if defined(LLVM_ON_WIN32)
|
|
int Error = ::localtime_s(&Storage, &OurTime);
|
|
assert(!Error);
|
|
(void)Error;
|
|
#endif
|
|
|
|
return Storage;
|
|
}
|
|
|
|
raw_ostream &operator<<(raw_ostream &OS, TimePoint<> TP) {
|
|
struct tm LT = getStructTM(TP);
|
|
char Buffer[sizeof("YYYY-MM-DD HH:MM:SS")];
|
|
strftime(Buffer, sizeof(Buffer), "%Y-%m-%d %H:%M:%S", <);
|
|
return OS << Buffer << '.'
|
|
<< format("%.9lu",
|
|
long((TP.time_since_epoch() % std::chrono::seconds(1))
|
|
.count()));
|
|
}
|
|
|
|
} // namespace llvm
|