Mercurial > projects > ldc
view gen/logger.cpp @ 102:027b8d8b71ec trunk
[svn r106] Turns out the last commit wasn't enough, now the D->LLVM process is even more split up.
Basically it tries to do the following in order: Resolve types, Declare symbols, Create constant initializers, Apply initializers, Generate functions bodies.
ClassInfo is now has the most useful(biased?) members working.
Probably other stuf...
author | lindquist |
---|---|
date | Sun, 18 Nov 2007 06:52:57 +0100 |
parents | 61615fa85940 |
children | 5825d48b27d1 |
line wrap: on
line source
#include <cassert> #include <cstdarg> #include <cstdio> #include <cstdlib> #include <iostream> #include <fstream> #include <string> #include "gen/logger.h" namespace Logger { static std::string indent_str; static std::ofstream null_out("/dev/null"); static bool enabled = false; void indent() { if (enabled) { indent_str += "* "; } } void undent() { if (enabled) { assert(!indent_str.empty()); indent_str.resize(indent_str.size()-2); } } std::ostream& cout() { if (enabled) return std::cout << indent_str; else return null_out; } void println(const char* fmt,...) { if (enabled) { printf(indent_str.c_str()); va_list va; va_start(va,fmt); vprintf(fmt,va); va_end(va); printf("\n"); } } void print(const char* fmt,...) { if (enabled) { printf(indent_str.c_str()); va_list va; va_start(va,fmt); vprintf(fmt,va); va_end(va); } } void enable() { enabled = true; } void disable() { enabled = false; } void attention(const char* fmt,...) { printf("***ATTENTION*** "); va_list va; va_start(va,fmt); vprintf(fmt,va); va_end(va); printf("\n"); } }