source: src/UIElements/Views/Qt4/QDebugStream.hpp

Candidate_v1.6.1
Last change on this file was ec8471, checked in by Frederik Heber <heber@…>, 9 years ago

FIX: QtLogBox is again included and working thread-safe.

  • QDebugStream is now appending text to QtLogBox in a thread-safe manner by using signal/slots. This code is taken from qt-forum.de.
  • Property mode set to 100644
File size: 2.0 KB
RevLine 
[e0b5f0]1/*
2 * QDebugStream.hpp
3 *
4 * Created on: Jun 19, 2014
5 * Author: heber
6 */
7
8#ifndef QDEBUGSTREAM_HPP_
9#define QDEBUGSTREAM_HPP_
10
11// include config.h
12#ifdef HAVE_CONFIG_H
13#include <config.h>
14#endif
15
[ec8471]16#include <QObject>
17#include <QPlainTextEdit>
[9737db]18#include <QMutex>
[e0b5f0]19
[ec8471]20/**
21 * Taken from http://www.qtforum.de/forum/viewtopic.php?t=7970
[e0b5f0]22 */
[ec8471]23class QDebugStream : public QObject, std::basic_streambuf<char>{
24
25 Q_OBJECT
26
27signals:
28 void sendString(QString text);
29
[e0b5f0]30public:
[ec8471]31 QDebugStream(std::ostream &stream, QPlainTextEdit* text_edit) : m_stream(stream){
32 log_window = text_edit;
33 m_old_buf = stream.rdbuf();
34 stream.rdbuf(this);
35
36 connect(this, SIGNAL(sendString(QString)), text_edit, SLOT(appendPlainText (QString)));
37 }
38 ~QDebugStream(){
39 // output anything that is left
40 if (!m_string.empty())
41 emit sendString(m_string.c_str());
42 //log_window->appendPlainText(m_string.c_str());
43 m_stream.rdbuf(m_old_buf);
44 }
[e0b5f0]45
46protected:
[ec8471]47 virtual int_type overflow(int_type v){
48 mutex.lock();
49 if (v == '\n'){
50 emit sendString(m_string.c_str());
51 //log_window->appendPlainText(m_string.c_str());
52 m_string.erase(m_string.begin(), m_string.end());
[e0b5f0]53 }
[ec8471]54 else
55 m_string += v;
[e0b5f0]56
[ec8471]57 mutex.unlock();
58 return v;
59 }
[e0b5f0]60
[ec8471]61 virtual std::streamsize xsputn(const char *p, std::streamsize n){
62 mutex.lock();
63
64 m_string.append(p, p + n);
65 size_t pos = 0;
66 while (pos != std::string::npos){
67 pos = m_string.find('\n');
68 if (pos != std::string::npos){
69 std::string tmp(m_string.begin(), m_string.begin() + pos);
70 emit sendString(tmp.c_str());
71 //log_window->appendPlainText(tmp.c_str());
72 m_string.erase(m_string.begin(), m_string.begin() + pos + 1);
73 }
74 }
[e0b5f0]75
[ec8471]76 mutex.unlock();
77 return n;
78 }
[9737db]79
[ec8471]80private:
81 std::ostream &m_stream;
82 std::streambuf *m_old_buf;
83 std::string m_string;
84 QPlainTextEdit* log_window;
85 QMutex mutex;
[e0b5f0]86};
87
[ec8471]88
89#endif // QDEBUGSTREAM_HPP
Note: See TracBrowser for help on using the repository browser.