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
|
/*
SPDX-FileCopyrightText: 2012 Olivier de Gaalon <olivier.jg@gmail.com>
SPDX-License-Identifier: LGPL-2.0-only
*/
#include "delayedoutput.h"
#include <QDebug>
#include <QStack>
namespace KDevelop {
using DepthedOutput = QPair<QString, int>;
class DelayedOutputPrivate
{
public:
void flushOutput()
{
while (!output.isEmpty()) {
DepthedOutput curOutput = output.pop();
qDebug().nospace() <<
qPrintable(QString(curOutput.second - 1, QLatin1Char(' '))) << curOutput.first.toUtf8().data();
}
}
QStack<DepthedOutput> output;
int delayDepth;
};
DelayedOutput::Delay::Delay(DelayedOutput* output)
{
m_output = output;
++m_output->d_func()->delayDepth;
}
DelayedOutput::Delay::~Delay()
{
--m_output->d_func()->delayDepth;
if (!m_output->d_func()->delayDepth)
m_output->d_func()->flushOutput();
}
DelayedOutput::DelayedOutput()
: d_ptr(new DelayedOutputPrivate())
{
}
DelayedOutput::~DelayedOutput()
{
}
DelayedOutput& DelayedOutput::self()
{
static DelayedOutput _inst;
return _inst;
}
void DelayedOutput::push(const QString& output)
{
Q_D(DelayedOutput);
d->output.push(DepthedOutput(output, d->delayDepth));
}
}
|