fork download
  1. #include <iostream>
  2. #include <string>
  3. #include <memory>
  4. #include <ostream>
  5.  
  6.  
  7. namespace console
  8. {
  9.  
  10.  
  11. class ReplaceBuffer : public std::streambuf
  12. {
  13. public:
  14. ReplaceBuffer(std::streambuf*);
  15.  
  16. std::streamsize xsputn(const char*, std::streamsize);
  17.  
  18. size_t getLastLineSize() const;
  19.  
  20. private:
  21. std::streambuf* buffer;
  22. size_t _lastLineSize = 0;
  23. };
  24.  
  25.  
  26. struct Erase {};
  27. extern Erase erase;
  28.  
  29.  
  30. class Logger : public std::ostream
  31. {
  32. public:
  33. Logger(std::streambuf*);
  34.  
  35. void erase(size_t = 0);
  36.  
  37. typedef Logger&(*LoggerManipulator)(Logger&);
  38. Logger& operator<<(LoggerManipulator);
  39.  
  40. private:
  41. ReplaceBuffer _buffer;
  42.  
  43. friend Logger& operator<<(Logger&, const Erase&);
  44.  
  45. friend Logger& endl(Logger&);
  46. friend Logger& flush(Logger&);
  47. };
  48.  
  49.  
  50. Logger& operator<<(Logger&, const Erase&);
  51.  
  52.  
  53. Logger& endl(Logger&);
  54. Logger& flush(Logger&);
  55.  
  56. extern Logger cout;
  57. extern Logger cerr;
  58.  
  59. }
  60.  
  61. console::Erase console::erase;
  62. console::Logger console::cout(std::cout.rdbuf());
  63. console::Logger console::cerr(std::cerr.rdbuf());
  64.  
  65.  
  66. console::ReplaceBuffer::ReplaceBuffer(std::streambuf* buffer)
  67. : buffer(buffer)
  68. {
  69. }
  70.  
  71.  
  72. std::streamsize console::ReplaceBuffer::xsputn(const char* s, std::streamsize n)
  73. {
  74. for (std::streamsize i = 0; i < n; ++i) {
  75. if (s[i] != '\n') {
  76. ++_lastLineSize;
  77. } else {
  78. _lastLineSize = 0;
  79. }
  80. }
  81. buffer->sputn(s, n);
  82. return n;
  83. }
  84.  
  85.  
  86. size_t console::ReplaceBuffer::getLastLineSize() const
  87. {
  88. return _lastLineSize;
  89. }
  90.  
  91.  
  92. console::Logger::Logger(std::streambuf* buf)
  93. : std::ostream()
  94. , _buffer(ReplaceBuffer(buf))
  95. {
  96. std::ostream::rdbuf(&_buffer);
  97. }
  98.  
  99. void console::Logger::erase(size_t size)
  100. {
  101. if (size == 0 || size > _buffer.getLastLineSize()) {
  102. size = _buffer.getLastLineSize();
  103. }
  104.  
  105. // go back
  106. for (size_t i = 0; i < size; ++i) {
  107. std::ostream::operator<<('\b');
  108. }
  109. // replace by space
  110. for (size_t i = 0; i < size; ++i) {
  111. std::ostream::operator<<(' ');
  112. }
  113. // go back again
  114. for (size_t i = 0; i < size; ++i) {
  115. std::ostream::operator<<('\b');
  116. }
  117. }
  118.  
  119.  
  120. console::Logger& console::Logger::operator<<(LoggerManipulator manip)
  121. {
  122. return manip(*this);
  123. }
  124.  
  125.  
  126. console::Logger& console::operator<<(Logger& log, const Erase&)
  127. {
  128. log.erase(0);
  129. return log;
  130. }
  131.  
  132.  
  133. console::Logger& console::endl(Logger& log)
  134. {
  135. log.put('\n');
  136. log.flush();
  137. return log;
  138. }
  139.  
  140.  
  141. console::Logger& console::flush(Logger& log)
  142. {
  143. log.flush();
  144. return log;
  145. }
  146.  
  147.  
  148. int main(int, char**)
  149. {
  150. console::cout << "hello" << 1 << console::erase << "hey" << console::endl
  151. << "three" << console::erase << "two" << console::endl;
  152.  
  153. // relevant error is :
  154. // note: candidate function not viable: cannot bind base class object of type '__ostream_type' (aka 'basic_ostream<char, std::char_traits<char> >') to derived
  155. // class reference 'console::Logger &' for 1st argument
  156. // Logger& operator<<(Logger&, const Erase&)
  157. }
