VCS: Add a way to filter out files/directories that belong to a VCS

Change-Id: I4dcbe6242cfe327e3b72d3dd550309be45e326a9
Reviewed-by: Orgad Shaneh <orgads@gmail.com>
This commit is contained in:
Tobias Hunger
2016-10-20 13:06:11 +02:00
parent 768eb4e52e
commit 28325aa446
21 changed files with 97 additions and 0 deletions

View File

@@ -32,6 +32,8 @@
#include <vcsbase/vcsoutputwindow.h>
#include <vcsbase/vcsbaseeditorparameterwidget.h>
#include <utils/hostosinfo.h>
#include <QDir>
#include <QFileInfo>
#include <QTextStream>
@@ -171,6 +173,12 @@ VcsBaseEditorWidget *BazaarClient::annotate(
QStringList(extraOptions) << QLatin1String("--long"));
}
bool BazaarClient::isVcsDirectory(const FileName &fileName) const
{
return fileName.toFileInfo().isDir()
&& fileName.fileName().compare(Constants::BAZAARREPO, HostOsInfo::fileNameCaseSensitivity());
}
QString BazaarClient::findTopLevelForFile(const QFileInfo &file) const
{
const QString repositoryCheckFile =

View File

@@ -52,6 +52,7 @@ public:
VcsBase::VcsBaseEditorWidget *annotate(
const QString &workingDir, const QString &file, const QString &revision = QString(),
int lineNumber = -1, const QStringList &extraOptions = QStringList());
bool isVcsDirectory(const Utils::FileName &fileName) const;
QString findTopLevelForFile(const QFileInfo &file) const;
bool managesFile(const QString &workingDirectory, const QString &fileName) const;

View File

@@ -52,6 +52,11 @@ Core::Id BazaarControl::id() const
return Core::Id(VcsBase::Constants::VCS_ID_BAZAAR);
}
bool BazaarControl::isVcsFileOrDirectory(const Utils::FileName &fileName) const
{
return m_bazaarClient->isVcsDirectory(fileName);
}
bool BazaarControl::managesDirectory(const QString &directory, QString *topLevel) const
{
QFileInfo dir(directory);

View File

@@ -48,6 +48,8 @@ public:
QString displayName() const final;
Core::Id id() const final;
bool isVcsFileOrDirectory(const Utils::FileName &fileName) const final;
bool managesDirectory(const QString &filename, QString *topLevel = 0) const final;
bool managesFile(const QString &workingDirectory, const QString &fileName) const final;
bool isConfigured() const final;

View File

@@ -49,6 +49,12 @@ Core::Id ClearCaseControl::id() const
return Constants::VCS_ID_CLEARCASE;
}
bool ClearCaseControl::isVcsFileOrDirectory(const Utils::FileName &fileName) const
{
Q_UNUSED(fileName);
return false; // ClearCase has no files/directories littering the sources
}
bool ClearCaseControl::isConfigured() const
{
#ifdef WITH_TESTS

View File

@@ -42,6 +42,8 @@ public:
QString displayName() const final;
Core::Id id() const final;
bool isVcsFileOrDirectory(const Utils::FileName &fileName) const final;
bool managesDirectory(const QString &directory, QString *topLevel = 0) const final;
bool managesFile(const QString &workingDirectory, const QString &fileName) const final;

View File

@@ -92,6 +92,17 @@ public:
virtual QString displayName() const = 0;
virtual Id id() const = 0;
/*!
* \brief isVcsFileOrDirectory
* \param fileName
* \return True if filename is a file or directory that is maintained by the
* version control system.
*
* It will return true only for exact matches of the name, not for e.g. files in a
* directory owned by the version control system (e.g. .git/control).
*/
virtual bool isVcsFileOrDirectory(const Utils::FileName &fileName) const = 0;
/*!
* Returns whether files in this directory should be managed with this
* version control.
@@ -232,6 +243,9 @@ public:
{ }
~TestVersionControl();
bool isVcsFileOrDirectory(const Utils::FileName &fileName) const final
{ Q_UNUSED(fileName); return false; }
void setManagedDirectories(const QHash<QString, QString> &dirs);
void setManagedFiles(const QSet<QString> &files);

View File

@@ -33,6 +33,7 @@
#include <vcsbase/vcscommand.h>
#include <utils/fileutils.h>
#include <utils/hostosinfo.h>
#include <utils/qtcassert.h>
#include <QFileInfo>
@@ -54,6 +55,12 @@ Core::Id CvsControl::id() const
return Core::Id(VcsBase::Constants::VCS_ID_CVS);
}
bool CvsControl::isVcsFileOrDirectory(const Utils::FileName &fileName) const
{
return fileName.toFileInfo().isDir()
&& fileName.fileName().compare("CVS", Utils::HostOsInfo::fileNameCaseSensitivity());
}
bool CvsControl::isConfigured() const
{
const Utils::FileName binary = m_plugin->client()->vcsBinary();

View File

@@ -42,6 +42,8 @@ public:
QString displayName() const final;
Core::Id id() const final;
bool isVcsFileOrDirectory(const Utils::FileName &fileName) const final;
bool managesDirectory(const QString &directory, QString *topLevel = 0) const final;
bool managesFile(const QString &workingDirectory, const QString &fileName) const final;

View File

@@ -30,6 +30,8 @@
#include <vcsbase/vcsbaseconstants.h>
#include <vcsbase/vcscommand.h>
#include <utils/hostosinfo.h>
#include <QFileInfo>
#include <QProcessEnvironment>
@@ -74,6 +76,12 @@ Core::Id GitVersionControl::id() const
return Core::Id(VcsBase::Constants::VCS_ID_GIT);
}
bool GitVersionControl::isVcsFileOrDirectory(const Utils::FileName &fileName) const
{
return fileName.toFileInfo().isDir()
&& fileName.fileName().compare(".git", Utils::HostOsInfo::fileNameCaseSensitivity());
}
bool GitVersionControl::isConfigured() const
{
return !m_client->vcsBinary().isEmpty();

View File

@@ -42,6 +42,8 @@ public:
QString displayName() const final;
Core::Id id() const final;
bool isVcsFileOrDirectory(const Utils::FileName &fileName) const final;
bool managesDirectory(const QString &directory, QString *topLevel) const final;
bool managesFile(const QString &workingDirectory, const QString &fileName) const final;

View File

@@ -33,6 +33,7 @@
#include <vcsbase/vcsbaseeditorparameterwidget.h>
#include <utils/synchronousprocess.h>
#include <utils/fileutils.h>
#include <utils/hostosinfo.h>
#include <utils/qtcassert.h>
#include <QDateTime>
@@ -333,6 +334,12 @@ void MercurialClient::revertAll(const QString &workingDir, const QString &revisi
QStringList(extraOptions) << QLatin1String("--all"));
}
bool MercurialClient::isVcsDirectory(const FileName &fileName) const
{
return fileName.toFileInfo().isDir()
&& fileName.fileName().compare(Constants::MERCURIALREPO, HostOsInfo::fileNameCaseSensitivity());
}
void MercurialClient::view(const QString &source, const QString &id,
const QStringList &extraOptions)
{

View File

@@ -70,6 +70,7 @@ public:
void revertAll(const QString &workingDir, const QString &revision = QString(),
const QStringList &extraOptions = QStringList()) override;
bool isVcsDirectory(const Utils::FileName &fileName) const;
QString findTopLevelForFile(const QFileInfo &file) const override;
public slots:

View File

@@ -78,6 +78,11 @@ Core::Id MercurialControl::id() const
return Core::Id(VcsBase::Constants::VCS_ID_MERCURIAL);
}
bool MercurialControl::isVcsFileOrDirectory(const Utils::FileName &fileName) const
{
return mercurialClient->isVcsDirectory(fileName);
}
bool MercurialControl::managesDirectory(const QString &directory, QString *topLevel) const
{
QFileInfo dir(directory);

View File

@@ -47,6 +47,8 @@ public:
QString displayName() const final;
Core::Id id() const final;
bool isVcsFileOrDirectory(const Utils::FileName &fileName) const final;
bool managesDirectory(const QString &filename, QString *topLevel = 0) const final;
bool managesFile(const QString &workingDirectory, const QString &fileName) const final;
bool isConfigured() const final;

View File

@@ -49,6 +49,12 @@ Core::Id PerforceVersionControl::id() const
return Core::Id(VcsBase::Constants::VCS_ID_PERFORCE);
}
bool PerforceVersionControl::isVcsFileOrDirectory(const Utils::FileName &fileName) const
{
Q_UNUSED(fileName);
return false; // Perforce does not seem to litter its files into the source tree.
}
bool PerforceVersionControl::isConfigured() const
{
const QString binary = m_plugin->settings().p4BinaryPath();

View File

@@ -41,6 +41,7 @@ public:
QString displayName() const final;
Core::Id id() const final;
bool isVcsFileOrDirectory(const Utils::FileName &fileName) const final;
bool managesDirectory(const QString &directory, QString *topLevel = 0) const final;
bool managesFile(const QString &workingDirectory, const QString &fileName) const final;

View File

@@ -77,6 +77,11 @@ Core::Id SubversionControl::id() const
return Core::Id(VcsBase::Constants::VCS_ID_SUBVERSION);
}
bool SubversionControl::isVcsFileOrDirectory(const Utils::FileName &fileName) const
{
return m_plugin->isVcsDirectory(fileName);
}
bool SubversionControl::isConfigured() const
{
const Utils::FileName binary = m_plugin->client()->vcsBinary();

View File

@@ -40,6 +40,7 @@ public:
explicit SubversionControl(SubversionPlugin *plugin);
QString displayName() const final;
Core::Id id() const final;
bool isVcsFileOrDirectory(const Utils::FileName &fileName) const final;
bool managesDirectory(const QString &directory, QString *topLevel = 0) const final;
bool managesFile(const QString &workingDirectory, const QString &fileName) const final;

View File

@@ -54,6 +54,7 @@
#include <coreplugin/locator/commandlocator.h>
#include <coreplugin/messagemanager.h>
#include <utils/algorithm.h>
#include <utils/fileutils.h>
#include <utils/hostosinfo.h>
#include <utils/mimetypes/mimedatabase.h>
@@ -408,6 +409,15 @@ bool SubversionPlugin::initialize(const QStringList & /*arguments */, QString *e
return true;
}
bool SubversionPlugin::isVcsDirectory(const FileName &fileName)
{
const QString baseName = fileName.fileName();
return fileName.toFileInfo().isDir()
&& contains(m_svnDirectories, [baseName](const QString &s) {
return baseName.compare(s, HostOsInfo::fileNameCaseSensitivity());
});
}
SubversionClient *SubversionPlugin::client() const
{
QTC_CHECK(m_client);

View File

@@ -73,6 +73,8 @@ public:
bool initialize(const QStringList &arguments, QString *errorMessage);
bool isVcsDirectory(const Utils::FileName &fileName);
SubversionClient *client() const;
SubversionSubmitEditor *openSubversionSubmitEditor(const QString &fileName);