Subversion: Move plugin pimpl to .cpp

Change-Id: I457747564bbe0bc71d009d08b27e2375dd4c073f
Reviewed-by: Orgad Shaneh <orgads@gmail.com>
This commit is contained in:
hjk
2020-01-30 17:02:30 +01:00
parent 1023a1d474
commit 04e45d1bd9
6 changed files with 175 additions and 186 deletions

View File

@@ -49,18 +49,19 @@ class SubversionSettingsPageWidget final : public Core::IOptionsPageWidget
Q_DECLARE_TR_FUNCTIONS(Subversion::Internal::SettingsPageWidget) Q_DECLARE_TR_FUNCTIONS(Subversion::Internal::SettingsPageWidget)
public: public:
SubversionSettingsPageWidget(Core::IVersionControl *control, SubversionSettings *settings); SubversionSettingsPageWidget(const std::function<void()> &onApply, SubversionSettings *settings);
void apply() final; void apply() final;
private: private:
Ui::SettingsPage m_ui; Ui::SettingsPage m_ui;
Core::IVersionControl *m_control; std::function<void()> m_onApply;
SubversionSettings *m_settings; SubversionSettings *m_settings;
}; };
SubversionSettingsPageWidget::SubversionSettingsPageWidget(Core::IVersionControl *control, SubversionSettings *settings) SubversionSettingsPageWidget::SubversionSettingsPageWidget(const std::function<void()> &onApply,
: m_control(control), m_settings(settings) SubversionSettings *settings)
: m_onApply(onApply), m_settings(settings)
{ {
m_ui.setupUi(this); m_ui.setupUi(this);
m_ui.pathChooser->setExpectedKind(PathChooser::ExistingCommand); m_ui.pathChooser->setExpectedKind(PathChooser::ExistingCommand);
@@ -98,16 +99,16 @@ void SubversionSettingsPageWidget::apply()
return; return;
*m_settings = rc; *m_settings = rc;
m_control->configurationChanged(); m_onApply();
} }
SubversionSettingsPage::SubversionSettingsPage(Core::IVersionControl *control, SubversionSettings *settings, QObject *parent) : SubversionSettingsPage::SubversionSettingsPage(const std::function<void()> &onApply, SubversionSettings *settings, QObject *parent) :
Core::IOptionsPage(parent) Core::IOptionsPage(parent)
{ {
setId(VcsBase::Constants::VCS_ID_SUBVERSION); setId(VcsBase::Constants::VCS_ID_SUBVERSION);
setDisplayName(SubversionSettingsPageWidget::tr("Subversion")); setDisplayName(SubversionSettingsPageWidget::tr("Subversion"));
setCategory(VcsBase::Constants::VCS_SETTINGS_CATEGORY); setCategory(VcsBase::Constants::VCS_SETTINGS_CATEGORY);
setWidgetCreator([control, settings] { return new SubversionSettingsPageWidget(control, settings); }); setWidgetCreator([onApply, settings] { return new SubversionSettingsPageWidget(onApply, settings); });
} }
} // Internal } // Internal

View File

