forked from qt-creator/qt-creator
CppTools: Remove all references to the tool chain in the project part
Change-Id: I5fd55eadf94c8a185c2082b93b27bf4432e5cabf Reviewed-by: Tobias Hunger <tobias.hunger@theqtcompany.com> Reviewed-by: Nikolai Kosjar <nikolai.kosjar@theqtcompany.com>
This commit is contained in:
@@ -25,8 +25,6 @@
|
||||
|
||||
#include "projectpart.h"
|
||||
|
||||
#include <projectexplorer/headerpath.h>
|
||||
|
||||
#include <QDir>
|
||||
#include <QTextStream>
|
||||
|
||||
@@ -37,78 +35,11 @@ ProjectPart::ProjectPart()
|
||||
, languageVersion(CXX14)
|
||||
, languageExtensions(NoExtensions)
|
||||
, qtVersion(UnknownQt)
|
||||
, warningFlags(ProjectExplorer::ToolChain::WarningsDefault)
|
||||
, warningFlags(ProjectExplorer::WarningFlags::Default)
|
||||
, selectedForBuilding(true)
|
||||
{
|
||||
}
|
||||
|
||||
static ProjectPartHeaderPath toProjectPartHeaderPath(const ProjectExplorer::HeaderPath &headerPath)
|
||||
{
|
||||
const ProjectPartHeaderPath::Type headerPathType =
|
||||
headerPath.kind() == ProjectExplorer::HeaderPath::FrameworkHeaderPath
|
||||
? ProjectPartHeaderPath::FrameworkPath
|
||||
: ProjectPartHeaderPath::IncludePath;
|
||||
|
||||
return ProjectPartHeaderPath(headerPath.path(), headerPathType);
|
||||
}
|
||||
|
||||
/*!
|
||||
\brief Retrieves info from concrete compiler using it's flags.
|
||||
|
||||
\param tc Either nullptr or toolchain for project's active target.
|
||||
\param cxxflags C++ or Objective-C++ flags.
|
||||
\param cflags C or ObjectiveC flags if possible, \a cxxflags otherwise.
|
||||
*/
|
||||
void ProjectPart::evaluateToolchain(const ProjectExplorer::ToolChain *tc,
|
||||
const QStringList &commandLineFlags,
|
||||
const Utils::FileName &sysRoot)
|
||||
{
|
||||
if (!tc)
|
||||
return;
|
||||
|
||||
using namespace ProjectExplorer;
|
||||
ToolChain::CompilerFlags flags = tc->compilerFlags(commandLineFlags);
|
||||
|
||||
if (flags & ToolChain::StandardC11)
|
||||
languageVersion = C11;
|
||||
else if (flags & ToolChain::StandardC99)
|
||||
languageVersion = C99;
|
||||
else if (flags & ToolChain::StandardCxx17)
|
||||
languageVersion = CXX17;
|
||||
else if (flags & ToolChain::StandardCxx14)
|
||||
languageVersion = CXX14;
|
||||
else if (flags & ToolChain::StandardCxx11)
|
||||
languageVersion = CXX11;
|
||||
else if (flags & ToolChain::StandardCxx98)
|
||||
languageVersion = CXX98;
|
||||
else
|
||||
languageVersion = CXX11;
|
||||
|
||||
if (flags & ToolChain::BorlandExtensions)
|
||||
languageExtensions |= BorlandExtensions;
|
||||
if (flags & ToolChain::GnuExtensions)
|
||||
languageExtensions |= GnuExtensions;
|
||||
if (flags & ToolChain::MicrosoftExtensions)
|
||||
languageExtensions |= MicrosoftExtensions;
|
||||
if (flags & ToolChain::OpenMP)
|
||||
languageExtensions |= OpenMPExtensions;
|
||||
if (flags & ToolChain::ObjectiveC)
|
||||
languageExtensions |= ObjectiveCExtensions;
|
||||
|
||||
warningFlags = tc->warningFlags(commandLineFlags);
|
||||
|
||||
const QList<ProjectExplorer::HeaderPath> headers = tc->systemHeaderPaths(commandLineFlags, sysRoot);
|
||||
foreach (const ProjectExplorer::HeaderPath &header, headers) {
|
||||
const ProjectPartHeaderPath headerPath = toProjectPartHeaderPath(header);
|
||||
if (!headerPaths.contains(headerPath))
|
||||
headerPaths << headerPath;
|
||||
}
|
||||
|
||||
toolchainDefines = tc->predefinedMacros(commandLineFlags);
|
||||
toolchainType = tc->typeId();
|
||||
updateLanguageFeatures();
|
||||
}
|
||||
|
||||
void ProjectPart::updateLanguageFeatures()
|
||||
{
|
||||
const bool hasQt = qtVersion != NoQt;
|
||||
|
||||
@@ -31,7 +31,7 @@
|
||||
#include "cppprojectfile.h"
|
||||
#include "projectpartheaderpath.h"
|
||||
|
||||
#include <projectexplorer/toolchain.h>
|
||||
#include <projectexplorer/projectexplorer_global.h>
|
||||
|
||||
#include <coreplugin/id.h>
|
||||
|
||||
@@ -88,10 +88,6 @@ public: // Types
|
||||
public: // methods
|
||||
ProjectPart();
|
||||
|
||||
void evaluateToolchain(const ProjectExplorer::ToolChain *tc,
|
||||
const QStringList &commandLineFlags,
|
||||
const Utils::FileName &sysRoot);
|
||||
|
||||
void updateLanguageFeatures();
|
||||
Ptr copy() const;
|
||||
|
||||
@@ -114,7 +110,7 @@ public: // fields
|
||||
LanguageExtensions languageExtensions;
|
||||
CPlusPlus::LanguageFeatures languageFeatures;
|
||||
QtVersion qtVersion;
|
||||
ProjectExplorer::ToolChain::WarningFlags warningFlags;
|
||||
ProjectExplorer::WarningFlags warningFlags;
|
||||
bool selectedForBuilding;
|
||||
};
|
||||
|
||||
|
||||
@@ -28,10 +28,12 @@
|
||||
#include "cppprojectfile.h"
|
||||
#include "cpptoolsconstants.h"
|
||||
|
||||
#include <projectexplorer/headerpath.h>
|
||||
#include <projectexplorer/kitinformation.h>
|
||||
#include <projectexplorer/project.h>
|
||||
#include <projectexplorer/projectexplorerconstants.h>
|
||||
#include <projectexplorer/target.h>
|
||||
#include <projectexplorer/toolchain.h>
|
||||
|
||||
#include <utils/mimetypes/mimedatabase.h>
|
||||
#include <utils/qtcassert.h>
|
||||
@@ -235,6 +237,83 @@ QList<Core::Id> ProjectPartBuilder::createProjectPartsForFiles(const QStringList
|
||||
return languages;
|
||||
}
|
||||
|
||||
namespace {
|
||||
|
||||
ProjectPartHeaderPath toProjectPartHeaderPath(const ProjectExplorer::HeaderPath &headerPath)
|
||||
{
|
||||
const ProjectPartHeaderPath::Type headerPathType =
|
||||
headerPath.kind() == ProjectExplorer::HeaderPath::FrameworkHeaderPath
|
||||
? ProjectPartHeaderPath::FrameworkPath
|
||||
: ProjectPartHeaderPath::IncludePath;
|
||||
|
||||
return ProjectPartHeaderPath(headerPath.path(), headerPathType);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/*!
|
||||
\brief Retrieves info from concrete compiler using it's flags.
|
||||
|
||||
\param projectPart Project part which can never be an null pointer.
|
||||
\param toolChain Either nullptr or toolchain for project's active target.
|
||||
\param cxxflags C++ or Objective-C++ flags.
|
||||
\param cflags C or ObjectiveC flags if possible, \a cxxflags otherwise.
|
||||
*/
|
||||
void ProjectPartBuilder::evaluateProjectPartToolchain(
|
||||
ProjectPart *projectPart,
|
||||
const ProjectExplorer::ToolChain *toolChain,
|
||||
const QStringList &commandLineFlags,
|
||||
const Utils::FileName &sysRoot)
|
||||
{
|
||||
if (toolChain == nullptr)
|
||||
return;
|
||||
|
||||
using namespace ProjectExplorer;
|
||||
ToolChain::CompilerFlags flags = toolChain->compilerFlags(commandLineFlags);
|
||||
auto &languageVersion = projectPart->languageVersion;
|
||||
|
||||
if (flags & ToolChain::StandardC11)
|
||||
languageVersion = ProjectPart::C11;
|
||||
else if (flags & ToolChain::StandardC99)
|
||||
languageVersion = ProjectPart::C99;
|
||||
else if (flags & ToolChain::StandardCxx17)
|
||||
languageVersion = ProjectPart::CXX17;
|
||||
else if (flags & ToolChain::StandardCxx14)
|
||||
languageVersion = ProjectPart::CXX14;
|
||||
else if (flags & ToolChain::StandardCxx11)
|
||||
languageVersion = ProjectPart::CXX11;
|
||||
else if (flags & ToolChain::StandardCxx98)
|
||||
languageVersion = ProjectPart::CXX98;
|
||||
else
|
||||
languageVersion = ProjectPart::CXX11;
|
||||
|
||||
auto &languageExtensions = projectPart->languageExtensions;
|
||||
|
||||
if (flags & ToolChain::BorlandExtensions)
|
||||
languageExtensions |= ProjectPart::BorlandExtensions;
|
||||
if (flags & ToolChain::GnuExtensions)
|
||||
languageExtensions |= ProjectPart::GnuExtensions;
|
||||
if (flags & ToolChain::MicrosoftExtensions)
|
||||
languageExtensions |= ProjectPart::MicrosoftExtensions;
|
||||
if (flags & ToolChain::OpenMP)
|
||||
languageExtensions |= ProjectPart::OpenMPExtensions;
|
||||
if (flags & ToolChain::ObjectiveC)
|
||||
languageExtensions |= ProjectPart::ObjectiveCExtensions;
|
||||
|
||||
projectPart->warningFlags = toolChain->warningFlags(commandLineFlags);
|
||||
|
||||
const QList<ProjectExplorer::HeaderPath> headers = toolChain->systemHeaderPaths(commandLineFlags, sysRoot);
|
||||
foreach (const ProjectExplorer::HeaderPath &header, headers) {
|
||||
const ProjectPartHeaderPath headerPath = toProjectPartHeaderPath(header);
|
||||
if (!projectPart->headerPaths.contains(headerPath))
|
||||
projectPart->headerPaths.push_back(headerPath);
|
||||
}
|
||||
|
||||
projectPart->toolchainDefines = toolChain->predefinedMacros(commandLineFlags);
|
||||
projectPart->toolchainType = toolChain->typeId();
|
||||
projectPart->updateLanguageFeatures();
|
||||
}
|
||||
|
||||
namespace Internal {
|
||||
|
||||
class ProjectFileAdder
|
||||
@@ -302,7 +381,10 @@ void ProjectPartBuilder::createProjectPart(const QStringList &theSources,
|
||||
if (ProjectExplorer::ToolChain *toolChain = ProjectExplorer::ToolChainKitInformation::toolChain(kit)) {
|
||||
const QStringList flags = languageVersion >= ProjectPart::CXX98 ? m_cxxFlags
|
||||
: m_cFlags;
|
||||
part->evaluateToolchain(toolChain, flags, ProjectExplorer::SysRootKitInformation::sysRoot(kit));
|
||||
evaluateProjectPartToolchain(part.data(),
|
||||
toolChain,
|
||||
flags,
|
||||
ProjectExplorer::SysRootKitInformation::sysRoot(kit));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -31,6 +31,10 @@
|
||||
#include "projectinfo.h"
|
||||
#include "projectpart.h"
|
||||
|
||||
namespace ProjectExplorer {
|
||||
class ToolChain;
|
||||
}
|
||||
|
||||
namespace CppTools {
|
||||
|
||||
class CPPTOOLS_EXPORT ProjectPartBuilder
|
||||
@@ -51,6 +55,11 @@ public:
|
||||
|
||||
QList<Core::Id> createProjectPartsForFiles(const QStringList &files);
|
||||
|
||||
static void evaluateProjectPartToolchain(ProjectPart *projectPart,
|
||||
const ProjectExplorer::ToolChain *toolChain,
|
||||
const QStringList &commandLineFlags,
|
||||
const Utils::FileName &sysRoot);
|
||||
|
||||
private:
|
||||
void createProjectPart(const QStringList &theSources, const QString &partName,
|
||||
ProjectPart::LanguageVersion languageVersion,
|
||||
|
||||
Reference in New Issue
Block a user