diff options
author | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
---|---|---|
committer | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
commit | bd9e6617827818fd043452c08c606f07b78014a0 (patch) | |
tree | 425bb4c3168f9c02f10150f235d2cb998dcc6108 /cervisia/protocolview.cpp | |
download | tdesdk-bd9e6617827818fd043452c08c606f07b78014a0.tar.gz tdesdk-bd9e6617827818fd043452c08c606f07b78014a0.zip |
Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features.
BUG:215923
git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdesdk@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'cervisia/protocolview.cpp')
-rw-r--r-- | cervisia/protocolview.cpp | 196 |
1 files changed, 196 insertions, 0 deletions
diff --git a/cervisia/protocolview.cpp b/cervisia/protocolview.cpp new file mode 100644 index 00000000..8496b983 --- /dev/null +++ b/cervisia/protocolview.cpp @@ -0,0 +1,196 @@ +/* + * Copyright (C) 1999-2002 Bernd Gehrmann + * bernd@physik.hu-berlin.de + * Copyright (c) 2003-2004 Christian Loose <christian.loose@kdemail.net> + * + * This program 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. + */ + + +#include "protocolview.h" + +#include <qdir.h> +#include <qpopupmenu.h> +#include <dcopref.h> +#include <kconfig.h> +#include <klocale.h> +#include <kmessagebox.h> + +#include "cervisiapart.h" +#include "cvsjob_stub.h" + + +ProtocolView::ProtocolView(const QCString& appId, QWidget *parent, const char *name) + : QTextEdit(parent, name) + , job(0) + , m_isUpdateJob(false) +{ + setReadOnly(true); + setUndoRedoEnabled(false); + setTabChangesFocus(true); + setTextFormat(Qt::LogText); + + KConfig *config = CervisiaPart::config(); + config->setGroup("LookAndFeel"); + setFont(config->readFontEntry("ProtocolFont")); + + config->setGroup("Colors"); + QColor defaultColor = QColor(255, 130, 130); + conflictColor=config->readColorEntry("Conflict",&defaultColor); + defaultColor=QColor(130, 130, 255); + localChangeColor=config->readColorEntry("LocalChange",&defaultColor); + defaultColor=QColor(70, 210, 70); + remoteChangeColor=config->readColorEntry("RemoteChange",&defaultColor); + + // create a DCOP stub for the non-concurrent cvs job + job = new CvsJob_stub(appId, "NonConcurrentJob"); + + // establish connections to the signals of the cvs job + connectDCOPSignal(job->app(), job->obj(), "jobExited(bool, int)", + "slotJobExited(bool, int)", true); + connectDCOPSignal(job->app(), job->obj(), "receivedStdout(QString)", + "slotReceivedOutput(QString)", true); + connectDCOPSignal(job->app(), job->obj(), "receivedStderr(QString)", + "slotReceivedOutput(QString)", true); +} + + +ProtocolView::~ProtocolView() +{ + delete job; +} + + +bool ProtocolView::startJob(bool isUpdateJob) +{ + m_isUpdateJob = isUpdateJob; + + // get command line and add it to output buffer + QString cmdLine = job->cvsCommand(); + buf += cmdLine; + buf += '\n'; + processOutput(); + + // disconnect 3rd party slots from our signals + disconnect( SIGNAL(receivedLine(QString)) ); + disconnect( SIGNAL(jobFinished(bool, int)) ); + + return job->execute(); +} + + +QPopupMenu* ProtocolView::createPopupMenu(const QPoint &pos) +{ + QPopupMenu* menu = QTextEdit::createPopupMenu(pos); + + int id = menu->insertItem(i18n("Clear"), this, SLOT( clear() ), 0, -1, 0); + + if( length() == 0 ) + menu->setItemEnabled(id, false); + + return menu; +} + + +void ProtocolView::cancelJob() +{ + job->cancel(); +} + + +void ProtocolView::slotReceivedOutput(QString buffer) +{ + buf += buffer; + processOutput(); +} + + +void ProtocolView::slotJobExited(bool normalExit, int exitStatus) +{ + QString msg; + + if( normalExit ) + { + if( exitStatus ) + msg = i18n("[Exited with status %1]\n").arg(exitStatus); + else + msg = i18n("[Finished]\n"); + } + else + msg = i18n("[Aborted]\n"); + + buf += '\n'; + buf += msg; + processOutput(); + + emit jobFinished(normalExit, exitStatus); +} + + +void ProtocolView::processOutput() +{ + int pos; + while ( (pos = buf.find('\n')) != -1) + { + QString line = buf.left(pos); + if (!line.isEmpty()) + { + appendLine(line); + emit receivedLine(line); + } + buf = buf.right(buf.length()-pos-1); + } +} + + +void ProtocolView::appendLine(const QString &line) +{ + // Escape output line, so that html tags in commit + // messages aren't interpreted + const QString escapedLine = QStyleSheet::escape(line); + + // When we don't get the output from an update job then + // just add it to the text edit. + if( !m_isUpdateJob ) + { + append(escapedLine); + return; + } + + QColor color; + // Colors are the same as in UpdateViewItem::paintCell() + if (line.startsWith("C ")) + color = conflictColor; + else if (line.startsWith("M ") + || line.startsWith("A ") || line.startsWith("R ")) + color = localChangeColor; + else if (line.startsWith("P ") || line.startsWith("U ")) + color = remoteChangeColor; + + append(color.isValid() + ? QString("<font color=\"%1\"><b>%2</b></font>").arg(color.name()) + .arg(escapedLine) + : escapedLine); +} + + +#include "protocolview.moc" + + +// Local Variables: +// c-basic-offset: 4 +// End: + + |