aboutsummaryrefslogtreecommitdiffstats
path: root/src/plugins/vcsbase/vcsbaseplugin.cpp
diff options
context:
space:
mode:
authorFriedemann Kleint <[email protected]>2010-01-12 16:45:21 +0100
committerFriedemann Kleint <[email protected]>2010-01-12 16:45:21 +0100
commitd5271a086d7be7fbf7b07a2ca450b805b229aa15 (patch)
tree2ceb1b48a2651455477b03c7ddbf01e50e0151e5 /src/plugins/vcsbase/vcsbaseplugin.cpp
parent5ab250fe5705210a422eeaf8c7ef2dd4a8ab4abb (diff)
VCS[hg, git]: Add support for repository creation.
Add repository creation operation to IVersionControl, implement for hg and git, add convenience slot with prompts to VCSBasePlugin. Add respective menu options and make menus are visible in case no VCS is active. Change project wizards extension page to list VCS that are capable of repository creation in a QComboBox in case the directory is not managed by another VCS (in which case it lists that one for operation 'add'). On that occasion, polish the Project selection to use a QComboBox as well and add some smartness to find the most suitable project to add via path matching.
Diffstat (limited to 'src/plugins/vcsbase/vcsbaseplugin.cpp')
-rw-r--r--src/plugins/vcsbase/vcsbaseplugin.cpp59
1 files changed, 55 insertions, 4 deletions
diff --git a/src/plugins/vcsbase/vcsbaseplugin.cpp b/src/plugins/vcsbase/vcsbaseplugin.cpp
index b672fba110a..0cb54a70087 100644
--- a/src/plugins/vcsbase/vcsbaseplugin.cpp
+++ b/src/plugins/vcsbase/vcsbaseplugin.cpp
@@ -47,6 +47,8 @@
#include <QtGui/QAction>
#include <QtGui/QMessageBox>
+#include <QtGui/QFileDialog>
+#include <QtGui/QMainWindow>
enum { debug = 0 };
@@ -345,6 +347,8 @@ VCSBASE_EXPORT QDebug operator<<(QDebug in, const VCSBasePluginState &state)
struct VCSBasePluginPrivate {
explicit VCSBasePluginPrivate(const QString &submitEditorId);
+ inline bool supportsRepositoryCreation() const;
+
const QString m_submitEditorId;
Core::IVersionControl *m_versionControl;
VCSBasePluginState m_state;
@@ -360,6 +364,11 @@ VCSBasePluginPrivate::VCSBasePluginPrivate(const QString &submitEditorId) :
{
}
+bool VCSBasePluginPrivate::supportsRepositoryCreation() const
+{
+ return m_versionControl && m_versionControl->supportsOperation(Core::IVersionControl::CreateRepositoryOperation);
+}
+
Internal::StateListener *VCSBasePluginPrivate::m_listener = 0;
VCSBasePlugin::VCSBasePlugin(const QString &submitEditorId) :
@@ -427,15 +436,17 @@ const VCSBasePluginState &VCSBasePlugin::currentState() const
return d->m_state;
}
-bool VCSBasePlugin::enableMenuAction(ActionState as, QAction *menuAction)
+bool VCSBasePlugin::enableMenuAction(ActionState as, QAction *menuAction) const
{
if (debug)
qDebug() << "enableMenuAction" << menuAction->text() << as;
switch (as) {
- case VCSBase::VCSBasePlugin::NoVCSEnabled:
+ case VCSBase::VCSBasePlugin::NoVCSEnabled: {
+ const bool supportsCreation = d->supportsRepositoryCreation();
menuAction->setVisible(true);
- menuAction->setEnabled(false);
- return false;
+ menuAction->setEnabled(supportsCreation);
+ return supportsCreation;
+ }
case VCSBase::VCSBasePlugin::OtherVCSEnabled:
menuAction->setVisible(false);
return false;
@@ -456,6 +467,46 @@ void VCSBasePlugin::promptToDeleteCurrentFile()
QMessageBox::warning(0, tr("Version Control"), tr("The file '%1' could not be deleted.").arg(state.currentFile()), QMessageBox::Ok);
}
+static inline bool ask(QWidget *parent, const QString &title, const QString &question, bool defaultValue = true)
+
+{
+ const QMessageBox::StandardButton defaultButton = defaultValue ? QMessageBox::Yes : QMessageBox::No;
+ return QMessageBox::question(parent, title, question, QMessageBox::Yes|QMessageBox::No, defaultButton) == QMessageBox::Yes;
+}
+
+void VCSBasePlugin::createRepository()
+{
+ QTC_ASSERT(d->m_versionControl->supportsOperation(Core::IVersionControl::CreateRepositoryOperation), return);
+ // Find current starting directory
+ QString directory;
+ if (const ProjectExplorer::Project *currentProject = ProjectExplorer::ProjectExplorerPlugin::instance()->currentProject())
+ directory = QFileInfo(currentProject->file()->fileName()).absolutePath();
+ // Prompt for a directory that is not under version control yet
+ QMainWindow *mw = Core::ICore::instance()->mainWindow();
+ do {
+ directory = QFileDialog::getExistingDirectory(mw, tr("Choose repository directory"), directory);
+ if (directory.isEmpty())
+ return;
+ const Core::IVersionControl *managingControl = Core::ICore::instance()->vcsManager()->findVersionControlForDirectory(directory);
+ if (managingControl == 0)
+ break;
+ const QString question = tr("The directory '%1' is already managed by a version control system (%2)."
+ " Would you like to specify another directory?").arg(directory, managingControl->displayName());
+
+ if (!ask(mw, tr("Repository already under version control"), question))
+ return;
+ } while (true);
+ // Create
+ const bool rc = d->m_versionControl->vcsCreateRepository(directory);
+ if (rc) {
+ QMessageBox::information(mw, tr("Repository created"),
+ tr("A version control repository has been created in %1.").arg(directory));
+ } else {
+ QMessageBox::warning(mw, tr("Repository creation failed"),
+ tr("A version control repository could not be created in %1.").arg(directory));
+ }
+}
+
} // namespace VCSBase
#include "vcsbaseplugin.moc"