2009-02-25 09:15:00 +01:00
|
|
|
/**************************************************************************
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
|
|
|
** This file is part of Qt Creator
|
|
|
|
**
|
2010-03-05 11:25:49 +01:00
|
|
|
** Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
2009-06-17 00:01:27 +10:00
|
|
|
** Contact: Nokia Corporation (qt-info@nokia.com)
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** Commercial Usage
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** Licensees holding valid Qt Commercial licenses may use this file in
|
|
|
|
** accordance with the Qt Commercial License Agreement provided with the
|
|
|
|
** Software or, alternatively, in accordance with the terms contained in
|
|
|
|
** a written agreement between you and Nokia.
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** GNU Lesser General Public License Usage
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** Alternatively, this file may be used under the terms of the GNU Lesser
|
|
|
|
** General Public License version 2.1 as published by the Free Software
|
|
|
|
** Foundation and appearing in the file LICENSE.LGPL included in the
|
|
|
|
** packaging of this file. Please review the following information to
|
|
|
|
** ensure the GNU Lesser General Public License version 2.1 requirements
|
|
|
|
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** If you are unsure which license is appropriate for your use, please
|
2009-08-14 09:30:56 +02:00
|
|
|
** contact the sales department at http://qt.nokia.com/contact.
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
**************************************************************************/
|
2008-12-02 16:19:05 +01:00
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
#ifndef VCSBASEPLUGIN_H
|
|
|
|
#define VCSBASEPLUGIN_H
|
|
|
|
|
2009-12-08 14:26:41 +01:00
|
|
|
#include "vcsbase_global.h"
|
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
#include <extensionsystem/iplugin.h>
|
|
|
|
|
2010-01-15 12:24:06 +01:00
|
|
|
#include <QtCore/QSharedDataPointer>
|
|
|
|
#include <QtCore/QList>
|
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 QProcessEnvironment;
|
|
|
|
class QTextCodec;
|
2009-03-20 14:20:28 +01:00
|
|
|
QT_END_NAMESPACE
|
|
|
|
|
2010-05-21 17:46:00 +02:00
|
|
|
namespace Utils {
|
|
|
|
struct SynchronousProcessResponse;
|
|
|
|
}
|
|
|
|
|
2009-12-08 14:26:41 +01:00
|
|
|
namespace Core {
|
|
|
|
class IVersionControl;
|
|
|
|
}
|
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
namespace VCSBase {
|
|
|
|
namespace Internal {
|
2009-12-08 14:26:41 +01:00
|
|
|
struct State;
|
|
|
|
}
|
|
|
|
|
|
|
|
class VCSBaseSubmitEditor;
|
|
|
|
struct VCSBasePluginPrivate;
|
|
|
|
class VCSBasePluginStateData;
|
|
|
|
class VCSBasePlugin;
|
|
|
|
|
|
|
|
/* VCSBasePlugin and VCSBasePluginState: Provide a base class for
|
|
|
|
* VCS plugins. It mainly takes care of maintaining the
|
|
|
|
* VCS-relevant state of Qt Creator which is a tuple of
|
|
|
|
*
|
|
|
|
* 1) Current file and it's version system control/top level
|
|
|
|
* 2) Current project and it's version system control/top level
|
|
|
|
*
|
|
|
|
* (reflected in VCSBasePluginState). The plugin connects to the
|
|
|
|
* relevant change signals in Qt Creator and calls the virtual
|
|
|
|
* updateActions() for the plugins to update their menu actions
|
|
|
|
* according to the new state. This is done centrally to avoid
|
|
|
|
* single plugins repeatedly invoking searches/QFileInfo on files,
|
|
|
|
* etc.
|
2010-03-25 16:23:37 +01:00
|
|
|
* Independently, there are accessors for current patch files, which return
|
|
|
|
* a file name if the current file could be a patch file which could be applied
|
|
|
|
* and a repository exists.
|
2009-12-08 14:26:41 +01:00
|
|
|
*
|
|
|
|
* If current file/project are managed
|
|
|
|
* by different version controls, the project is discarded and only
|
|
|
|
* the current file is taken into account, allowing to do a diff
|
|
|
|
* also when the project of a file is not opened.
|
|
|
|
*
|
|
|
|
* When triggering an action, a copy of the state should be made to
|
|
|
|
* keep it, as it may rapidly change due to context changes, etc.
|
|
|
|
*
|
|
|
|
* The class also detects the VCS plugin submit editor closing and calls
|
|
|
|
* the virtual submitEditorAboutToClose() to trigger the submit process. */
|
|
|
|
|
|
|
|
class VCSBASE_EXPORT VCSBasePluginState
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
VCSBasePluginState();
|
|
|
|
VCSBasePluginState(const VCSBasePluginState &);
|
|
|
|
VCSBasePluginState &operator=(const VCSBasePluginState &);
|
|
|
|
~VCSBasePluginState();
|
|
|
|
|
|
|
|
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
|
|
|
|
* differs from top level (else empty()) as an argument list to do
|
|
|
|
* eg a 'vcs diff <args>' */
|
|
|
|
QStringList relativeCurrentProject() const;
|
|
|
|
|
|
|
|
// Top level directory for actions on the top level. Preferably
|
|
|
|
// the file one.
|
|
|
|
QString topLevel() const;
|
|
|
|
|
|
|
|
bool equals(const VCSBasePluginState &rhs) const;
|
|
|
|
|
|
|
|
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:
|
|
|
|
friend class VCSBasePlugin;
|
|
|
|
bool equals(const Internal::State &s) const;
|
|
|
|
void setState(const Internal::State &s);
|
2009-03-19 17:40:01 +01:00
|
|
|
|
2009-12-08 14:26:41 +01:00
|
|
|
QSharedDataPointer<VCSBasePluginStateData> data;
|
|
|
|
};
|
|
|
|
|
|
|
|
VCSBASE_EXPORT QDebug operator<<(QDebug in, const VCSBasePluginState &state);
|
|
|
|
|
|
|
|
inline bool operator==(const VCSBasePluginState &s1, const VCSBasePluginState &s2)
|
|
|
|
{ return s1.equals(s2); }
|
|
|
|
inline bool operator!=(const VCSBasePluginState &s1, const VCSBasePluginState &s2)
|
|
|
|
{ return !s1.equals(s2); }
|
|
|
|
|
|
|
|
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:
|
2010-01-07 18:17:24 +01:00
|
|
|
explicit VCSBasePlugin(const QString &submitEditorId);
|
2008-12-02 12:01:29 +01:00
|
|
|
|
2010-04-26 09:12:58 +02:00
|
|
|
virtual void initialize(Core::IVersionControl *vc);
|
|
|
|
virtual void extensionsInitialized();
|
2008-12-02 12:01:29 +01:00
|
|
|
|
|
|
|
public:
|
2009-12-08 14:26:41 +01:00
|
|
|
virtual ~VCSBasePlugin();
|
2008-12-02 12:01:29 +01:00
|
|
|
|
2009-12-08 14:26:41 +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-01-15 12:24:06 +01:00
|
|
|
// For internal tests: Create actions driving IVersionControl's snapshot interface.
|
|
|
|
QList<QAction*> createSnapShotTestActions();
|
|
|
|
|
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.
|
|
|
|
static void setProcessEnvironment(QProcessEnvironment *e, bool forceCLocale);
|
2010-05-21 17:46:00 +02:00
|
|
|
// Returns whether an SSH prompt is configured.
|
|
|
|
static bool isSshPromptConfigured();
|
|
|
|
|
|
|
|
// Convenience to synchronously run VCS commands
|
|
|
|
enum RunVCSFlags {
|
|
|
|
ShowStdOutInLogWindow = 0x1, // Append standard output to VCS output window.
|
|
|
|
MergeOutputChannels = 0x2, // see QProcess: Merge stderr/stdout.
|
2010-06-10 08:38:23 +02:00
|
|
|
SshPasswordPrompt = 0x4, // Disable terminal on UNIX to force graphical prompt.
|
2010-05-21 17:46:00 +02:00
|
|
|
SuppressStdErrInLogWindow = 0x8, // No standard error output to VCS output window.
|
|
|
|
SuppressFailMessageInLogWindow = 0x10, // No message VCS about failure in VCS output window.
|
2010-05-25 11:48:53 +02:00
|
|
|
SuppressCommandLogging = 0x20, // No command log entry in VCS output window.
|
2010-06-15 12:17:09 +02:00
|
|
|
ShowSuccessMessage = 0x40, // Show message about successful completion in VCS output window.
|
|
|
|
ForceCLocale = 0x80 // Force C-locale for commands whose output is parsed.
|
2010-05-21 17:46:00 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
static Utils::SynchronousProcessResponse
|
|
|
|
runVCS(const QString &workingDir,
|
|
|
|
const QString &binary,
|
|
|
|
const QStringList &arguments,
|
|
|
|
int timeOutMS,
|
|
|
|
QProcessEnvironment env,
|
|
|
|
unsigned flags = 0,
|
|
|
|
QTextCodec *outputCodec = 0);
|
|
|
|
|
|
|
|
static Utils::SynchronousProcessResponse
|
|
|
|
runVCS(const QString &workingDir,
|
|
|
|
const QString &binary,
|
|
|
|
const QStringList &arguments,
|
|
|
|
int timeOutMS,
|
|
|
|
unsigned flags = 0,
|
|
|
|
QTextCodec *outputCodec = 0);
|
|
|
|
|
2010-01-11 15:22:17 +01:00
|
|
|
public slots:
|
|
|
|
// Convenience slot for "Delete current file" action. Prompts to
|
|
|
|
// delete the file via VCSManager.
|
|
|
|
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
|
|
|
|
2009-12-08 14:26:41 +01:00
|
|
|
protected:
|
|
|
|
enum ActionState { NoVCSEnabled, OtherVCSEnabled, VCSEnabled };
|
2009-03-19 17:40:01 +01:00
|
|
|
|
2009-12-08 14:26:41 +01:00
|
|
|
// Implement to enable the plugin menu actions according to state.
|
|
|
|
virtual void updateActions(ActionState as) = 0;
|
2010-01-29 22:49:55 +01:00
|
|
|
// Implement to start the submit process.
|
2009-12-08 14:26:41 +01:00
|
|
|
virtual bool submitEditorAboutToClose(VCSBaseSubmitEditor *submitEditor) = 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:
|
2010-01-12 16:45:21 +01:00
|
|
|
// NoVCSEnabled -> visible, enabled if repository creation is supported
|
|
|
|
// OtherVCSEnabled -> invisible
|
|
|
|
// 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
|
|
|
|
|
|
|
private slots:
|
2009-12-08 14:26:41 +01:00
|
|
|
void slotSubmitEditorAboutToClose(VCSBaseSubmitEditor *submitEditor, bool *result);
|
|
|
|
void slotStateChanged(const VCSBase::Internal::State &s, Core::IVersionControl *vc);
|
2010-01-15 12:24:06 +01:00
|
|
|
void slotTestSnapshot();
|
|
|
|
void slotTestListSnapshots();
|
|
|
|
void slotTestRestoreSnapshot();
|
|
|
|
void slotTestRemoveSnapshot();
|
2009-03-20 14:20:28 +01:00
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
private:
|
2009-12-08 14:26:41 +01:00
|
|
|
VCSBasePluginPrivate *d;
|
2008-12-02 12:01:29 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace VCSBase
|
|
|
|
|
|
|
|
#endif // VCSBASEPLUGIN_H
|