@@ -27,8 +27,6 @@
#include <coreplugin/dialogs/ioptionspage.h> #include <coreplugin/dialogs/ioptionspage.h>
namespace Core { class IVersionControl; }
namespace Subversion { namespace Subversion {
namespace Internal { namespace Internal {
@@ -37,7 +35,7 @@ class SubversionSettings;
class SubversionSettingsPage final : public Core::IOptionsPage class SubversionSettingsPage final : public Core::IOptionsPage
{ {
public: public:
SubversionSettingsPage(Core::IVersionControl *control, SubversionSettings *settings, QObject *parent); SubversionSettingsPage(const std::function<void()> &onApply, SubversionSettings *settings, QObject *parent);
}; };
} // namespace Subversion } // namespace Subversion

View File

@@ -172,7 +172,12 @@ class SubversionDiffEditorController : public VcsBaseDiffEditorController
Q_OBJECT Q_OBJECT
public: public:
SubversionDiffEditorController(IDocument *document, SubversionDiffEditorController(IDocument *document,
const QString &workingDirectory); VcsBaseClient *client,
const QString &workingDirectory)
: VcsBaseDiffEditorController(document, client, workingDirectory)
{
forceContextLineCount(3); // SVN cannot change that when using internal diff
}
void setFilesList(const QStringList &filesList); void setFilesList(const QStringList &filesList);
void setChangeNumber(int changeNumber); void setChangeNumber(int changeNumber);
@@ -186,19 +191,11 @@ private:
void requestDiff(); void requestDiff();
enum State { Idle, GettingDescription, GettingDiff }; enum State { Idle, GettingDescription, GettingDiff };
State m_state; State m_state = Idle;
QStringList m_filesList; QStringList m_filesList;
int m_changeNumber = 0; int m_changeNumber = 0;
}; };
SubversionDiffEditorController::SubversionDiffEditorController(
IDocument *document,
const QString &workingDirectory)
: VcsBaseDiffEditorController(document, SubversionPluginPrivate::instance()->client(), workingDirectory)
, m_state(Idle)
{
forceContextLineCount(3); // SVN cannot change that when using internal diff
}
void SubversionDiffEditorController::setFilesList(const QStringList &filesList) void SubversionDiffEditorController::setFilesList(const QStringList &filesList)
{ {
@@ -271,13 +268,13 @@ void SubversionDiffEditorController::processCommandOutput(const QString &output)
SubversionDiffEditorController *SubversionClient::findOrCreateDiffEditor(const QString &documentId, SubversionDiffEditorController *SubversionClient::findOrCreateDiffEditor(const QString &documentId,
const QString &source, const QString &source,
const QString &title, const QString &title,
const QString &workingDirectory) const const QString &workingDirectory)
{ {
IDocument *document = DiffEditorController::findOrCreateDocument(documentId, title); IDocument *document = DiffEditorController::findOrCreateDocument(documentId, title);
auto controller = qobject_cast<SubversionDiffEditorController *>( auto controller = qobject_cast<SubversionDiffEditorController *>(
DiffEditorController::controller(document)); DiffEditorController::controller(document));
if (!controller) if (!controller)
controller = new SubversionDiffEditorController(document, workingDirectory); controller = new SubversionDiffEditorController(document, this, workingDirectory);
VcsBase::setSource(document, source); VcsBase::setSource(document, source);
EditorManager::activateEditorForDocument(document); EditorManager::activateEditorForDocument(document);
return controller; return controller;

View File

@@ -79,7 +79,7 @@ protected:
private: private:
SubversionDiffEditorController *findOrCreateDiffEditor(const QString &documentId, const QString &source, SubversionDiffEditorController *findOrCreateDiffEditor(const QString &documentId, const QString &source,
const QString &title, const QString &workingDirectory) const; const QString &title, const QString &workingDirectory);
mutable Utils::FilePath m_svnVersionBinary; mutable Utils::FilePath m_svnVersionBinary;
mutable QString m_svnVersion; mutable QString m_svnVersion;

View File

@@ -31,6 +31,7 @@
#include "subversionsubmiteditor.h" #include "subversionsubmiteditor.h"
#include "subversionclient.h" #include "subversionclient.h"
#include "subversionconstants.h" #include "subversionconstants.h"
#include "subversionsettings.h"
#include <vcsbase/basevcseditorfactory.h> #include <vcsbase/basevcseditorfactory.h>
#include <vcsbase/vcscommand.h> #include <vcsbase/vcscommand.h>
@@ -38,6 +39,7 @@
#include <vcsbase/basevcssubmiteditorfactory.h> #include <vcsbase/basevcssubmiteditorfactory.h>
#include <vcsbase/vcsbaseconstants.h> #include <vcsbase/vcsbaseconstants.h>
#include <vcsbase/vcsoutputwindow.h> #include <vcsbase/vcsoutputwindow.h>
#include <vcsbase/vcsbaseplugin.h>
#include <texteditor/textdocument.h> #include <texteditor/textdocument.h>
@@ -107,6 +109,14 @@ const char CMD_ID_UPDATE[] = "Subversion.Update";
const char CMD_ID_COMMIT_PROJECT[] = "Subversion.CommitProject"; const char CMD_ID_COMMIT_PROJECT[] = "Subversion.CommitProject";
const char CMD_ID_DESCRIBE[] = "Subversion.Describe"; const char CMD_ID_DESCRIBE[] = "Subversion.Describe";
struct SubversionResponse
{
bool error = false;
QString stdOut;
QString stdErr;
QString message;
};
const VcsBaseEditorParameters editorParameters[] = { const VcsBaseEditorParameters editorParameters[] = {
{ {
LogOutput, LogOutput,
@@ -167,6 +177,8 @@ static inline QStringList svnDirectories()
return rc; return rc;
} }
class SubversionPluginPrivate;
class SubversionTopicCache : public Core::IVersionControl::TopicCache class SubversionTopicCache : public Core::IVersionControl::TopicCache
{ {
public: public:
@@ -175,20 +187,142 @@ public:
{ } { }
protected: protected:
QString trackFile(const QString &repository) override QString trackFile(const QString &repository) override;
{
return m_plugin->monitorFile(repository);
}
QString refreshTopic(const QString &repository) override QString refreshTopic(const QString &repository) override;
{
return m_plugin->synchronousTopic(repository);
}
private: private:
SubversionPluginPrivate *m_plugin; SubversionPluginPrivate *m_plugin;
}; };
class SubversionPluginPrivate final : public VcsBase::VcsBasePluginPrivate
{
Q_DECLARE_TR_FUNCTIONS(Subversion::Internal::SubversionPlugin)
public:
SubversionPluginPrivate();
~SubversionPluginPrivate() final;
// IVersionControl
QString displayName() const final;
Core::Id id() const final;
bool isVcsFileOrDirectory(const Utils::FilePath &fileName) const final;
bool managesDirectory(const QString &directory, QString *topLevel) const final;
bool managesFile(const QString &workingDirectory, const QString &fileName) const final;
bool isConfigured() const final;
bool supportsOperation(Operation operation) const final;
bool vcsOpen(const QString &fileName) final;
bool vcsAdd(const QString &fileName) final;
bool vcsDelete(const QString &filename) final;
bool vcsMove(const QString &from, const QString &to) final;
bool vcsCreateRepository(const QString &directory) final;
bool vcsAnnotate(const QString &file, int line) final;
Core::ShellCommand *createInitialCheckoutCommand(const QString &url,
const Utils::FilePath &baseDirectory,
const QString &localName,
const QStringList &extraArgs) final;
bool isVcsDirectory(const Utils::FilePath &fileName) const;
///
SubversionClient *client();
SubversionSubmitEditor *openSubversionSubmitEditor(const QString &fileName);
// IVersionControl
bool vcsAdd(const QString &workingDir, const QString &fileName);
bool vcsDelete(const QString &workingDir, const QString &fileName);
bool vcsMove(const QString &workingDir, const QString &from, const QString &to);
bool vcsCheckout(const QString &directory, const QByteArray &url);
static SubversionPluginPrivate *instance();
QString monitorFile(const QString &repository) const;
QString synchronousTopic(const QString &repository) const;
SubversionResponse runSvn(const QString &workingDir,
const QStringList &arguments, int timeOutS,
unsigned flags, QTextCodec *outputCodec = nullptr) const;
void describe(const QString &source, const QString &changeNr);
void vcsAnnotateHelper(const QString &workingDir, const QString &file,
const QString &revision = QString(), int lineNumber = -1);
protected:
void updateActions(VcsBase::VcsBasePluginPrivate::ActionState) override;
bool submitEditorAboutToClose() override;
private:
void addCurrentFile();
void revertCurrentFile();
void diffProject();
void diffCurrentFile();
void cleanCommitMessageFile();
void startCommitAll();
void startCommitProject();
void startCommitCurrentFile();
void revertAll();
void filelogCurrentFile();
void annotateCurrentFile();
void projectStatus();
void slotDescribe();
void updateProject();
void commitFromEditor() override;
void diffCommitFiles(const QStringList &);
void logProject();
void logRepository();
void diffRepository();
void statusRepository();
void updateRepository();
inline bool isCommitEditorOpen() const;
Core::IEditor *showOutputInEditor(const QString &title, const QString &output,
int editorType, const QString &source,
QTextCodec *codec);
void filelog(const QString &workingDir,
const QString &file = QString(),
bool enableAnnotationContextMenu = false);
void svnStatus(const QString &workingDir, const QString &relativePath = QString());
void svnUpdate(const QString &workingDir, const QString &relativePath = QString());
bool checkSVNSubDir(const QDir &directory) const;
void startCommit(const QString &workingDir, const QStringList &files = QStringList());
const QStringList m_svnDirectories;
SubversionSettings m_settings;
SubversionClient *m_client = nullptr;
QString m_commitMessageFileName;
QString m_commitRepository;
Core::CommandLocator *m_commandLocator = nullptr;
Utils::ParameterAction *m_addAction = nullptr;
Utils::ParameterAction *m_deleteAction = nullptr;
Utils::ParameterAction *m_revertAction = nullptr;
Utils::ParameterAction *m_diffProjectAction = nullptr;
Utils::ParameterAction *m_diffCurrentAction = nullptr;
Utils::ParameterAction *m_logProjectAction = nullptr;
QAction *m_logRepositoryAction = nullptr;
QAction *m_commitAllAction = nullptr;
QAction *m_revertRepositoryAction = nullptr;
QAction *m_diffRepositoryAction = nullptr;
QAction *m_statusRepositoryAction = nullptr;
QAction *m_updateRepositoryAction = nullptr;
Utils::ParameterAction *m_commitCurrentAction = nullptr;
Utils::ParameterAction *m_filelogCurrentAction = nullptr;
Utils::ParameterAction *m_annotateCurrentAction = nullptr;
Utils::ParameterAction *m_statusProjectAction = nullptr;
Utils::ParameterAction *m_updateProjectAction = nullptr;
Utils::ParameterAction *m_commitProjectAction = nullptr;
QAction *m_describeAction = nullptr;
QAction *m_menuAction = nullptr;
bool m_submitActionTriggered = false;
};
// ------------- SubversionPlugin // ------------- SubversionPlugin
static SubversionPluginPrivate *dd = nullptr; static SubversionPluginPrivate *dd = nullptr;
@@ -252,7 +386,7 @@ SubversionPluginPrivate::SubversionPluginPrivate()
using namespace Core::Constants; using namespace Core::Constants;
Context context(SUBVERSION_CONTEXT); Context context(SUBVERSION_CONTEXT);
new SubversionSettingsPage(this, &m_settings, this); new SubversionSettingsPage([this] { configurationChanged(); }, &m_settings, this);
new VcsSubmitEditorFactory(&submitParameters, new VcsSubmitEditorFactory(&submitParameters,
[]() { return new SubversionSubmitEditor(&submitParameters); }, this); []() { return new SubversionSubmitEditor(&submitParameters); }, this);
@@ -1166,6 +1300,17 @@ Core::ShellCommand *SubversionPluginPrivate::createInitialCheckoutCommand(const
return command; return command;
} }
QString SubversionTopicCache::trackFile(const QString &repository)
{
return m_plugin->monitorFile(repository);
}
QString SubversionTopicCache::refreshTopic(const QString &repository)
{
return m_plugin->synchronousTopic(repository);
}
#ifdef WITH_TESTS #ifdef WITH_TESTS
void SubversionPlugin::testLogResolving() void SubversionPlugin::testLogResolving()
{ {
@@ -1187,6 +1332,7 @@ void SubversionPlugin::testLogResolving()
); );
VcsBaseEditorWidget::testLogResolving(editorParameters[0].id, data, "r1439551", "r1439540"); VcsBaseEditorWidget::testLogResolving(editorParameters[0].id, data, "r1439551", "r1439540");
} }
#endif #endif
} // Internal } // Internal

View File

@@ -25,169 +25,16 @@
#pragma once #pragma once
#include "subversionsettings.h" #include <extensionsystem/iplugin.h>
#include <vcsbase/vcsbaseplugin.h>
#include <QStringList>
QT_BEGIN_NAMESPACE
class QDir;
class QAction;
class QTextCodec;
QT_END_NAMESPACE
namespace Core {
class CommandLocator;
class IEditor;
}
namespace Utils { class ParameterAction; }
namespace Subversion { namespace Subversion {
namespace Internal { namespace Internal {
class SubversionSubmitEditor;
class SubversionClient;
struct SubversionResponse
{
bool error = false;
QString stdOut;
QString stdErr;
QString message;
};
const char FileAddedC[] = "A"; const char FileAddedC[] = "A";
const char FileConflictedC[] = "C"; const char FileConflictedC[] = "C";
const char FileDeletedC[] = "D"; const char FileDeletedC[] = "D";
const char FileModifiedC[] = "M"; const char FileModifiedC[] = "M";
class SubversionPluginPrivate final : public VcsBase::VcsBasePluginPrivate
{
Q_OBJECT
public:
SubversionPluginPrivate();
~SubversionPluginPrivate() final;
// IVersionControl
QString displayName() const final;
Core::Id id() const final;
bool isVcsFileOrDirectory(const Utils::FilePath &fileName) const final;
bool managesDirectory(const QString &directory, QString *topLevel) const final;
bool managesFile(const QString &workingDirectory, const QString &fileName) const final;
bool isConfigured() const final;
bool supportsOperation(Operation operation) const final;
bool vcsOpen(const QString &fileName) final;
bool vcsAdd(const QString &fileName) final;
bool vcsDelete(const QString &filename) final;
bool vcsMove(const QString &from, const QString &to) final;
bool vcsCreateRepository(const QString &directory) final;
bool vcsAnnotate(const QString &file, int line) final;
Core::ShellCommand *createInitialCheckoutCommand(const QString &url,
const Utils::FilePath &baseDirectory,
const QString &localName,
const QStringList &extraArgs) final;
bool isVcsDirectory(const Utils::FilePath &fileName) const;
///
SubversionClient *client();
SubversionSubmitEditor *openSubversionSubmitEditor(const QString &fileName);
// IVersionControl
bool vcsAdd(const QString &workingDir, const QString &fileName);
bool vcsDelete(const QString &workingDir, const QString &fileName);
bool vcsMove(const QString &workingDir, const QString &from, const QString &to);
bool vcsCheckout(const QString &directory, const QByteArray &url);
static SubversionPluginPrivate *instance();
QString monitorFile(const QString &repository) const;
QString synchronousTopic(const QString &repository) const;
SubversionResponse runSvn(const QString &workingDir,
const QStringList &arguments, int timeOutS,
unsigned flags, QTextCodec *outputCodec = nullptr) const;
void describe(const QString &source, const QString &changeNr);
void vcsAnnotateHelper(const QString &workingDir, const QString &file,
const QString &revision = QString(), int lineNumber = -1);
protected:
void updateActions(VcsBase::VcsBasePluginPrivate::ActionState) override;
bool submitEditorAboutToClose() override;
private:
void addCurrentFile();
void revertCurrentFile();
void diffProject();
void diffCurrentFile();
void cleanCommitMessageFile();
void startCommitAll();
void startCommitProject();
void startCommitCurrentFile();
void revertAll();
void filelogCurrentFile();
void annotateCurrentFile();
void projectStatus();
void slotDescribe();
void updateProject();
void commitFromEditor() override;
void diffCommitFiles(const QStringList &);
void logProject();
void logRepository();
void diffRepository();
void statusRepository();
void updateRepository();
inline bool isCommitEditorOpen() const;
Core::IEditor *showOutputInEditor(const QString &title, const QString &output,
int editorType, const QString &source,
QTextCodec *codec);
void filelog(const QString &workingDir,
const QString &file = QString(),
bool enableAnnotationContextMenu = false);
void svnStatus(const QString &workingDir, const QString &relativePath = QString());
void svnUpdate(const QString &workingDir, const QString &relativePath = QString());
bool checkSVNSubDir(const QDir &directory) const;
void startCommit(const QString &workingDir, const QStringList &files = QStringList());
const QStringList m_svnDirectories;
SubversionSettings m_settings;
SubversionClient *m_client = nullptr;
QString m_commitMessageFileName;
QString m_commitRepository;
Core::CommandLocator *m_commandLocator = nullptr;
Utils::ParameterAction *m_addAction = nullptr;
Utils::ParameterAction *m_deleteAction = nullptr;
Utils::ParameterAction *m_revertAction = nullptr;
Utils::ParameterAction *m_diffProjectAction = nullptr;
Utils::ParameterAction *m_diffCurrentAction = nullptr;
Utils::ParameterAction *m_logProjectAction = nullptr;
QAction *m_logRepositoryAction = nullptr;
QAction *m_commitAllAction = nullptr;
QAction *m_revertRepositoryAction = nullptr;
QAction *m_diffRepositoryAction = nullptr;
QAction *m_statusRepositoryAction = nullptr;
QAction *m_updateRepositoryAction = nullptr;
Utils::ParameterAction *m_commitCurrentAction = nullptr;
Utils::ParameterAction *m_filelogCurrentAction = nullptr;
Utils::ParameterAction *m_annotateCurrentAction = nullptr;
Utils::ParameterAction *m_statusProjectAction = nullptr;
Utils::ParameterAction *m_updateProjectAction = nullptr;
Utils::ParameterAction *m_commitProjectAction = nullptr;
QAction *m_describeAction = nullptr;
QAction *m_menuAction = nullptr;
bool m_submitActionTriggered = false;
};
class SubversionPlugin final : public ExtensionSystem::IPlugin class SubversionPlugin final : public ExtensionSystem::IPlugin
{ {
Q_OBJECT Q_OBJECT