The standard C++
iostreamlibrary does not know about colors. Hence, console applications tend to look very boring and often fail to emphasize the important bits in the flood of text. As I normally use console applications to do unit testing, I wanted the input conditions and the results of the test cases to stand out and be easily interpreted (i.e. PASSED in green and FAIL in red).
The Win32 API has some functions to manipulate the color of characters in a console but these are C style functions that do not interface seemlessly with the C++ stream style programming. Moreover, I want to keep my main code clean and uncluttered. Anybody reading my test cases should not have to wade through dozens of lines of output formatting code.
To that end, I created a handy set of
iostreammanipulators that allow me to change background and foreground colors at any point in the output stream.
Using the Code
All the necessary code is contained in one header file: Console.h. To guard against name clashing, the functions in this file are placed in a single namespace: "
As the following snippet shows, the use of the
iostreamcolor manipulators is simplicity itself.
namespace con = JadedHoboConsole;
cout << "I like " << con::fg_green << "green" << con::fg_white << " eggs and ham."
The header file has stream manipulators to set background colors (those are the ones starting with
bg_) and to set foreground colors (the ones prefixed with
fg_). Additionally, I created a manipulator to clear the screen (
This is the list of available manipulators:
Points of Interest
iostreammanipulators are easy to implement because the most important part has already been done by the standardization committee when they included the
basic_ostream& operator<<( basic_ostream& (*pf)(basic_ostream&)); overload in the standard. Thus, any function with the correct signature can be used as an stream manipulator:
std::ostream& Copyleft( std::ostream& os )
os << "(L)2004 by EgoTripper";
cout << Copyleft << endl;
- December 2004: First published
- November 2009: Article updated