From f8db7aca18fda294eae40df4ff5ba407a942f94e Mon Sep 17 00:00:00 2001 From: dt Date: Tue, 23 Mar 2010 16:02:59 +0100 Subject: [PATCH] Warn the user against building in a subdirectory of the source directory Reviewed-By: hunger Task-Nr: QTCREATORBUG-670 --- .../qt4projectconfigwidget.cpp | 28 +++++++++++++------ .../qt4projectconfigwidget.ui | 8 +++--- 2 files changed, 24 insertions(+), 12 deletions(-) diff --git a/src/plugins/qt4projectmanager/qt4projectconfigwidget.cpp b/src/plugins/qt4projectmanager/qt4projectconfigwidget.cpp index 44ded3ddec6..96781714567 100644 --- a/src/plugins/qt4projectmanager/qt4projectconfigwidget.cpp +++ b/src/plugins/qt4projectmanager/qt4projectconfigwidget.cpp @@ -319,16 +319,28 @@ void Qt4ProjectConfigWidget::updateImportLabel() } } - if (targetMatches) { - m_ui->importProblemLabel->setVisible(false); - m_ui->importWarningLabel->setVisible(false); + QString sourceDirectory = + QFileInfo(m_buildConfiguration->qt4Target()->qt4Project()->file()->fileName()).absolutePath(); + if (!sourceDirectory.endsWith('/')) + sourceDirectory.append('/'); + bool invalidBuildDirectory = m_buildConfiguration->shadowBuild() + && m_buildConfiguration->buildDirectory().startsWith(sourceDirectory); + + if (invalidBuildDirectory) { + m_ui->problemLabel->setVisible(true); + m_ui->warningLabel->setVisible(true); + m_ui->importLabel->setVisible(visible); + m_ui->problemLabel->setText(tr("Building in subdirectories of the source directory is not supported by qmake.")); + } else if (targetMatches) { + m_ui->problemLabel->setVisible(false); + m_ui->warningLabel->setVisible(false); m_ui->importLabel->setVisible(visible); } else { - m_ui->importWarningLabel->setVisible(visible); - m_ui->importProblemLabel->setVisible(visible); - m_ui->importProblemLabel->setText(tr("An incompatible build exists in %1, which will be overwritten.", - "%1 build directory"). - arg(m_ui->shadowBuildDirEdit->path())); + m_ui->warningLabel->setVisible(visible); + m_ui->problemLabel->setVisible(visible); + m_ui->problemLabel->setText(tr("An incompatible build exists in %1, which will be overwritten.", + "%1 build directory"). + arg(m_ui->shadowBuildDirEdit->path())); m_ui->importLabel->setVisible(false); } } diff --git a/src/plugins/qt4projectmanager/qt4projectconfigwidget.ui b/src/plugins/qt4projectmanager/qt4projectconfigwidget.ui index 81cb23e9a03..bb0acd3a161 100644 --- a/src/plugins/qt4projectmanager/qt4projectconfigwidget.ui +++ b/src/plugins/qt4projectmanager/qt4projectconfigwidget.ui @@ -6,7 +6,7 @@ 0 0 - 487 + 712 194 @@ -138,16 +138,16 @@ - + :/projectexplorer/images/compile_warning.png - + - The Qt Version about to be imported does not support this target. + problemLabel