//===- raw_ostream.h ------------------------------------------------------===// // // The MCLinker Project // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #ifndef MCLD_SUPPORT_RAW_OSTREAM_H_ #define MCLD_SUPPORT_RAW_OSTREAM_H_ #include <llvm/Support/FileSystem.h> #include <llvm/Support/raw_ostream.h> #include <string> namespace mcld { class raw_fd_ostream : public llvm::raw_fd_ostream { public: /// raw_fd_ostream - Open the specified file for writing. If an error occurs, /// information about the error is put into ErrorInfo, and the stream should /// be immediately destroyed; the string will be empty if no error occurred. /// This allows optional flags to control how the file will be opened. /// /// As a special case, if Filename is "-", then the stream will use /// STDOUT_FILENO instead of opening a file. Note that it will still consider /// itself to own the file descriptor. In particular, it will close the /// file descriptor when it is done (this is necessary to detect /// output errors). raw_fd_ostream(const char* pFilename, std::error_code& pErrorCode, llvm::sys::fs::OpenFlags pFlags = llvm::sys::fs::F_None); /// raw_fd_ostream ctor - FD is the file descriptor that this writes to. If /// ShouldClose is true, this closes the file when the stream is destroyed. raw_fd_ostream(int pFD, bool pShouldClose, bool pUnbuffered = false); virtual ~raw_fd_ostream(); void setColor(bool pEnable = true); llvm::raw_ostream& changeColor(enum llvm::raw_ostream::Colors pColors, bool pBold = false, bool pBackground = false); llvm::raw_ostream& resetColor(); llvm::raw_ostream& reverseColor(); bool is_displayed() const; private: bool m_bConfigColor : 1; bool m_bSetColor : 1; }; /// outs() - This returns a reference to a raw_ostream for standard output. /// Use it like: outs() << "foo" << "bar"; mcld::raw_fd_ostream& outs(); /// errs() - This returns a reference to a raw_ostream for standard error. /// Use it like: errs() << "foo" << "bar"; mcld::raw_fd_ostream& errs(); } // namespace mcld #endif // MCLD_SUPPORT_RAW_OSTREAM_H_