forked from qt-creator/qt-creator
ProjectManagers: Avoid deletion of special files
Do not allow deletion or rename of files that are used to define or manage projects. This fixes issues of being able to remove or rename pri and pro files of qmake based projects as well as special files used by the GenericProjectManager. Change-Id: Ib173abf04368f0625a9e481bb7290aa11933e62f Reviewed-by: Christian Kandeler <christian.kandeler@qt.io>
This commit is contained in:
@@ -3264,20 +3264,21 @@ void ProjectExplorerPluginPrivate::updateContextMenuActions()
|
|||||||
m_addExistingFilesAction->setEnabled(supports(AddExistingFile));
|
m_addExistingFilesAction->setEnabled(supports(AddExistingFile));
|
||||||
m_addExistingDirectoryAction->setEnabled(supports(AddExistingDirectory));
|
m_addExistingDirectoryAction->setEnabled(supports(AddExistingDirectory));
|
||||||
m_renameFileAction->setEnabled(supports(Rename));
|
m_renameFileAction->setEnabled(supports(Rename));
|
||||||
} else if (currentNode->asFileNode()) {
|
} else if (auto fileNode = currentNode->asFileNode()) {
|
||||||
// Enable and show remove / delete in magic ways:
|
// Enable and show remove / delete in magic ways:
|
||||||
// If both are disabled show Remove
|
// If both are disabled show Remove
|
||||||
// If both are enabled show both (can't happen atm)
|
// If both are enabled show both (can't happen atm)
|
||||||
// If only removeFile is enabled only show it
|
// If only removeFile is enabled only show it
|
||||||
// If only deleteFile is enable only show it
|
// If only deleteFile is enable only show it
|
||||||
bool enableRemove = supports(RemoveFile);
|
bool isTypeProject = fileNode->fileType() == FileType::Project;
|
||||||
|
bool enableRemove = !isTypeProject && supports(RemoveFile);
|
||||||
m_removeFileAction->setEnabled(enableRemove);
|
m_removeFileAction->setEnabled(enableRemove);
|
||||||
bool enableDelete = supports(EraseFile);
|
bool enableDelete = !isTypeProject && supports(EraseFile);
|
||||||
m_deleteFileAction->setEnabled(enableDelete);
|
m_deleteFileAction->setEnabled(enableDelete);
|
||||||
m_deleteFileAction->setVisible(enableDelete);
|
m_deleteFileAction->setVisible(enableDelete);
|
||||||
|
|
||||||
m_removeFileAction->setVisible(!enableDelete || enableRemove);
|
m_removeFileAction->setVisible(!enableDelete || enableRemove);
|
||||||
m_renameFileAction->setEnabled(supports(Rename));
|
m_renameFileAction->setEnabled(!isTypeProject && supports(Rename));
|
||||||
const bool currentNodeIsTextFile = isTextFile(
|
const bool currentNodeIsTextFile = isTextFile(
|
||||||
currentNode->filePath().toString());
|
currentNode->filePath().toString());
|
||||||
m_diffFileAction->setEnabled(DiffService::instance()
|
m_diffFileAction->setEnabled(DiffService::instance()
|
||||||
|
@@ -217,17 +217,8 @@ static bool supportsNodeAction(ProjectAction action, const Node *node)
|
|||||||
const QbsProject * const project = parentQbsProjectNode(node)->project();
|
const QbsProject * const project = parentQbsProjectNode(node)->project();
|
||||||
if (!project->isProjectEditable())
|
if (!project->isProjectEditable())
|
||||||
return false;
|
return false;
|
||||||
|
if (action == RemoveFile || action == Rename)
|
||||||
auto equalsNodeFilePath = [node](const QString &str)
|
return node->asFileNode();
|
||||||
{
|
|
||||||
return str == node->filePath().toString();
|
|
||||||
};
|
|
||||||
|
|
||||||
if (action == RemoveFile || action == Rename) {
|
|
||||||
if (node->asFileNode())
|
|
||||||
return !Utils::contains(project->qbsProject().buildSystemFiles(), equalsNodeFilePath);
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user