我需要在main()执行结束时检查发送到stdout(通过std::cout
)的最后一个char是'\n'
(或特定于平台的行尾)。如何测试呢?可以安全地假设没有使用C样式io(如printf)。
程序是C ++的REPL。它评估C ++表达式(或语句)并在stdout上打印结果。希望输出总是以单个换行符终止。
答案 0 :(得分:3)
您可以定义自己的类似于流的对象,而不是打印到cout
,它可以接受标准的ostream
运算符/函数,但会在通过操作时跟踪最近打印的字符。真正的cout
。
答案 1 :(得分:3)
这是@Kevin给出的类似答案。但是我相信它对你的需求更好。而不是使用一些你的流代替cout - 你可以用你自己的std :: cout替换streambuf:
int main() {
std::streambuf* cbuf = std::cout.rdbuf(); // back up cout's streambuf
std::cout.flush();
keep_last_char_outbuf keep_last_buf(cbuf);
std::cout.rdbuf(&keep_last_buf); // assign your streambuf to cout
std::cout << "ala ma kota\n";
char last_char = keep_last_buf.get_last_char();
if (last_char == '\r' || last_char == '\n')
std::cout << "\nLast char was newline: " << int(last_char) << "\n";
else
std::cout << "\nLast char: '" << last_char << "'\n";
std::cout << "ala ma kota";
last_char = keep_last_buf.get_last_char();
if (last_char == '\r' || last_char == '\n')
std::cout << "\nLast char was newline: " << int(last_char) << "\n";
else
std::cout << "\nLast char: '" << last_char << "'\n";
std::cout.rdbuf(cbuf); // restore cout's original streambuf
}
预期产量:
ala ma kota
Last char was newline: 10
ala ma kota
Last char: 'a'
编写此类class keep_last_char_outbuf
的任务并不容易,查找装饰器模式和streambuf接口。
如果您没有时间玩这个 - 请查看我的提案ideone link
class keep_last_char_outbuf : public std::streambuf {
public:
keep_last_char_outbuf(std::streambuf* buf) : buf(buf), last_char(traits_type::eof()) {
// no buffering, overflow on every char
setp(0, 0);
}
char get_last_char() const { return last_char; }
virtual int_type overflow(int_type c) {
buf->sputc(c);
last_char = c;
return c;
}
private:
std::streambuf* buf;
char last_char;
};