123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960 |
- //===- RenderingSupport.h - output stream rendering support functions ----===//
- //
- // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
- // See https://llvm.org/LICENSE.txt for license information.
- // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
- //
- //===----------------------------------------------------------------------===//
- #ifndef LLVM_COV_RENDERINGSUPPORT_H
- #define LLVM_COV_RENDERINGSUPPORT_H
- #include "llvm/Support/raw_ostream.h"
- #include <utility>
- namespace llvm {
- /// A helper class that resets the output stream's color if needed
- /// when destroyed.
- class ColoredRawOstream {
- ColoredRawOstream(const ColoredRawOstream &OS) = delete;
- public:
- raw_ostream &OS;
- bool IsColorUsed;
- ColoredRawOstream(raw_ostream &OS, bool IsColorUsed)
- : OS(OS), IsColorUsed(IsColorUsed) {}
- ColoredRawOstream(ColoredRawOstream &&Other)
- : OS(Other.OS), IsColorUsed(Other.IsColorUsed) {
- // Reset the other IsColorUsed so that the other object won't reset the
- // color when destroyed.
- Other.IsColorUsed = false;
- }
- ~ColoredRawOstream() {
- if (IsColorUsed)
- OS.resetColor();
- }
- };
- template <typename T>
- inline raw_ostream &operator<<(const ColoredRawOstream &OS, T &&Value) {
- return OS.OS << std::forward<T>(Value);
- }
- /// Change the color of the output stream if the `IsColorUsed` flag
- /// is true. Returns an object that resets the color when destroyed.
- inline ColoredRawOstream colored_ostream(raw_ostream &OS,
- raw_ostream::Colors Color,
- bool IsColorUsed = true,
- bool Bold = false, bool BG = false) {
- if (IsColorUsed)
- OS.changeColor(Color, Bold, BG);
- return ColoredRawOstream(OS, IsColorUsed);
- }
- } // namespace llvm
- #endif // LLVM_COV_RENDERINGSUPPORT_H
|