2012-10-02 09:12:39 +02:00
|
|
|
/****************************************************************************
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
2016-01-15 14:57:40 +01:00
|
|
|
** Copyright (C) 2016 The Qt Company Ltd.
|
|
|
|
** Contact: https://www.qt.io/licensing/
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
2012-10-02 09:12:39 +02:00
|
|
|
** This file is part of Qt Creator.
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
2012-10-02 09:12:39 +02:00
|
|
|
** Commercial License Usage
|
|
|
|
** Licensees holding valid commercial Qt licenses may use this file in
|
|
|
|
** accordance with the commercial license agreement provided with the
|
|
|
|
** Software or, alternatively, in accordance with the terms contained in
|
2016-01-15 14:57:40 +01:00
|
|
|
** a written agreement between you and The Qt Company. For licensing terms
|
|
|
|
** and conditions see https://www.qt.io/terms-conditions. For further
|
|
|
|
** information use the contact form at https://www.qt.io/contact-us.
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2016-01-15 14:57:40 +01:00
|
|
|
** GNU General Public License Usage
|
|
|
|
** Alternatively, this file may be used under the terms of the GNU
|
|
|
|
** General Public License version 3 as published by the Free Software
|
|
|
|
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
|
|
|
|
** included in the packaging of this file. Please review the following
|
|
|
|
** information to ensure the GNU General Public License requirements will
|
|
|
|
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
|
2010-12-17 16:01:08 +01:00
|
|
|
**
|
2012-10-02 09:12:39 +02:00
|
|
|
****************************************************************************/
|
2008-12-02 16:19:05 +01:00
|
|
|
|
2016-02-03 12:15:21 +01:00
|
|
|
#pragma once
|
2008-12-02 12:01:29 +01:00
|
|
|
|
2009-12-08 14:26:41 +01:00
|
|
|
#include "vcsbase_global.h"
|
|
|
|
|
2017-06-15 13:37:33 +02:00
|
|
|
#include <coreplugin/iversioncontrol.h>
|
|
|
|
#include <coreplugin/vcsmanager.h>
|
2008-12-02 12:01:29 +01:00
|
|
|
#include <extensionsystem/iplugin.h>
|
|
|
|
|
2012-02-15 10:42:41 +01:00
|
|
|
#include <QList>
|
2013-08-28 11:32:33 +03:00
|
|
|
#include <QProcessEnvironment>
|
2016-02-03 12:15:21 +01:00
|
|
|
#include <QSharedDataPointer>
|
2008-12-02 12:01:29 +01:00
|
|
|
|
2009-03-20 14:20:28 +01:00
|
|
|
QT_BEGIN_NAMESPACE
|
2009-12-08 14:26:41 +01:00
|
|
|
class QAction;
|
2010-05-21 17:46:00 +02:00
|
|
|
class QTextCodec;
|
2009-03-20 14:20:28 +01:00
|
|
|
QT_END_NAMESPACE
|
|
|
|
|
2016-07-20 13:44:47 +02:00
|
|
|
namespace Utils {
|
2015-02-26 09:33:24 +01:00
|
|
|
class FileName;
|
2016-07-20 13:44:47 +02:00
|
|
|
class SynchronousProcessResponse;
|
|
|
|
} // namespace Utils
|
2010-05-21 17:46:00 +02:00
|
|
|
|
2013-03-25 11:36:51 +01:00
|
|
|
namespace Core {
|
2014-11-16 12:05:34 +02:00
|
|
|
class Context;
|
2013-03-25 11:36:51 +01:00
|
|
|
class IVersionControl;
|
|
|
|
class Id;
|
2014-02-11 13:00:35 +01:00
|
|
|
class IDocument;
|
2016-07-20 13:44:47 +02:00
|
|
|
} // namespace Core
|
2009-12-08 14:26:41 +01:00
|
|
|
|
2012-01-07 12:31:48 +01:00
|
|
|
namespace VcsBase {
|
2012-01-07 03:35:54 +01:00
|
|
|
|
2015-09-16 14:54:58 +02:00
|
|
|
namespace Internal { class State; }
|
2009-12-08 14:26:41 +01:00
|
|
|
|
2012-01-07 12:31:48 +01:00
|
|
|
class VcsBaseSubmitEditor;
|
2013-10-14 15:38:00 +02:00
|
|
|
class VcsBasePluginPrivate;
|
2012-01-07 12:31:48 +01:00
|
|
|
class VcsBasePluginStateData;
|
|
|
|
class VcsBasePlugin;
|
2009-12-08 14:26:41 +01:00
|
|
|
|
2011-03-28 14:19:17 +02:00
|
|
|
// Documentation inside.
|
2012-01-07 12:31:48 +01:00
|
|
|
class VCSBASE_EXPORT VcsBasePluginState
|
2009-12-08 14:26:41 +01:00
|
|
|
{
|
|
|
|
public:
|
2012-01-07 12:31:48 +01:00
|
|
|
VcsBasePluginState();
|
|
|
|
VcsBasePluginState(const VcsBasePluginState &);
|
|
|
|
VcsBasePluginState &operator=(const VcsBasePluginState &);
|
|
|
|
~VcsBasePluginState();
|
2009-12-08 14:26:41 +01:00
|
|
|
|
|
|
|
void clear();
|
|
|
|
|
|
|
|
bool isEmpty() const;
|
|
|
|
bool hasFile() const;
|
2010-03-25 16:23:37 +01:00
|
|
|
bool hasPatchFile() const;
|
2009-12-08 14:26:41 +01:00
|
|
|
bool hasProject() const;
|
|
|
|
bool hasTopLevel() const;
|
|
|
|
|
|
|
|
// Current file.
|
|
|
|
QString currentFile() const;
|
|
|
|
QString currentFileName() const;
|
|
|
|
QString currentFileDirectory() const;
|
|
|
|
QString currentFileTopLevel() const;
|
|
|
|
// Convenience: Returns file relative to top level.
|
|
|
|
QString relativeCurrentFile() const;
|
|
|
|
|
2010-03-25 16:23:37 +01:00
|
|
|
// If the current file looks like a patch and there is a top level,
|
|
|
|
// it will end up here (for VCS that offer patch functionality).
|
|
|
|
QString currentPatchFile() const;
|
|
|
|
QString currentPatchFileDisplayName() const;
|
|
|
|
|
2009-12-08 14:26:41 +01:00
|
|
|
// Current project.
|
|
|
|
QString currentProjectPath() const;
|
|
|
|
QString currentProjectName() const;
|
|
|
|
QString currentProjectTopLevel() const;
|
|
|
|
/* Convenience: Returns project path relative to top level if it
|
2013-08-06 15:14:54 +03:00
|
|
|
* differs from top level (else empty string) as an argument list to do
|
2009-12-08 14:26:41 +01:00
|
|
|
* eg a 'vcs diff <args>' */
|
2013-08-06 15:14:54 +03:00
|
|
|
QString relativeCurrentProject() const;
|
2009-12-08 14:26:41 +01:00
|
|
|
|
|
|
|
// Top level directory for actions on the top level. Preferably
|
|
|
|
// the file one.
|
|
|
|
QString topLevel() const;
|
|
|
|
|
2012-01-07 12:31:48 +01:00
|
|
|
bool equals(const VcsBasePluginState &rhs) const;
|
2009-12-08 14:26:41 +01:00
|
|
|
|
2012-01-07 12:31:48 +01:00
|
|
|
friend VCSBASE_EXPORT QDebug operator<<(QDebug in, const VcsBasePluginState &state);
|
2008-12-02 12:01:29 +01:00
|
|
|
|
2009-12-08 14:26:41 +01:00
|
|
|
private:
|
2012-01-07 12:31:48 +01:00
|
|
|
friend class VcsBasePlugin;
|
2009-12-08 14:26:41 +01:00
|
|
|
bool equals(const Internal::State &s) const;
|
|
|
|
void setState(const Internal::State &s);
|
2009-03-19 17:40:01 +01:00
|
|
|
|
2012-01-07 12:31:48 +01:00
|
|
|
QSharedDataPointer<VcsBasePluginStateData> data;
|
2009-12-08 14:26:41 +01:00
|
|
|
};
|
|
|
|
|
2012-01-07 12:31:48 +01:00
|
|
|
VCSBASE_EXPORT QDebug operator<<(QDebug in, const VcsBasePluginState &state);
|
2009-12-08 14:26:41 +01:00
|
|
|
|
2012-01-07 12:31:48 +01:00
|
|
|
inline bool operator==(const VcsBasePluginState &s1, const VcsBasePluginState &s2)
|
2009-12-08 14:26:41 +01:00
|
|
|
{ return s1.equals(s2); }
|
2012-01-07 12:31:48 +01:00
|
|
|
inline bool operator!=(const VcsBasePluginState &s1, const VcsBasePluginState &s2)
|
2009-12-08 14:26:41 +01:00
|
|
|
{ return !s1.equals(s2); }
|
|
|
|
|
2012-01-07 12:31:48 +01:00
|
|
|
class VCSBASE_EXPORT VcsBasePlugin : public ExtensionSystem::IPlugin
|
2008-12-02 12:01:29 +01:00
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
2009-12-08 14:26:41 +01:00
|
|
|
protected:
|
2013-04-18 12:06:43 +02:00
|
|
|
explicit VcsBasePlugin();
|
2008-12-02 12:01:29 +01:00
|
|
|
|
2017-06-15 13:37:33 +02:00
|
|
|
template<class T, typename... Args>
|
|
|
|
T *initializeVcs(const Core::Context &context, Args&&... args)
|
|
|
|
{
|
|
|
|
T *vc = Core::VcsManager::registerVersionControl<T>(std::forward<Args>(args)...);
|
|
|
|
initializeVcs(vc, context);
|
|
|
|
return vc;
|
|
|
|
}
|
|
|
|
|
2016-02-03 12:15:21 +01:00
|
|
|
void extensionsInitialized() override;
|
2008-12-02 12:01:29 +01:00
|
|
|
|
|
|
|
public:
|
2016-02-03 12:15:21 +01:00
|
|
|
~VcsBasePlugin() override;
|
2008-12-02 12:01:29 +01:00
|
|
|
|
2012-01-07 12:31:48 +01:00
|
|
|
const VcsBasePluginState ¤tState() const;
|
2009-12-08 16:50:27 +01:00
|
|
|
Core::IVersionControl *versionControl() const;
|
2008-12-02 12:01:29 +01:00
|
|
|
|
2010-05-19 17:41:14 +02:00
|
|
|
// Convenience that searches for the repository specifically for version control
|
|
|
|
// systems that do not have directories like "CVS" in each managed subdirectory
|
|
|
|
// but have a directory at the top of the repository like ".git" containing
|
|
|
|
// a well known file. See implementation for gory details.
|
|
|
|
static QString findRepositoryForDirectory(const QString &dir, const QString &checkFile);
|
|
|
|
|
2010-05-21 17:46:00 +02:00
|
|
|
// Set up the environment for a version control command line call.
|
2010-06-15 12:17:09 +02:00
|
|
|
// Sets up SSH graphical password prompting (note that the latter
|
|
|
|
// requires a terminal-less process) and sets LANG to 'C' to force English
|
|
|
|
// (suppress LOCALE warnings/parse commands output) if desired.
|
2013-08-28 11:32:33 +03:00
|
|
|
static void setProcessEnvironment(QProcessEnvironment *e,
|
|
|
|
bool forceCLocale,
|
|
|
|
const QString &sshPasswordPrompt = sshPrompt());
|
2013-08-16 17:02:30 +03:00
|
|
|
// Returns SSH prompt configured in settings.
|
|
|
|
static QString sshPrompt();
|
2010-05-21 17:46:00 +02:00
|
|
|
// Returns whether an SSH prompt is configured.
|
|
|
|
static bool isSshPromptConfigured();
|
|
|
|
|
2013-12-19 10:37:26 +01:00
|
|
|
// Sets the source of editor contents, can be directory or file.
|
2014-02-11 13:00:35 +01:00
|
|
|
static void setSource(Core::IDocument *document, const QString &source);
|
2013-12-19 10:37:26 +01:00
|
|
|
// Returns the source of editor contents.
|
2014-02-11 13:00:35 +01:00
|
|
|
static QString source(Core::IDocument *document);
|
2013-12-19 10:37:26 +01:00
|
|
|
|
2012-01-07 12:31:48 +01:00
|
|
|
static Utils::SynchronousProcessResponse runVcs(const QString &workingDir,
|
2014-07-15 23:32:11 +03:00
|
|
|
const Utils::FileName &binary,
|
2011-10-05 10:35:24 +00:00
|
|
|
const QStringList &arguments,
|
2015-04-10 14:44:17 +02:00
|
|
|
int timeOutS,
|
2011-10-05 10:35:24 +00:00
|
|
|
unsigned flags = 0,
|
2018-05-07 17:30:00 +02:00
|
|
|
QTextCodec *outputCodec = nullptr,
|
2013-08-28 11:32:33 +03:00
|
|
|
const QProcessEnvironment &env = QProcessEnvironment());
|
2010-05-21 17:46:00 +02:00
|
|
|
|
2015-06-10 11:39:41 +02:00
|
|
|
protected:
|
2017-09-08 12:52:35 +02:00
|
|
|
// Display name of the commit action:
|
|
|
|
virtual QString commitDisplayName() const;
|
|
|
|
// Prompt to save all files before commit:
|
|
|
|
bool promptBeforeCommit();
|
|
|
|
|
2010-01-11 15:22:17 +01:00
|
|
|
// Convenience slot for "Delete current file" action. Prompts to
|
2012-01-07 12:31:48 +01:00
|
|
|
// delete the file via VcsManager.
|
2010-01-11 15:22:17 +01:00
|
|
|
void promptToDeleteCurrentFile();
|
2010-02-01 12:43:56 +01:00
|
|
|
// Prompt to initialize version control in a directory, initially
|
2010-01-12 16:45:21 +01:00
|
|
|
// pointing to the current project.
|
|
|
|
void createRepository();
|
2010-01-11 15:22:17 +01:00
|
|
|
|
2012-01-07 12:31:48 +01:00
|
|
|
enum ActionState { NoVcsEnabled, OtherVcsEnabled, VcsEnabled };
|
2009-03-19 17:40:01 +01:00
|
|
|
|
2013-04-18 12:06:43 +02:00
|
|
|
// Sets the current submit editor for this specific version control plugin.
|
|
|
|
// The plugin automatically checks if the submit editor is closed and calls
|
|
|
|
// submitEditorAboutToClose().
|
2013-10-07 13:34:40 +02:00
|
|
|
// The function raiseSubmitEditor can be used to check for a running submit editor and raise it.
|
2013-04-18 12:06:43 +02:00
|
|
|
void setSubmitEditor(VcsBaseSubmitEditor *submitEditor);
|
|
|
|
// Current submit editor set through setSubmitEditor, if it wasn't closed inbetween
|
|
|
|
VcsBaseSubmitEditor *submitEditor() const;
|
|
|
|
// Tries to raise the submit editor set through setSubmitEditor. Returns true if that was found.
|
|
|
|
bool raiseSubmitEditor() const;
|
|
|
|
|
2009-12-08 14:26:41 +01:00
|
|
|
// Implement to enable the plugin menu actions according to state.
|
|
|
|
virtual void updateActions(ActionState as) = 0;
|
2013-04-18 12:06:43 +02:00
|
|
|
// Implement to start the submit process, use submitEditor() to get the submit editor instance.
|
|
|
|
virtual bool submitEditorAboutToClose() = 0;
|
2009-03-20 14:20:28 +01:00
|
|
|
|
2009-12-08 14:26:41 +01:00
|
|
|
// A helper to enable the VCS menu action according to state:
|
2012-01-07 12:31:48 +01:00
|
|
|
// NoVcsEnabled -> visible, enabled if repository creation is supported
|
|
|
|
// OtherVcsEnabled -> invisible
|
2010-01-12 16:45:21 +01:00
|
|
|
// Else: -> fully enabled.
|
|
|
|
// Returns whether actions should be set up further.
|
|
|
|
bool enableMenuAction(ActionState as, QAction *in) const;
|
2009-03-20 14:20:28 +01:00
|
|
|
|
2016-02-03 12:15:21 +01:00
|
|
|
private:
|
2012-01-07 12:31:48 +01:00
|
|
|
void slotSubmitEditorAboutToClose(VcsBaseSubmitEditor *submitEditor, bool *result);
|
|
|
|
void slotStateChanged(const VcsBase::Internal::State &s, Core::IVersionControl *vc);
|
2009-03-20 14:20:28 +01:00
|
|
|
|
2017-06-15 13:37:33 +02:00
|
|
|
void initializeVcs(Core::IVersionControl *vc, const Core::Context &context);
|
|
|
|
|
2012-01-07 12:31:48 +01:00
|
|
|
VcsBasePluginPrivate *d;
|
2008-12-02 12:01:29 +01:00
|
|
|
};
|
|
|
|
|
2012-01-07 12:31:48 +01:00
|
|
|
} // namespace VcsBase
|