raw_ostream.h revision 87f34658dec9097d987d254a990ea7f311bfc95f
1//===- raw_ostream.h ------------------------------------------------------===//
2//
3//                     The MCLinker Project
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9#ifndef MCLD_SUPPORT_RAWOSTREAM_H
10#define MCLD_SUPPORT_RAWOSTREAM_H
11#ifdef ENABLE_UNITTEST
12#include <gtest.h>
13#endif
14#include <string>
15#include <llvm/Support/raw_ostream.h>
16
17namespace mcld {
18
19class raw_fd_ostream : public llvm::raw_fd_ostream
20{
21public:
22  /// raw_fd_ostream - Open the specified file for writing. If an error occurs,
23  /// information about the error is put into ErrorInfo, and the stream should
24  /// be immediately destroyed; the string will be empty if no error occurred.
25  /// This allows optional flags to control how the file will be opened.
26  ///
27  /// As a special case, if Filename is "-", then the stream will use
28  /// STDOUT_FILENO instead of opening a file. Note that it will still consider
29  /// itself to own the file descriptor. In particular, it will close the
30  /// file descriptor when it is done (this is necessary to detect
31  /// output errors).
32  raw_fd_ostream(const char *pFilename,
33                 std::string &pErrorInfo,
34                 llvm::sys::fs::OpenFlags pFlags = llvm::sys::fs::F_None);
35
36  /// raw_fd_ostream ctor - FD is the file descriptor that this writes to.  If
37  /// ShouldClose is true, this closes the file when the stream is destroyed.
38  raw_fd_ostream(int pFD, bool pShouldClose, bool pUnbuffered=false);
39
40  virtual ~raw_fd_ostream();
41
42  void setColor(bool pEnable = true);
43
44
45  llvm::raw_ostream &changeColor(enum llvm::raw_ostream::Colors pColors,
46                                 bool pBold=false,
47                                 bool pBackground=false);
48
49  llvm::raw_ostream &resetColor();
50
51  llvm::raw_ostream &reverseColor();
52
53  bool is_displayed() const;
54
55private:
56  bool m_bConfigColor : 1;
57  bool m_bSetColor : 1;
58
59};
60
61/// outs() - This returns a reference to a raw_ostream for standard output.
62/// Use it like: outs() << "foo" << "bar";
63mcld::raw_fd_ostream &outs();
64
65/// errs() - This returns a reference to a raw_ostream for standard error.
66/// Use it like: errs() << "foo" << "bar";
67mcld::raw_fd_ostream &errs();
68
69} // namespace of mcld
70
71#endif
72
73