mirror of
https://github.com/RPCS3/llvm.git
synced 2025-04-13 11:30:21 +00:00

(Relands r344930, reverted in r344935, and now hopefully fixed for Windows.) While this change specifically targets FileCheck, it affects any tool using the same SourceMgr facilities. Previously, -color was documented in FileCheck's -help output, but -color had no effect. Now, -color obeys its documentation: it forces colors to be used in FileCheck diagnostics even when stderr is not a terminal. -color is especially helpful when combined with FileCheck's -v, which can produce a long series of diagnostics that you might wish to pipe to a pager, such as less -R. The WithColor extensions here will also help to clean up color usage in FileCheck's annotated dump of input, which is proposed in D52999. Reviewed By: JDevlieghere, zturner Differential Revision: https://reviews.llvm.org/D53419 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@345202 91177308-0d34-0410-b5e6-96231b3b80d8
122 lines
3.6 KiB
C++
122 lines
3.6 KiB
C++
//===- WithColor.cpp ------------------------------------------------------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "llvm/Support/WithColor.h"
|
|
#include "llvm/Support/raw_ostream.h"
|
|
|
|
using namespace llvm;
|
|
|
|
cl::OptionCategory llvm::ColorCategory("Color Options");
|
|
|
|
static cl::opt<cl::boolOrDefault>
|
|
UseColor("color", cl::cat(ColorCategory),
|
|
cl::desc("Use colors in output (default=autodetect)"),
|
|
cl::init(cl::BOU_UNSET));
|
|
|
|
WithColor::WithColor(raw_ostream &OS, HighlightColor Color, bool DisableColors)
|
|
: OS(OS), DisableColors(DisableColors) {
|
|
// Detect color from terminal type unless the user passed the --color option.
|
|
if (colorsEnabled()) {
|
|
switch (Color) {
|
|
case HighlightColor::Address:
|
|
OS.changeColor(raw_ostream::YELLOW);
|
|
break;
|
|
case HighlightColor::String:
|
|
OS.changeColor(raw_ostream::GREEN);
|
|
break;
|
|
case HighlightColor::Tag:
|
|
OS.changeColor(raw_ostream::BLUE);
|
|
break;
|
|
case HighlightColor::Attribute:
|
|
OS.changeColor(raw_ostream::CYAN);
|
|
break;
|
|
case HighlightColor::Enumerator:
|
|
OS.changeColor(raw_ostream::MAGENTA);
|
|
break;
|
|
case HighlightColor::Macro:
|
|
OS.changeColor(raw_ostream::RED);
|
|
break;
|
|
case HighlightColor::Error:
|
|
OS.changeColor(raw_ostream::RED, true);
|
|
break;
|
|
case HighlightColor::Warning:
|
|
OS.changeColor(raw_ostream::MAGENTA, true);
|
|
break;
|
|
case HighlightColor::Note:
|
|
OS.changeColor(raw_ostream::BLACK, true);
|
|
break;
|
|
case HighlightColor::Remark:
|
|
OS.changeColor(raw_ostream::BLUE, true);
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
raw_ostream &WithColor::error() { return error(errs()); }
|
|
|
|
raw_ostream &WithColor::warning() { return warning(errs()); }
|
|
|
|
raw_ostream &WithColor::note() { return note(errs()); }
|
|
|
|
raw_ostream &WithColor::remark() { return remark(errs()); }
|
|
|
|
raw_ostream &WithColor::error(raw_ostream &OS, StringRef Prefix,
|
|
bool DisableColors) {
|
|
if (!Prefix.empty())
|
|
OS << Prefix << ": ";
|
|
return WithColor(OS, HighlightColor::Error, DisableColors).get()
|
|
<< "error: ";
|
|
}
|
|
|
|
raw_ostream &WithColor::warning(raw_ostream &OS, StringRef Prefix,
|
|
bool DisableColors) {
|
|
if (!Prefix.empty())
|
|
OS << Prefix << ": ";
|
|
return WithColor(OS, HighlightColor::Warning, DisableColors).get()
|
|
<< "warning: ";
|
|
}
|
|
|
|
raw_ostream &WithColor::note(raw_ostream &OS, StringRef Prefix,
|
|
bool DisableColors) {
|
|
if (!Prefix.empty())
|
|
OS << Prefix << ": ";
|
|
return WithColor(OS, HighlightColor::Note, DisableColors).get() << "note: ";
|
|
}
|
|
|
|
raw_ostream &WithColor::remark(raw_ostream &OS, StringRef Prefix,
|
|
bool DisableColors) {
|
|
if (!Prefix.empty())
|
|
OS << Prefix << ": ";
|
|
return WithColor(OS, HighlightColor::Remark, DisableColors).get()
|
|
<< "remark: ";
|
|
}
|
|
|
|
bool WithColor::colorsEnabled() {
|
|
if (DisableColors)
|
|
return false;
|
|
if (UseColor == cl::BOU_UNSET)
|
|
return OS.has_colors();
|
|
return UseColor == cl::BOU_TRUE;
|
|
}
|
|
|
|
WithColor &WithColor::changeColor(raw_ostream::Colors Color, bool Bold,
|
|
bool BG) {
|
|
if (colorsEnabled())
|
|
OS.changeColor(Color, Bold, BG);
|
|
return *this;
|
|
}
|
|
|
|
WithColor &WithColor::resetColor() {
|
|
if (colorsEnabled())
|
|
OS.resetColor();
|
|
return *this;
|
|
}
|
|
|
|
WithColor::~WithColor() { resetColor(); }
|