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

@@ -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;