Compilation error #stdin compilation error #stdout 0s 0KB
stdin
Standard input is empty
compilation info
prog.cpp: In function 'int main(int, char**)':
prog.cpp:150:32: error: no match for 'operator<<' (operand types are 'std::basic_ostream<char>' and 'console::Erase')
  console::cout << "hello" << 1 << console::erase << "hey" << console::endl                                                                                                                                    
                                ^
In file included from /usr/include/c++/5/iostream:39:0,
                 from prog.cpp:1:
/usr/include/c++/5/ostream:108:7: note: candidate: std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(std::basic_ostream<_CharT, _Traits>::__ostream_type& (*)(std::basic_ostream<_CharT, _Traits>::__ostream_type&)) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]
       operator<<(__ostream_type& (*__pf)(__ostream_type&))
       ^
/usr/include/c++/5/ostream:108:7: note:   no known conversion for argument 1 from 'console::Erase' to 'std::basic_ostream<char>::__ostream_type& (*)(std::basic_ostream<char>::__ostream_type&) {aka std::basic_ostream<char>& (*)(std::basic_ostream<char>&)}'
/usr/include/c++/5/ostream:117:7: note: candidate: std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(std::basic_ostream<_CharT, _Traits>::__ios_type& (*)(std::basic_ostream<_CharT, _Traits>::__ios_type&)) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>; std::basic_ostream<_CharT, _Traits>::__ios_type = std::basic_ios<char>]
       operator<<(__ios_type& (*__pf)(__ios_type&))
       ^
/usr/include/c++/5/ostream:117:7: note:   no known conversion for argument 1 from 'console::Erase' to 'std::basic_ostream<char>::__ios_type& (*)(std::basic_ostream<char>::__ios_type&) {aka std::basic_ios<char>& (*)(std::basic_ios<char>&)}'
/usr/include/c++/5/ostream:127:7: note: candidate: std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(std::ios_base& (*)(std::ios_base&)) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]
       operator<<(ios_base& (*__pf) (ios_base&))
       ^
/usr/include/c++/5/ostream:127:7: note:   no known conversion for argument 1 from 'console::Erase' to 'std::ios_base& (*)(std::ios_base&)'
/usr/include/c++/5/ostream:166:7: note: candidate: std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(long int) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]
       operator<<(long __n)
       ^
/usr/include/c++/5/ostream:166:7: note:   no known conversion for argument 1 from 'console::Erase' to 'long int'
/usr/include/c++/5/ostream:170:7: note: candidate: std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(long unsigned int) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]
       operator<<(unsigned long __n)
       ^
/usr/include/c++/5/ostream:170:7: note:   no known conversion for argument 1 from 'console::Erase' to 'long unsigned int'
/usr/include/c++/5/ostream:174:7: note: candidate: std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(bool) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]
       operator<<(bool __n)
       ^
/usr/include/c++/5/ostream:174:7: note:   no known conversion for argument 1 from 'console::Erase' to 'bool'
In file included from /usr/include/c++/5/ostream:638:0,
                 from /usr/include/c++/5/iostream:39,
                 from prog.cpp:1:
