mirror of
https://github.com/ldc-developers/ldc.git
synced 2025-05-07 19:36:06 +03:00

Contains all changes necessary to LDC specific source to compile LDC2 with VS2010. See https://github.com/D-Programming-Language/dmd/pull/516 for necessary changes to DMDFE.
129 lines
2.9 KiB
C++
129 lines
2.9 KiB
C++
#include <cassert>
|
|
#include <cstdarg>
|
|
#include <cstdio>
|
|
#include <cstdlib>
|
|
#include <fstream>
|
|
#include <string>
|
|
#include <iostream>
|
|
|
|
#include "mars.h"
|
|
|
|
#include "llvm/Support/CommandLine.h"
|
|
|
|
#include "llvm/GlobalValue.h"
|
|
#include "llvm/Support/Casting.h"
|
|
#include "llvm/Support/raw_os_ostream.h"
|
|
#include "llvm/Assembly/Writer.h"
|
|
|
|
#include "gen/logger.h"
|
|
#include "gen/irstate.h"
|
|
|
|
void Stream::writeType(std::ostream& OS, const llvm::Type& Ty) {
|
|
llvm::raw_os_ostream raw(OS);
|
|
Ty.print(raw);
|
|
}
|
|
|
|
void Stream::writeValue(std::ostream& OS, const llvm::Value& V) {
|
|
// Constants don't always get their types pretty-printed.
|
|
// (Only treat non-global constants like this, so that e.g. global variables
|
|
// still get their initializers printed)
|
|
llvm::raw_os_ostream raw(OS);
|
|
if (llvm::isa<llvm::Constant>(V) && !llvm::isa<llvm::GlobalValue>(V))
|
|
llvm::WriteAsOperand(raw, &V, true, gIR->module);
|
|
else
|
|
V.print(raw);
|
|
}
|
|
|
|
namespace Logger
|
|
{
|
|
static std::string indent_str;
|
|
|
|
llvm::cl::opt<bool> _enabled("vv",
|
|
llvm::cl::desc("Very verbose"),
|
|
llvm::cl::ZeroOrMore);
|
|
|
|
void indent()
|
|
{
|
|
if (_enabled) {
|
|
indent_str += "* ";
|
|
}
|
|
}
|
|
void undent()
|
|
{
|
|
if (_enabled) {
|
|
assert(!indent_str.empty());
|
|
indent_str.resize(indent_str.size()-2);
|
|
}
|
|
}
|
|
Stream cout()
|
|
{
|
|
if (_enabled)
|
|
return std::cout << indent_str;
|
|
else
|
|
return 0;
|
|
}
|
|
|
|
#if defined(_MSC_VER)
|
|
static inline void
|
|
search_and_replace(std::string& str, const std::string& what, const std::string& replacement)
|
|
{
|
|
assert(!what.empty());
|
|
size_t pos = str.find(what);
|
|
while (pos != std::string::npos)
|
|
{
|
|
str.replace(pos, what.size(), replacement);
|
|
pos = str.find(what, pos + replacement.size());
|
|
}
|
|
}
|
|
|
|
#define WORKAROUND_C99_SPECIFIERS_BUG(f) \
|
|
std::string tmp = f; \
|
|
search_and_replace(tmp, std::string("%z"), std::string("%I")); \
|
|
f = tmp.c_str();
|
|
#else
|
|
#define WORKAROUND_C99_SPECIFIERS_BUG(f)
|
|
#endif
|
|
|
|
void println(const char* fmt,...)
|
|
{
|
|
if (_enabled) {
|
|
printf("%s", indent_str.c_str());
|
|
va_list va;
|
|
va_start(va,fmt);
|
|
WORKAROUND_C99_SPECIFIERS_BUG(fmt);
|
|
vprintf(fmt,va);
|
|
va_end(va);
|
|
printf("\n");
|
|
}
|
|
}
|
|
void print(const char* fmt,...)
|
|
{
|
|
if (_enabled) {
|
|
printf("%s", indent_str.c_str());
|
|
va_list va;
|
|
va_start(va,fmt);
|
|
WORKAROUND_C99_SPECIFIERS_BUG(fmt);
|
|
vprintf(fmt,va);
|
|
va_end(va);
|
|
}
|
|
}
|
|
void enable()
|
|
{
|
|
_enabled = true;
|
|
}
|
|
void disable()
|
|
{
|
|
_enabled = false;
|
|
}
|
|
bool enabled()
|
|
{
|
|
return _enabled;
|
|
}
|
|
void attention(Loc loc, const char* fmt,...)
|
|
{
|
|
va_list va;
|
|
va_start(va,fmt);
|
|
vwarning(loc,fmt,va);
|
|
va_end(va);
|
|
}
|
|
}
|