summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlessandro Portale <alessandro.portale@qt.io>2019-11-21 01:22:28 +0100
committerAlessandro Portale <alessandro.portale@qt.io>2019-11-21 07:49:10 +0000
commitf8f6f53960e774f48ca29ea82191c9e08130817b (patch)
tree2ad6dd4df53fb5a13384961ab2f7751235e5e4ca
parentb738a9d02d57dd7433f3933aa4f330121dbd2808 (diff)
downloadqt-creator-f8f6f53960e774f48ca29ea82191c9e08130817b.tar.gz
McuSupport: Add optional color depth (bpp) property to McuTarget
...include that in kit names and add it as "QUL_COLOR_DEPTH" CMake parameter. Change-Id: I14ba7ce465c54d525683be2660d2e24b6ecfed6c Reviewed-by: hjk <hjk@qt.io>
-rw-r--r--src/plugins/mcusupport/mcusupportoptions.cpp31
-rw-r--r--src/plugins/mcusupport/mcusupportoptions.h3
2 files changed, 29 insertions, 5 deletions
diff --git a/src/plugins/mcusupport/mcusupportoptions.cpp b/src/plugins/mcusupport/mcusupportoptions.cpp
index d45bafc666..10147d2ac3 100644
--- a/src/plugins/mcusupport/mcusupportoptions.cpp
+++ b/src/plugins/mcusupport/mcusupportoptions.cpp
@@ -251,6 +251,16 @@ bool McuTarget::isValid() const
});
}
+int McuTarget::colorDepth() const
+{
+ return m_colorDepth;
+}
+
+void McuTarget::setColorDepth(int colorDepth)
+{
+ m_colorDepth = colorDepth;
+}
+
static McuPackage *createQtForMCUsPackage()
{
auto result = new McuPackage(
@@ -387,6 +397,12 @@ McuSupportOptions::McuSupportOptions(QObject *parent)
// STM
auto mcuTarget = new McuTarget(vendorStm, "stm32f7508", stmEvalPackages);
mcuTarget->setToolChainFile("CMake/stm32f7508-discovery.cmake");
+ mcuTarget->setColorDepth(32);
+ mcuTargets.append(mcuTarget);
+
+ mcuTarget = new McuTarget(vendorStm, "stm32f7508", stmEvalPackages);
+ mcuTarget->setToolChainFile("CMake/stm32f7508-discovery.cmake");
+ mcuTarget->setColorDepth(16);
mcuTargets.append(mcuTarget);
mcuTarget = new McuTarget(vendorStm, "stm32f769i", stmEvalPackages);
@@ -407,6 +423,7 @@ McuSupportOptions::McuSupportOptions(QObject *parent)
// Desktop
mcuTarget = new McuTarget(vendorQt, "Desktop", desktopPackages);
mcuTarget->setQulPlatform("Qt");
+ mcuTarget->setColorDepth(32);
mcuTargets.append(mcuTarget);
for (auto package : packages)
@@ -552,11 +569,11 @@ static void setKitCMakeOptions(ProjectExplorer::Kit *k, const McuTarget* mcuTarg
if (!mcuTarget->qulPlatform().isEmpty())
config.append(CMakeConfigItem("QUL_PLATFORM",
mcuTarget->qulPlatform().toUtf8()));
- if (mcuTargetIsDesktop(mcuTarget)) {
+ if (mcuTargetIsDesktop(mcuTarget))
config.append(CMakeConfigItem("CMAKE_PREFIX_PATH", "%{Qt:QT_INSTALL_PREFIX}"));
- // TODO: Hack! Implement color depth variants of all targets
- config.append(CMakeConfigItem("QUL_COLOR_DEPTH", "32"));
- }
+ if (mcuTarget->colorDepth() >= 0)
+ config.append(CMakeConfigItem("QUL_COLOR_DEPTH",
+ QString::number(mcuTarget->colorDepth()).toLatin1()));
CMakeConfigurationKitAspect::setConfiguration(k, config);
if (Utils::HostOsInfo::isWindowsHost())
CMakeGeneratorKitAspect::setGenerator(k, "NMake Makefiles JOM");
@@ -565,7 +582,11 @@ static void setKitCMakeOptions(ProjectExplorer::Kit *k, const McuTarget* mcuTarg
QString McuSupportOptions::kitName(const McuTarget *mcuTarget) const
{
// TODO: get version from qulSdkPackage and insert into name
- return QString::fromLatin1("Qt for MCUs - %1 %2").arg(mcuTarget->vendor(), mcuTarget->model());
+ const QString colorDepth = mcuTarget->colorDepth() > 0
+ ? QString::fromLatin1(" %1bpp").arg(mcuTarget->colorDepth())
+ : "";
+ return QString::fromLatin1("Qt for MCUs - %1 %2%3")
+ .arg(mcuTarget->vendor(), mcuTarget->model(), colorDepth);
}
QList<ProjectExplorer::Kit *> McuSupportOptions::existingKits(const McuTarget *mcuTargt)
diff --git a/src/plugins/mcusupport/mcusupportoptions.h b/src/plugins/mcusupport/mcusupportoptions.h
index 8a64260180..f8cba93199 100644
--- a/src/plugins/mcusupport/mcusupportoptions.h
+++ b/src/plugins/mcusupport/mcusupportoptions.h
@@ -110,6 +110,8 @@ public:
QString toolChainFile() const;
void setQulPlatform(const QString &qulPlatform);
QString qulPlatform() const;
+ void setColorDepth(int colorDepth);
+ int colorDepth() const;
bool isValid() const;
private:
@@ -118,6 +120,7 @@ private:
const QVector<McuPackage*> m_packages;
QString m_toolChainFile;
QString m_qulPlatform;
+ int m_colorDepth = -1;
};
class McuSupportOptions : public QObject