/usr/include/c++/5/bits/ostream.tcc:91:5: note: candidate: std::basic_ostream<_CharT, _Traits>& std::basic_ostream<_CharT, _Traits>::operator<<(short int) [with _CharT = char; _Traits = std::char_traits<char>]
     basic_ostream<_CharT, _Traits>::
     ^
/usr/include/c++/5/bits/ostream.tcc:91:5: note:   no known conversion for argument 1 from 'console::Erase' to 'short int'
In file included from /usr/include/c++/5/iostream:39:0,
                 from prog.cpp:1:
/usr/include/c++/5/ostream:181:7: note: candidate: std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(short unsigned int) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]
       operator<<(unsigned short __n)
       ^
/usr/include/c++/5/ostream:181:7: note:   no known conversion for argument 1 from 'console::Erase' to 'short unsigned int'
In file included from /usr/include/c++/5/ostream:638:0,
                 from /usr/include/c++/5/iostream:39,
                 from prog.cpp:1:
/usr/include/c++/5/bits/ostream.tcc:105:5: note: candidate: std::basic_ostream<_CharT, _Traits>& std::basic_ostream<_CharT, _Traits>::operator<<(int) [with _CharT = char; _Traits = std::char_traits<char>]
     basic_ostream<_CharT, _Traits>::
     ^
/usr/include/c++/5/bits/ostream.tcc:105:5: note:   no known conversion for argument 1 from 'console::Erase' to 'int'
In file included from /usr/include/c++/5/iostream:39:0,
                 from prog.cpp:1:
/usr/include/c++/5/ostream:192:7: note: candidate: std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(unsigned int) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]
       operator<<(unsigned int __n)
       ^
/usr/include/c++/5/ostream:192:7: note:   no known conversion for argument 1 from 'console::Erase' to 'unsigned int'
/usr/include/c++/5/ostream:201:7: note: candidate: std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(long long int) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]
       operator<<(long long __n)
       ^
/usr/include/c++/5/ostream:201:7: note:   no known conversion for argument 1 from 'console::Erase' to 'long long int'
/usr/include/c++/5/ostream:205:7: note: candidate: std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(long long unsigned int) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]
       operator<<(unsigned long long __n)
       ^
/usr/include/c++/5/ostream:205:7: note:   no known conversion for argument 1 from 'console::Erase' to 'long long unsigned int'
/usr/include/c++/5/ostream:220:7: note: candidate: std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(double) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]
       operator<<(double __f)
       ^
/usr/include/c++/5/ostream:220:7: note:   no known conversion for argument 1 from 'console::Erase' to 'double'
/usr/include/c++/5/ostream:224:7: note: candidate: std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(float) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]
       operator<<(float __f)
       ^
/usr/include/c++/5/ostream:224:7: note:   no known conversion for argument 1 from 'console::Erase' to 'float'
/usr/include/c++/5/ostream:232:7: note: candidate: std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(long double) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]
       operator<<(long double __f)
       ^
/usr/include/c++/5/ostream:232:7: note:   no known conversion for argument 1 from 'console::Erase' to 'long double'
/usr/include/c++/5/ostream:245:7: note: candidate: std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(const void*) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__ostream_type = std::basic_ostream<char>]
       operator<<(const void* __p)
       ^
/usr/include/c++/5/ostream:245:7: note:   no known conversion for argument 1 from 'console::Erase' to 'const void*'
In file included from /usr/include/c++/5/ostream:638:0,
                 from /usr/include/c++/5/iostream:39,
                 from prog.cpp:1:
/usr/include/c++/5/bits/ostream.tcc:119:5: note: candidate: std::basic_ostream<_CharT, _Traits>& std::basic_ostream<_CharT, _Traits>::operator<<(std::basic_ostream<_CharT, _Traits>::__streambuf_type*) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_ostream<_CharT, _Traits>::__streambuf_type = std::basic_streambuf<char>]
     basic_ostream<_CharT, _Traits>::
     ^
