-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlogtoparent.cpp
69 lines (62 loc) · 3.6 KB
/
logtoparent.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
/******************************************************************************
* *File: logtoparent.cpp *
* *Date: 2013-09-29 *
* *Version: 1.0 *
* *Author(s): Jochen Bauer <[email protected]> *
* Lukas Kern <[email protected]> *
* Carsten Klein <[email protected]> *
* *
* *License information: *
* *
* Copyright (C) [2013] [Jochen Bauer, Lukas Kern, Carsten Klein] *
* *
* This file is part of PLCANALYZER. PLCANALYZER is free software; you can *
* redistribute it and/or modify it under the terms of the GNU General *
* Public License as published by the Free Software Foundation; either *
* version 2 of the License, or (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, but *
* WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU General Public License for more details. *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the Free Software *
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA *
* 02110-1301, USA. *
* *
* *Program name: PLCANALYZER *
* *What this program does: Connects to most SIMATIC S7/S5 Controllers *
* * Reads memory areas *
* * Draws a graph over time for operands *
* *Have fun! *
******************************************************************************/
#include "logtoparent.h"
//construct a redirector for piping the outputs to the
//textedit of the mainwindow
logToParent::logToParent(MainWindow *parent) :
QMainWindow(parent)
{
// See also the destructor description
myRedirector = new stdoutRedirector;
connect(this, SIGNAL(threadTerminator()),myRedirector,SLOT(terminate()));
myRedirector->start();
parentStatbar = parent->ui->statusBar;
parentTextEdit = parent->ui->textEdit;
connect(myRedirector, SIGNAL(writeOut(QString)),
this,SLOT(updateParentLog(QString)));
}
logToParent::~logToParent()
{
emit threadTerminator();
// myRedirector should have been removed here
// unfortunately that leads to hard thread destroying
}
//write the data to the statusbar and the textedit
//statbar will hold text for 2 and a half seconds
void logToParent::updateParentLog(const QString &logString)
{
parentStatbar->showMessage(logString,2500);
parentTextEdit->append(logString);
// debug output with timestamp
qDebug() << QDateTime::currentDateTime().toString("yyyy-mm-dd hh:mm:ss") << "Debug :" << logString;
}