mirror of
https://github.com/RPCS3/llvm.git
synced 2025-05-18 03:16:13 +00:00

This patch introduces 3 helper functions: error(), warn() and note() to make printing during verification more consistent. When supported, the respective prefixes are printed in color using the same color scheme as clang. Differential revision: https://reviews.llvm.org/D38368 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@314498 91177308-0d34-0410-b5e6-96231b3b80d8
44 lines
1.7 KiB
C++
44 lines
1.7 KiB
C++
//===- SyntaxHighlighting.cpp ---------------------------------------------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "SyntaxHighlighting.h"
|
|
#include "llvm/Support/CommandLine.h"
|
|
#include "llvm/Support/raw_ostream.h"
|
|
|
|
using namespace llvm;
|
|
using namespace dwarf;
|
|
using namespace syntax;
|
|
|
|
static cl::opt<cl::boolOrDefault>
|
|
UseColor("color",
|
|
cl::desc("use colored syntax highlighting (default=autodetect)"),
|
|
cl::init(cl::BOU_UNSET));
|
|
|
|
WithColor::WithColor(raw_ostream &OS, enum HighlightColor Type) : OS(OS) {
|
|
// Detect color from terminal type unless the user passed the --color option.
|
|
if (UseColor == cl::BOU_UNSET ? OS.has_colors() : UseColor == cl::BOU_TRUE) {
|
|
switch (Type) {
|
|
case Address: OS.changeColor(raw_ostream::YELLOW); break;
|
|
case String: OS.changeColor(raw_ostream::GREEN); break;
|
|
case Tag: OS.changeColor(raw_ostream::BLUE); break;
|
|
case Attribute: OS.changeColor(raw_ostream::CYAN); break;
|
|
case Enumerator: OS.changeColor(raw_ostream::MAGENTA); break;
|
|
case Macro: OS.changeColor(raw_ostream::RED); break;
|
|
case Error: OS.changeColor(raw_ostream::RED, true); break;
|
|
case Warning: OS.changeColor(raw_ostream::MAGENTA, true); break;
|
|
case Note: OS.changeColor(raw_ostream::BLACK, true); break;
|
|
}
|
|
}
|
|
}
|
|
|
|
WithColor::~WithColor() {
|
|
if (UseColor == cl::BOU_UNSET ? OS.has_colors() : UseColor == cl::BOU_TRUE)
|
|
OS.resetColor();
|
|
}
|