/usr/include/c++/5/bits/ostream.tcc:119:5: note:   no known conversion for argument 1 from 'console::Erase' to 'std::basic_ostream<char>::__streambuf_type* {aka std::basic_streambuf<char>*}'
In file included from /usr/include/c++/5/memory:82:0,
                 from prog.cpp:3:
/usr/include/c++/5/bits/shared_ptr.h:66:5: note: candidate: template<class _Ch, class _Tr, class _Tp, __gnu_cxx::_Lock_policy _Lp> std::basic_ostream<_CharT, _Traits>& std::operator<<(std::basic_ostream<_CharT, _Traits>&, const std::__shared_ptr<_Tp, _Lp>&)
     operator<<(std::basic_ostream<_Ch, _Tr>& __os,
     ^
/usr/include/c++/5/bits/shared_ptr.h:66:5: note:   template argument deduction/substitution failed:
prog.cpp:150:44: note:   'console::Erase' is not derived from 'const std::__shared_ptr<_Tp, _Lp>'
  console::cout << "hello" << 1 << console::erase << "hey" << console::endl                                                                                                                                    
                                            ^
In file included from /usr/include/c++/5/iostream:39:0,
                 from prog.cpp:1:
/usr/include/c++/5/ostream:628:5: note: candidate: std::basic_ostream<_CharT, _Traits>& std::operator<<(std::basic_ostream<_CharT, _Traits>&&, const _Tp&) [with _CharT = char; _Traits = std::char_traits<char>; _Tp = console::Erase] <near match>
     operator<<(basic_ostream<_CharT, _Traits>&& __os, const _Tp& __x)
     ^
/usr/include/c++/5/ostream:628:5: note:   conversion of argument 1 would be ill-formed:
prog.cpp:150:27: error: cannot bind 'std::basic_ostream<char>' lvalue to 'std::basic_ostream<char>&&'
  console::cout << "hello" << 1 << console::erase << "hey" << console::endl                                                                                                                                    
                           ^
In file included from /usr/include/c++/5/iostream:39:0,
                 from prog.cpp:1:
/usr/include/c++/5/ostream:574:5: note: candidate: template<class _Traits> std::basic_ostream<char, _Traits>& std::operator<<(std::basic_ostream<char, _Traits>&, const unsigned char*)
     operator<<(basic_ostream<char, _Traits>& __out, const unsigned char* __s)
     ^
/usr/include/c++/5/ostream:574:5: note:   template argument deduction/substitution failed:
prog.cpp:150:44: note:   cannot convert 'console::erase' (type 'console::Erase') to type 'const unsigned char*'
  console::cout << "hello" << 1 << console::erase << "hey" << console::endl                                                                                                                                    
                                            ^
In file included from /usr/include/c++/5/iostream:39:0,
                 from prog.cpp:1:
/usr/include/c++/5/ostream:569:5: note: candidate: template<class _Traits> std::basic_ostream<char, _Traits>& std::operator<<(std::basic_ostream<char, _Traits>&, const signed char*)
     operator<<(basic_ostream<char, _Traits>& __out, const signed char* __s)
     ^
/usr/include/c++/5/ostream:569:5: note:   template argument deduction/substitution failed:
prog.cpp:150:44: note:   cannot convert 'console::erase' (type 'console::Erase') to type 'const signed char*'
  console::cout << "hello" << 1 << console::erase << "hey" << console::endl                                                                                                                                    
                                            ^
In file included from /usr/include/c++/5/iostream:39:0,
                 from prog.cpp:1:
/usr/include/c++/5/ostream:556:5: note: candidate: template<class _Traits> std::basic_ostream<char, _Traits>& std::operator<<(std::basic_ostream<char, _Traits>&, const char*)
     operator<<(basic_ostream<char, _Traits>& __out, const char* __s)
     ^
/usr/include/c++/5/ostream:556:5: note:   template argument deduction/substitution failed:
prog.cpp:150:44: note:   cannot convert 'console::erase' (type 'console::Erase') to type 'const char*'
  console::cout << "hello" << 1 << console::erase << "hey" << console::endl                                                                                                                                    
                                            ^
In file included from /usr/include/c++/5/ostream:638:0,
                 from /usr/include/c++/5/iostream:39,
                 from prog.cpp:1:
/usr/include/c++/5/bits/ostream.tcc:321:5: note: candidate: template<class _CharT, class _Traits> std::basic_ostream<_CharT, _Traits>& std::operator<<(std::basic_ostream<_CharT, _Traits>&, const char*)
     operator<<(basic_ostream<_CharT, _Traits>& __out, const char* __s)
     ^
/usr/include/c++/5/bits/ostream.tcc:321:5: note:   template argument deduction/substitution failed:
prog.cpp:150:44: note:   cannot convert 'console::erase' (type 'console::Erase') to type 'const char*'
  console::cout << "hello" << 1 << console::erase << "hey" << console::endl                                                                                                                                    
                                            ^
In file included from /usr/include/c++/5/iostream:39:0,
                 from prog.cpp:1:
/usr/include/c++/5/ostream:539:5: note: candidate: template<class _CharT, class _Traits> std::basic_ostream<_CharT, _Traits>& std::operator<<(std::basic_ostream<_CharT, _Traits>&, const _CharT*)
     operator<<(basic_ostream<_CharT, _Traits>& __out, const _CharT* __s)
     ^
/usr/include/c++/5/ostream:539:5: note:   template argument deduction/substitution failed:
prog.cpp:150:44: note:   mismatched types 'const _CharT*' and 'console::Erase'
  console::cout << "hello" << 1 << console::erase << "hey" << console::endl                                                                                                                                    
                                            ^
In file included from /usr/include/c++/5/iostream:39:0,
                 from prog.cpp:1:
/usr/include/c++/5/ostream:519:5: note: candidate: template<class _Traits> std::basic_ostream<char, _Traits>& std::operator<<(std::basic_ostream<char, _Traits>&, unsigned char)
     operator<<(basic_ostream<char, _Traits>& __out, unsigned char __c)
     ^
/usr/include/c++/5/ostream:519:5: note:   template argument deduction/substitution failed:
prog.cpp:150:44: note:   cannot convert 'console::erase' (type 'console::Erase') to type 'unsigned char'
  console::cout << "hello" << 1 << console::erase << "hey" << console::endl                                                                                                                                    
                                            ^
In file included from /usr/include/c++/5/iostream:39:0,
                 from prog.cpp:1:
/usr/include/c++/5/ostream:514:5: note: candidate: template<class _Traits> std::basic_ostream<char, _Traits>& std::operator<<(std::basic_ostream<char, _Traits>&, signed char)
     operator<<(basic_ostream<char, _Traits>& __out, signed char __c)
     ^
/usr/include/c++/5/ostream:514:5: note:   template argument deduction/substitution failed:
prog.cpp:150:44: note:   cannot convert 'console::erase' (type 'console::Erase') to type 'signed char'
  console::cout << "hello" << 1 << console::erase << "hey" << console::endl                                                                                                                                    
                                            ^
In file included from /usr/include/c++/5/iostream:39:0,
                 from prog.cpp:1:
/usr/include/c++/5/ostream:508:5: note: candidate: template<class _Traits> std::basic_ostream<char, _Traits>& std::operator<<(std::basic_ostream<char, _Traits>&, char)
     operator<<(basic_ostream<char, _Traits>& __out, char __c)
     ^
/usr/include/c++/5/ostream:508:5: note:   template argument deduction/substitution failed:
prog.cpp:150:44: note:   cannot convert 'console::erase' (type 'console::Erase') to type 'char'
  console::cout << "hello" << 1 << console::erase << "hey" << console::endl                                                                                                                                    
                                            ^
In file included from /usr/include/c++/5/iostream:39:0,
                 from prog.cpp:1:
/usr/include/c++/5/ostream:502:5: note: candidate: template<class _CharT, class _Traits> std::basic_ostream<_CharT, _Traits>& std::operator<<(std::basic_ostream<_CharT, _Traits>&, char)
     operator<<(basic_ostream<_CharT, _Traits>& __out, char __c)
     ^
/usr/include/c++/5/ostream:502:5: note:   template argument deduction/substitution failed:
prog.cpp:150:44: note:   cannot convert 'console::erase' (type 'console::Erase') to type 'char'
  console::cout << "hello" << 1 << console::erase << "hey" << console::endl                                                                                                                                    
                                            ^
In file included from /usr/include/c++/5/iostream:39:0,
                 from prog.cpp:1:
/usr/include/c++/5/ostream:497:5: note: candidate: template<class _CharT, class _Traits> std::basic_ostream<_CharT, _Traits>& std::operator<<(std::basic_ostream<_CharT, _Traits>&, _CharT)
     operator<<(basic_ostream<_CharT, _Traits>& __out, _CharT __c)
     ^
/usr/include/c++/5/ostream:497:5: note:   template argument deduction/substitution failed:
prog.cpp:150:44: note:   deduced conflicting types for parameter '_CharT' ('char' and 'console::Erase')
  console::cout << "hello" << 1 << console::erase << "hey" << console::endl                                                                                                                                    
                                            ^
In file included from /usr/include/c++/5/bits/ios_base.h:46:0,
                 from /usr/include/c++/5/ios:42,
                 from /usr/include/c++/5/ostream:38,
                 from /usr/include/c++/5/iostream:39,
                 from prog.cpp:1:
/usr/include/c++/5/system_error:209:5: note: candidate: template<class _CharT, class _Traits> std::basic_ostream<_CharT, _Traits>& std::operator<<(std::basic_ostream<_CharT, _Traits>&, const std::error_code&)
     operator<<(basic_ostream<_CharT, _Traits>& __os, const error_code& __e)
     ^
/usr/include/c++/5/system_error:209:5: note:   template argument deduction/substitution failed:
prog.cpp:150:44: note:   cannot convert 'console::erase' (type 'console::Erase') to type 'const std::error_code&'
  console::cout << "hello" << 1 << console::erase << "hey" << console::endl                                                                                                                                    
                                            ^
In file included from /usr/include/c++/5/string:52:0,
                 from /usr/include/c++/5/bits/locale_classes.h:40,
                 from /usr/include/c++/5/bits/ios_base.h:41,
                 from /usr/include/c++/5/ios:42,
                 from /usr/include/c++/5/ostream:38,
                 from /usr/include/c++/5/iostream:39,
                 from prog.cpp:1:
/usr/include/c++/5/bits/basic_string.h:5170:5: note: candidate: template<class _CharT, class _Traits, class _Alloc> std::basic_ostream<_CharT, _Traits>& std::operator<<(std::basic_ostream<_CharT, _Traits>&, const std::basic_string<_CharT, _Traits, _Alloc>&)
     operator<<(basic_ostream<_CharT, _Traits>& __os,
     ^
/usr/include/c++/5/bits/basic_string.h:5170:5: note:   template argument deduction/substitution failed:
prog.cpp:150:44: note:   'console::Erase' is not derived from 'const std::basic_string<_CharT, _Traits, _Alloc>'
  console::cout << "hello" << 1 << console::erase << "hey" << console::endl                                                                                                                                    
                                            ^
prog.cpp:126:18: note: candidate: console::Logger& console::operator<<(console::Logger&, const console::Erase&)
 console::Logger& console::operator<<(Logger& log, const Erase&)                                                                                                                                        
                  ^
prog.cpp:126:18: note:   no known conversion for argument 1 from 'std::basic_ostream<char>' to 'console::Logger&'
stdout
Standard output is empty