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:
Orgad Shaneh
2012-07-01 17:55:22 +03:00
committed by Tobias Hunger
parent 3b5c40ba47
commit 202ce8ad70
5 changed files with 54 additions and 48 deletions

View File

@@ -1331,12 +1331,11 @@ bool GitClient::synchronousShow(const QString &workingDirectory, const QString &
} }
// Retrieve list of files to be cleaned // Retrieve list of files to be cleaned
bool GitClient::synchronousCleanList(const QString &workingDirectory, bool GitClient::cleanList(const QString &workingDirectory, const QString &flag, QStringList *files, QString *errorMessage)
QStringList *files, QString *errorMessage)
{ {
files->clear(); files->clear();
QStringList args; QStringList args;
args << QLatin1String("clean") << QLatin1String("--dry-run") << QLatin1String("-dxf"); args << QLatin1String("clean") << QLatin1String("--dry-run") << flag;
QByteArray outputText; QByteArray outputText;
QByteArray errorText; QByteArray errorText;
const bool rc = fullySynchronousGit(workingDirectory, args, &outputText, &errorText); const bool rc = fullySynchronousGit(workingDirectory, args, &outputText, &errorText);
@@ -1352,6 +1351,14 @@ bool GitClient::synchronousCleanList(const QString &workingDirectory,
return true; 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, bool GitClient::synchronousApplyPatch(const QString &workingDirectory,
const QString &file, QString *errorMessage) const QString &file, QString *errorMessage)
{ {

View File

@@ -122,7 +122,7 @@ public:
bool synchronousReset(const QString &workingDirectory, bool synchronousReset(const QString &workingDirectory,
const QStringList &files = QStringList(), const QStringList &files = QStringList(),
QString *errorMessage = 0); 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 synchronousApplyPatch(const QString &workingDirectory, const QString &file, QString *errorMessage);
bool synchronousInit(const QString &workingDirectory); bool synchronousInit(const QString &workingDirectory);
bool synchronousCheckoutFiles(const QString &workingDirectory, bool synchronousCheckoutFiles(const QString &workingDirectory,
@@ -289,6 +289,7 @@ private:
const QString &workingDirectory, const QString &workingDirectory,
const QString &gitBinDirectory, const QString &gitBinDirectory,
bool silent); bool silent);
bool cleanList(const QString &workingDirectory, const QString &flag, QStringList *files, QString *errorMessage);
mutable QString m_gitVersionForBinary; mutable QString m_gitVersionForBinary;
mutable unsigned m_cachedGitVersion; mutable unsigned m_cachedGitVersion;

View File

@@ -853,31 +853,25 @@ void GitPlugin::cleanRepository(const QString &directory)
// Find files to be deleted // Find files to be deleted
QString errorMessage; QString errorMessage;
QStringList files; QStringList files;
QStringList ignoredFiles;
QApplication::setOverrideCursor(Qt::WaitCursor); 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(); QApplication::restoreOverrideCursor();
QWidget *parent = Core::ICore::mainWindow(); QWidget *parent = Core::ICore::mainWindow();
if (!gotFiles) { if (!gotFiles) {
QMessageBox::warning(parent, tr("Unable to retrieve file list"), QMessageBox::warning(parent, tr("Unable to retrieve file list"), errorMessage);
errorMessage);
return; return;
} }
if (files.isEmpty()) { if (files.isEmpty() && ignoredFiles.isEmpty()) {
QMessageBox::information(parent, tr("Repository Clean"), QMessageBox::information(parent, tr("Repository Clean"),
tr("The repository is clean.")); tr("The repository is clean."));
return; 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 // Show in dialog
VcsBase::CleanDialog dialog(parent); VcsBase::CleanDialog dialog(parent);
dialog.setFileList(directory, files); dialog.setFileList(directory, files, ignoredFiles);
dialog.exec(); dialog.exec();
} }

View File

@@ -180,7 +180,8 @@ CleanDialog::~CleanDialog()
delete d; delete d;
} }
void CleanDialog::setFileList(const QString &workingDirectory, const QStringList &l) void CleanDialog::setFileList(const QString &workingDirectory, const QStringList &files,
const QStringList &ignoredFiles)
{ {
d->m_workingDirectory = workingDirectory; d->m_workingDirectory = workingDirectory;
d->ui.groupBox->setTitle(tr("Repository: %1"). d->ui.groupBox->setTitle(tr("Repository: %1").
@@ -188,27 +189,33 @@ void CleanDialog::setFileList(const QString &workingDirectory, const QStringList
if (const int oldRowCount = d->m_filesModel->rowCount()) if (const int oldRowCount = d->m_filesModel->rowCount())
d->m_filesModel->removeRows(0, oldRowCount); d->m_filesModel->removeRows(0, oldRowCount);
foreach (const QString &fileName, files)
addFile(workingDirectory, fileName, true);
foreach (const QString &fileName, ignoredFiles)
addFile(workingDirectory, fileName, false);
for (int c = 0; c < d->m_filesModel->columnCount(); c++)
d->ui.filesTreeView->resizeColumnToContents(c);
}
void CleanDialog::addFile(const QString &workingDirectory, QString fileName, bool checked)
{
QStyle *style = QApplication::style(); QStyle *style = QApplication::style();
const QIcon folderIcon = style->standardIcon(QStyle::SP_DirIcon); const QIcon folderIcon = style->standardIcon(QStyle::SP_DirIcon);
const QIcon fileIcon = style->standardIcon(QStyle::SP_FileIcon); const QIcon fileIcon = style->standardIcon(QStyle::SP_FileIcon);
const QString diffSuffix = QLatin1String(".diff");
const QString patchSuffix = QLatin1String(".patch");
const QString proUserSuffix = QLatin1String(".pro.user");
const QString qmlProUserSuffix = QLatin1String(".qmlproject.user");
const QChar slash = QLatin1Char('/'); const QChar slash = QLatin1Char('/');
// Do not initially check patches or 'pro.user' files for deletion. // Clean the trailing slash of directories
foreach (const QString &fileName, l) { if (fileName.endsWith(slash))
const QFileInfo fi(workingDirectory + slash + fileName); fileName.chop(1);
const bool isDir = fi.isDir(); QFileInfo fi(workingDirectory + slash + fileName);
bool isDir = fi.isDir();
if (isDir)
checked = false;
QStandardItem *nameItem = new QStandardItem(QDir::toNativeSeparators(fileName)); QStandardItem *nameItem = new QStandardItem(QDir::toNativeSeparators(fileName));
nameItem->setFlags(Qt::ItemIsUserCheckable|Qt::ItemIsEnabled); nameItem->setFlags(Qt::ItemIsUserCheckable|Qt::ItemIsEnabled);
nameItem->setIcon(isDir ? folderIcon : fileIcon); nameItem->setIcon(isDir ? folderIcon : fileIcon);
const bool saveFile = !isDir && (fileName.endsWith(diffSuffix)
|| fileName.endsWith(patchSuffix)
|| fileName.endsWith(proUserSuffix)
|| fileName.endsWith(qmlProUserSuffix));
nameItem->setCheckable(true); nameItem->setCheckable(true);
nameItem->setCheckState(saveFile ? Qt::Unchecked : Qt::Checked); nameItem->setCheckState(checked ? Qt::Checked : Qt::Unchecked);
nameItem->setData(QVariant(fi.absoluteFilePath()), Internal::fileNameRole); nameItem->setData(QVariant(fi.absoluteFilePath()), Internal::fileNameRole);
nameItem->setData(QVariant(isDir), Internal::isDirectoryRole); nameItem->setData(QVariant(isDir), Internal::isDirectoryRole);
// Tooltip with size information // Tooltip with size information
@@ -218,10 +225,6 @@ void CleanDialog::setFileList(const QString &workingDirectory, const QStringList
.arg(fi.size()).arg(lastModified)); .arg(fi.size()).arg(lastModified));
} }
d->m_filesModel->appendRow(nameItem); d->m_filesModel->appendRow(nameItem);
}
for (int c = 0; c < d->m_filesModel->columnCount(); c++)
d->ui.filesTreeView->resizeColumnToContents(c);
} }
QStringList CleanDialog::checkedFiles() const QStringList CleanDialog::checkedFiles() const

View File

@@ -53,7 +53,7 @@ public:
explicit CleanDialog(QWidget *parent = 0); explicit CleanDialog(QWidget *parent = 0);
~CleanDialog(); ~CleanDialog();
void setFileList(const QString &workingDirectory, const QStringList &); void setFileList(const QString &workingDirectory, const QStringList &files, const QStringList &ignoredFiles);
public slots: public slots:
void accept(); void accept();
@@ -67,6 +67,7 @@ private slots:
private: private:
QStringList checkedFiles() const; QStringList checkedFiles() const;
bool promptToDelete(); bool promptToDelete();
void addFile(const QString &workingDirectory, QString fileName, bool checked);
Internal::CleanDialogPrivate *const d; Internal::CleanDialogPrivate *const d;
}; };