mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-09 16:45:03 +00:00
Added "DOUT" macro. This is used as a replacement for the std::cerr
stream. It centralizes the use of std::cerr so that static c'tor/d'tors aren't scattered around all over the place. The way to use it is like this: DOUT << "This is a status line: " << Var << "\n"; If "-debug" is specified, it will print. Otherwise, it'll not print. If NDEBUG is defined, the DOUT does nothing. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@31798 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
e28a12a3b8
commit
1ea783f13a
@ -26,6 +26,8 @@
|
||||
#ifndef LLVM_SUPPORT_DEBUG_H
|
||||
#define LLVM_SUPPORT_DEBUG_H
|
||||
|
||||
#include <ostream> // Doesn't have static d'tors!!
|
||||
|
||||
namespace llvm {
|
||||
|
||||
// DebugFlag - This boolean is set to true if the '-debug' command line option
|
||||
@ -59,6 +61,34 @@ bool isCurrentDebugType(const char *Type);
|
||||
do { if (DebugFlag && isCurrentDebugType(DEBUG_TYPE)) { X; } } while (0)
|
||||
#endif
|
||||
|
||||
// llvm_ostream - Acts like an ostream. However, it doesn't print things out if
|
||||
// an ostream isn't specified.
|
||||
//
|
||||
class llvm_ostream {
|
||||
std::ostream* Stream;
|
||||
public:
|
||||
llvm_ostream() : Stream(0) {}
|
||||
llvm_ostream(std::ostream& OStream) : Stream(&OStream) {}
|
||||
|
||||
template <typename Ty>
|
||||
llvm_ostream& operator << (const Ty& Thing) {
|
||||
if (Stream) *Stream << Thing;
|
||||
return *this;
|
||||
}
|
||||
};
|
||||
|
||||
// getErrorOutputStream - Returns the error output stream (std::cerr). This
|
||||
// places the std::c* I/O streams into one .cpp file and relieves the whole
|
||||
// program from having to have hundreds of static c'tor/d'tors for them.
|
||||
//
|
||||
llvm_ostream getErrorOutputStream(const char *DebugType);
|
||||
|
||||
#ifdef NDEBUG
|
||||
#define DOUT llvm_ostream()
|
||||
#else
|
||||
#define DOUT getErrorOutputStream(DEBUG_TYPE)
|
||||
#endif
|
||||
|
||||
} // End llvm namespace
|
||||
|
||||
#endif
|
||||
|
@ -25,6 +25,7 @@
|
||||
|
||||
#include "llvm/Support/Debug.h"
|
||||
#include "llvm/Support/CommandLine.h"
|
||||
#include <iostream>
|
||||
using namespace llvm;
|
||||
|
||||
bool llvm::DebugFlag; // DebugFlag - Exported boolean set by the -debug option
|
||||
@ -63,3 +64,14 @@ bool llvm::isCurrentDebugType(const char *DebugType) {
|
||||
return false;
|
||||
#endif
|
||||
}
|
||||
|
||||
// getErrorOutputStream - Returns the error output stream (std::cerr). This
|
||||
// places the std::c* I/O streams into one .cpp file and relieves the whole
|
||||
// program from having to have hundreds of static c'tor/d'tors for them.
|
||||
//
|
||||
llvm_ostream llvm::getErrorOutputStream(const char *DebugType) {
|
||||
if (DebugFlag && isCurrentDebugType(DebugType))
|
||||
return llvm_ostream(std::cerr);
|
||||
else
|
||||
return llvm_ostream();
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user