forked from qt-creator/qt-creator
Git: Improve Clean dialog
Check file iff it is not ignored Change-Id: I16a489bdd772ea9b4df462b449a23324b5ef3b77 Reviewed-by: Tobias Hunger <tobias.hunger@nokia.com>
This commit is contained in:
committed by
Tobias Hunger
parent
3b5c40ba47
commit
202ce8ad70
@@ -1331,12 +1331,11 @@ bool GitClient::synchronousShow(const QString &workingDirectory, const QString &
|
||||
}
|
||||
|
||||
// Retrieve list of files to be cleaned
|
||||
bool GitClient::synchronousCleanList(const QString &workingDirectory,
|
||||
QStringList *files, QString *errorMessage)
|
||||
bool GitClient::cleanList(const QString &workingDirectory, const QString &flag, QStringList *files, QString *errorMessage)
|
||||
{
|
||||
files->clear();
|
||||
QStringList args;
|
||||
args << QLatin1String("clean") << QLatin1String("--dry-run") << QLatin1String("-dxf");
|
||||
args << QLatin1String("clean") << QLatin1String("--dry-run") << flag;
|
||||
QByteArray outputText;
|
||||
QByteArray errorText;
|
||||
const bool rc = fullySynchronousGit(workingDirectory, args, &outputText, &errorText);
|
||||
@@ -1352,6 +1351,14 @@ bool GitClient::synchronousCleanList(const QString &workingDirectory,
|
||||
return true;
|
||||
}
|
||||
|
||||
bool GitClient::synchronousCleanList(const QString &workingDirectory, QStringList *files,
|
||||
QStringList *ignoredFiles, QString *errorMessage)
|
||||
{
|
||||
bool res = cleanList(workingDirectory, QLatin1String("-df"), files, errorMessage);
|
||||
res &= cleanList(workingDirectory, QLatin1String("-dXf"), ignoredFiles, errorMessage);
|
||||
return res;
|
||||
}
|
||||
|
||||
bool GitClient::synchronousApplyPatch(const QString &workingDirectory,
|
||||
const QString &file, QString *errorMessage)
|
||||
{
|
||||
|
||||
@@ -122,7 +122,7 @@ public:
|
||||
bool synchronousReset(const QString &workingDirectory,
|
||||
const QStringList &files = QStringList(),
|
||||
QString *errorMessage = 0);
|
||||
bool synchronousCleanList(const QString &workingDirectory, QStringList *files, QString *errorMessage);
|
||||
bool synchronousCleanList(const QString &workingDirectory, QStringList *files, QStringList *ignoredFiles, QString *errorMessage);
|
||||
bool synchronousApplyPatch(const QString &workingDirectory, const QString &file, QString *errorMessage);
|
||||
bool synchronousInit(const QString &workingDirectory);
|
||||
bool synchronousCheckoutFiles(const QString &workingDirectory,
|
||||
@@ -289,6 +289,7 @@ private:
|
||||
const QString &workingDirectory,
|
||||
const QString &gitBinDirectory,
|
||||
bool silent);
|
||||
bool cleanList(const QString &workingDirectory, const QString &flag, QStringList *files, QString *errorMessage);
|
||||
|
||||
mutable QString m_gitVersionForBinary;
|
||||
mutable unsigned m_cachedGitVersion;
|
||||
|
||||
@@ -853,31 +853,25 @@ void GitPlugin::cleanRepository(const QString &directory)
|
||||
// Find files to be deleted
|
||||
QString errorMessage;
|
||||
QStringList files;
|
||||
QStringList ignoredFiles;
|
||||
QApplication::setOverrideCursor(Qt::WaitCursor);
|
||||
const bool gotFiles = m_gitClient->synchronousCleanList(directory, &files, &errorMessage);
|
||||
const bool gotFiles = m_gitClient->synchronousCleanList(directory, &files, &ignoredFiles, &errorMessage);
|
||||
QApplication::restoreOverrideCursor();
|
||||
|
||||
QWidget *parent = Core::ICore::mainWindow();
|
||||
if (!gotFiles) {
|
||||
QMessageBox::warning(parent, tr("Unable to retrieve file list"),
|
||||
errorMessage);
|
||||
QMessageBox::warning(parent, tr("Unable to retrieve file list"), errorMessage);
|
||||
return;
|
||||
}
|
||||
if (files.isEmpty()) {
|
||||
if (files.isEmpty() && ignoredFiles.isEmpty()) {
|
||||
QMessageBox::information(parent, tr("Repository Clean"),
|
||||
tr("The repository is clean."));
|
||||
return;
|
||||
}
|
||||
// Clean the trailing slash of directories
|
||||
const QChar slash = QLatin1Char('/');
|
||||
const QStringList::iterator end = files.end();
|
||||
for (QStringList::iterator it = files.begin(); it != end; ++it)
|
||||
if (it->endsWith(slash))
|
||||
it->truncate(it->size() - 1);
|
||||
|
||||
// Show in dialog
|
||||
VcsBase::CleanDialog dialog(parent);
|
||||
dialog.setFileList(directory, files);
|
||||
dialog.setFileList(directory, files, ignoredFiles);
|
||||
dialog.exec();
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user