summaryrefslogtreecommitdiff
path: root/src/plugins/winrt/winrtrunfactories.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/plugins/winrt/winrtrunfactories.cpp')
-rw-r--r--src/plugins/winrt/winrtrunfactories.cpp50
1 files changed, 29 insertions, 21 deletions
diff --git a/src/plugins/winrt/winrtrunfactories.cpp b/src/plugins/winrt/winrtrunfactories.cpp
index c49f41b0b3..fda57eb5b2 100644
--- a/src/plugins/winrt/winrtrunfactories.cpp
+++ b/src/plugins/winrt/winrtrunfactories.cpp
@@ -37,25 +37,16 @@
#include <projectexplorer/kitinformation.h>
#include <projectexplorer/project.h>
#include <projectexplorer/target.h>
-#include <projectexplorer/toolchain.h>
-
-#include <debugger/debuggerkitinformation.h>
-#include <debugger/debuggerplugin.h>
-#include <debugger/debuggerrunner.h>
-#include <debugger/debuggerstartparameters.h>
-
+#include <qmakeprojectmanager/qmakeproject.h>
#include <utils/qtcassert.h>
-#include <QLocalServer>
-#include <QLocalSocket>
-
using namespace ProjectExplorer;
+using QmakeProjectManager::QmakeProject;
+using QmakeProjectManager::QmakeProFileNode;
namespace WinRt {
namespace Internal {
-static const char winrtConfigurationIdC[] = "WinRTConfigurationID";
-
static bool isKitCompatible(Kit *kit)
{
IDevice::ConstPtr device = DeviceKitInformation::device(kit);
@@ -72,13 +63,17 @@ WinRtRunConfigurationFactory::WinRtRunConfigurationFactory()
{
}
-QList<Core::Id> WinRtRunConfigurationFactory::availableCreationIds(Target *parent, CreationMode mode) const
+QList<Core::Id> WinRtRunConfigurationFactory::availableCreationIds(Target *parent,
+ CreationMode mode) const
{
- Q_UNUSED(mode)
- QList<Core::Id> result;
- if (isKitCompatible(parent->kit()))
- result.append(Core::Id(winrtConfigurationIdC));
- return result;
+ if (!canHandle(parent))
+ return QList<Core::Id>();
+
+ QmakeProject *project = static_cast<QmakeProject *>(parent->project());
+ QList<QmakeProFileNode *> nodes = project->applicationProFiles();
+ if (mode == AutoCreate)
+ nodes = QmakeProject::nodesWithQtcRunnable(nodes);
+ return QmakeProject::idsForNodes(Core::Id(Constants::WINRT_RC_PREFIX), nodes);
}
QString WinRtRunConfigurationFactory::displayNameForId(Core::Id id) const
@@ -89,7 +84,8 @@ QString WinRtRunConfigurationFactory::displayNameForId(Core::Id id) const
bool WinRtRunConfigurationFactory::canCreate(Target *parent, Core::Id id) const
{
- return id == winrtConfigurationIdC && isKitCompatible(parent->kit());
+ Q_UNUSED(id);
+ return canHandle(parent);
}
RunConfiguration *WinRtRunConfigurationFactory::doCreate(Target *parent, Core::Id id)
@@ -99,12 +95,15 @@ RunConfiguration *WinRtRunConfigurationFactory::doCreate(Target *parent, Core::I
bool WinRtRunConfigurationFactory::canRestore(Target *parent, const QVariantMap &map) const
{
- return ProjectExplorer::idFromMap(map) == winrtConfigurationIdC && isKitCompatible(parent->kit());
+ if (!canHandle(parent))
+ return false;
+
+ return idFromMap(map).toString().startsWith(QLatin1String(Constants::WINRT_RC_PREFIX));
}
RunConfiguration *WinRtRunConfigurationFactory::doRestore(Target *parent, const QVariantMap &map)
{
- RunConfiguration *config = new WinRtRunConfiguration(parent, winrtConfigurationIdC);
+ RunConfiguration *config = new WinRtRunConfiguration(parent, idFromMap(map));
config->fromMap(map);
return config;
}
@@ -123,6 +122,15 @@ RunConfiguration *WinRtRunConfigurationFactory::clone(Target *parent, RunConfigu
return 0;
}
+bool WinRtRunConfigurationFactory::canHandle(Target *parent) const
+{
+ if (!isKitCompatible(parent->kit()))
+ return false;
+ if (!qobject_cast<QmakeProject *>(parent->project()))
+ return false;
+ return true;
+}
+
WinRtRunControlFactory::WinRtRunControlFactory()
{
}