vcsbase: move VCSBaseClient's private slots in its pimpl

Change-Id: Ic9bd8d75d3985538c686fdd632a6ce5993997fc6
Merge-request: 358
Reviewed-by: Tobias Hunger <tobias.hunger@nokia.com>
Reviewed-on: http://codereview.qt.nokia.com/3334
This commit is contained in:
cerf
2011-08-22 15:33:02 +00:00
committed by Tobias Hunger
parent 652312347d
commit 96819ddb7a
2 changed files with 52 additions and 46 deletions

View File

@@ -81,20 +81,58 @@ namespace VCSBase {
class VCSBaseClientPrivate class VCSBaseClientPrivate
{ {
public: public:
explicit VCSBaseClientPrivate(VCSBaseClientSettings *settings); VCSBaseClientPrivate(VCSBaseClient *client, VCSBaseClientSettings *settings);
void statusParser(QByteArray data);
void annotateRevision(QString source, QString change, int lineNumber);
void saveSettings();
VCSJobRunner *m_jobManager; VCSJobRunner *m_jobManager;
Core::ICore *m_core; Core::ICore *m_core;
VCSBaseClientSettings* m_clientSettings; VCSBaseClientSettings *m_clientSettings;
private:
VCSBaseClient *m_client;
}; };
VCSBaseClientPrivate::VCSBaseClientPrivate(VCSBaseClientSettings *settings) : VCSBaseClientPrivate::VCSBaseClientPrivate(VCSBaseClient *client, VCSBaseClientSettings *settings) :
m_jobManager(0), m_core(Core::ICore::instance()), m_clientSettings(settings) m_jobManager(0), m_core(Core::ICore::instance()), m_clientSettings(settings), m_client(client)
{ {
} }
void VCSBaseClientPrivate::statusParser(QByteArray data)
{
QList<QPair<QString, QString> > statusList;
QStringList rawStatusList = QTextCodec::codecForLocale()->toUnicode(data).split(QLatin1Char('\n'));
foreach (const QString &string, rawStatusList) {
QPair<QString, QString> status = m_client->parseStatusLine(string);
if (!status.first.isEmpty() && !status.second.isEmpty())
statusList.append(status);
}
emit m_client->parsedStatus(statusList);
}
void VCSBaseClientPrivate::annotateRevision(QString source, QString change, int lineNumber)
{
// This might be invoked with a verbose revision description
// "SHA1 author subject" from the annotation context menu. Strip the rest.
const int blankPos = change.indexOf(QLatin1Char(' '));
if (blankPos != -1)
change.truncate(blankPos);
const QFileInfo fi(source);
m_client->annotate(fi.absolutePath(), fi.fileName(), change, lineNumber);
}
void VCSBaseClientPrivate::saveSettings()
{
m_clientSettings->writeSettings(m_core->settings());
}
VCSBaseClient::VCSBaseClient(VCSBaseClientSettings *settings) : VCSBaseClient::VCSBaseClient(VCSBaseClientSettings *settings) :
d(new VCSBaseClientPrivate(settings)) d(new VCSBaseClientPrivate(this, settings))
{ {
qRegisterMetaType<QVariant>(); qRegisterMetaType<QVariant>();
connect(d->m_core, SIGNAL(saveSettingsRequested()), this, SLOT(saveSettings())); connect(d->m_core, SIGNAL(saveSettingsRequested()), this, SLOT(saveSettings()));
@@ -240,24 +278,6 @@ Utils::SynchronousProcessResponse VCSBaseClient::vcsSynchronousExec(
flags, outputCodec); flags, outputCodec);
} }
void VCSBaseClient::slotAnnotateRevisionRequested(const QString &source,
QString change,
int lineNumber)
{
// This might be invoked with a verbose revision description
// "SHA1 author subject" from the annotation context menu. Strip the rest.
const int blankPos = change.indexOf(QLatin1Char(' '));
if (blankPos != -1)
change.truncate(blankPos);
const QFileInfo fi(source);
annotate(fi.absolutePath(), fi.fileName(), change, lineNumber);
}
void VCSBaseClient::saveSettings()
{
d->m_clientSettings->writeSettings(d->m_core->settings());
}
void VCSBaseClient::annotate(const QString &workingDir, const QString &file, void VCSBaseClient::annotate(const QString &workingDir, const QString &file,
const QString revision /* = QString() */, const QString revision /* = QString() */,
int lineNumber /* = -1 */) int lineNumber /* = -1 */)
@@ -372,8 +392,7 @@ void VCSBaseClient::statusWithSignal(const QString &repositoryRoot)
QStringList args(vcsCommandString(StatusCommand)); QStringList args(vcsCommandString(StatusCommand));
args << statusArguments(QString()); args << statusArguments(QString());
QSharedPointer<VCSJob> job(new VCSJob(repositoryRoot, args, VCSJob::RawDataEmitMode)); QSharedPointer<VCSJob> job(new VCSJob(repositoryRoot, args, VCSJob::RawDataEmitMode));
connect(job.data(), SIGNAL(rawData(QByteArray)), connect(job.data(), SIGNAL(rawData(QByteArray)), this, SLOT(statusParser(QByteArray)));
this, SLOT(statusParser(QByteArray)));
enqueueJob(job); enqueueJob(job);
} }
@@ -399,21 +418,6 @@ QString VCSBaseClient::vcsCommandString(VCSCommand cmd) const
return QString(); return QString();
} }
void VCSBaseClient::statusParser(const QByteArray &data)
{
QList<QPair<QString, QString> > statusList;
QStringList rawStatusList = QTextCodec::codecForLocale()->toUnicode(data).split(QLatin1Char('\n'));
foreach (const QString &string, rawStatusList) {
QPair<QString, QString> status = parseStatusLine(string);
if (!status.first.isEmpty() && !status.second.isEmpty())
statusList.append(status);
}
emit parsedStatus(statusList);
}
void VCSBaseClient::import(const QString &repositoryRoot, const QStringList &files) void VCSBaseClient::import(const QString &repositoryRoot, const QStringList &files)
{ {
QStringList args(vcsCommandString(ImportCommand)); QStringList args(vcsCommandString(ImportCommand));
@@ -521,7 +525,7 @@ VCSBase::VCSBaseEditorWidget *VCSBaseClient::createVCSEditor(const QString &kind
outputEditor->file()->setProperty(registerDynamicProperty, dynamicPropertyValue); outputEditor->file()->setProperty(registerDynamicProperty, dynamicPropertyValue);
baseEditor = VCSBase::VCSBaseEditorWidget::getVcsBaseEditor(outputEditor); baseEditor = VCSBase::VCSBaseEditorWidget::getVcsBaseEditor(outputEditor);
connect(baseEditor, SIGNAL(annotateRevisionRequested(QString,QString,int)), connect(baseEditor, SIGNAL(annotateRevisionRequested(QString,QString,int)),
this, SLOT(slotAnnotateRevisionRequested(QString,QString,int))); this, SLOT(annotateRevision(QString,QString,int)));
QTC_ASSERT(baseEditor, return 0); QTC_ASSERT(baseEditor, return 0);
baseEditor->setSource(source); baseEditor->setSource(source);
if (setSourceCodec) if (setSourceCodec)
@@ -546,3 +550,5 @@ void VCSBaseClient::enqueueJob(const QSharedPointer<VCSJob> &job)
} }
} // namespace VCSBase } // namespace VCSBase
#include "moc_vcsbaseclient.cpp"

View File

@@ -185,13 +185,13 @@ protected:
const char *registerDynamicProperty, const char *registerDynamicProperty,
const QString &dynamicPropertyValue) const; const QString &dynamicPropertyValue) const;
private slots:
void statusParser(const QByteArray &data);
void slotAnnotateRevisionRequested(const QString &source, QString change, int lineNumber);
void saveSettings();
private: private:
friend class VCSBaseClientPrivate;
QScopedPointer<VCSBaseClientPrivate> d; QScopedPointer<VCSBaseClientPrivate> d;
Q_PRIVATE_SLOT(d, void statusParser(QByteArray))
Q_PRIVATE_SLOT(d, void annotateRevision(QString, QString, int))
Q_PRIVATE_SLOT(d, void saveSettings())
}; };
} //namespace VCSBase } //namespace VCSBase