2018-02-12 Thomas Koenig <tkoenig@gcc.gnu.org>
[official-gcc.git] / libsanitizer / sanitizer_common / sanitizer_report_decorator.h
blobc0edfcf7437509c64c6cf1cc4666731da49f8f52
1 //===-- sanitizer_report_decorator.h ----------------------------*- C++ -*-===//
2 //
3 // This file is distributed under the University of Illinois Open Source
4 // License. See LICENSE.TXT for details.
5 //
6 //===----------------------------------------------------------------------===//
7 //
8 // Tags to decorate the sanitizer reports.
9 // Currently supported tags:
10 // * None.
11 // * ANSI color sequences.
13 //===----------------------------------------------------------------------===//
15 #ifndef SANITIZER_REPORT_DECORATOR_H
16 #define SANITIZER_REPORT_DECORATOR_H
18 #include "sanitizer_common.h"
20 namespace __sanitizer {
21 class SanitizerCommonDecorator {
22 // FIXME: This is not portable. It assumes the special strings are printed to
23 // stdout, which is not the case on Windows (see SetConsoleTextAttribute()).
24 public:
25 SanitizerCommonDecorator() : ansi_(ColorizeReports()) {}
26 const char *Bold() const { return ansi_ ? "\033[1m" : ""; }
27 const char *Default() const { return ansi_ ? "\033[1m\033[0m" : ""; }
28 const char *Warning() const { return Red(); }
29 const char *MemoryByte() { return Magenta(); }
31 protected:
32 const char *Black() const { return ansi_ ? "\033[1m\033[30m" : ""; }
33 const char *Red() const { return ansi_ ? "\033[1m\033[31m" : ""; }
34 const char *Green() const { return ansi_ ? "\033[1m\033[32m" : ""; }
35 const char *Yellow() const { return ansi_ ? "\033[1m\033[33m" : ""; }
36 const char *Blue() const { return ansi_ ? "\033[1m\033[34m" : ""; }
37 const char *Magenta() const { return ansi_ ? "\033[1m\033[35m" : ""; }
38 const char *Cyan() const { return ansi_ ? "\033[1m\033[36m" : ""; }
39 const char *White() const { return ansi_ ? "\033[1m\033[37m" : ""; }
40 private:
41 bool ansi_;
44 } // namespace __sanitizer
46 #endif // SANITIZER_REPORT_DECORATOR_H