summaryrefslogtreecommitdiff
path: root/src/plugins/cpptools/cppprojects.cpp
diff options
context:
space:
mode:
authorMarco Bubke <marco.bubke@theqtcompany.com>2016-01-11 21:08:13 +0100
committerMarco Bubke <marco.bubke@theqtcompany.com>2016-01-13 14:47:11 +0000
commit1ae509541c1b453463005ddf89170c0978f8d378 (patch)
treedfbaba72e8a1bfe907b3deae5205e1efeedf8e70 /src/plugins/cpptools/cppprojects.cpp
parentda1f8e66e55d88919079e619a9d43ba71a4e517d (diff)
downloadqt-creator-1ae509541c1b453463005ddf89170c0978f8d378.tar.gz
CppTools: Moving ProjectPartBuilder in its own header
Change-Id: I0aa65ec6c80dcd437f13ff70021388b0da57ccfd Reviewed-by: Nikolai Kosjar <nikolai.kosjar@theqtcompany.com>
Diffstat (limited to 'src/plugins/cpptools/cppprojects.cpp')
-rw-r--r--src/plugins/cpptools/cppprojects.cpp227
1 files changed, 0 insertions, 227 deletions
diff --git a/src/plugins/cpptools/cppprojects.cpp b/src/plugins/cpptools/cppprojects.cpp
index d1719c3b72..29c13d0834 100644
--- a/src/plugins/cpptools/cppprojects.cpp
+++ b/src/plugins/cpptools/cppprojects.cpp
@@ -46,235 +46,8 @@
#include <QTextStream>
using namespace CppTools;
-using namespace CppTools::Internal;
using namespace ProjectExplorer;
-namespace {
-class ProjectFileCategorizer
-{
-public:
- ProjectFileCategorizer(const QString &partName, const QStringList &files)
- : m_partName(partName)
- {
- using CppTools::ProjectFile;
-
- QStringList cHeaders, cxxHeaders;
-
- foreach (const QString &file, files) {
- switch (ProjectFile::classify(file)) {
- case ProjectFile::CSource: m_cSources += file; break;
- case ProjectFile::CHeader: cHeaders += file; break;
- case ProjectFile::CXXSource: m_cxxSources += file; break;
- case ProjectFile::CXXHeader: cxxHeaders += file; break;
- case ProjectFile::ObjCSource: m_objcSources += file; break;
- case ProjectFile::ObjCXXSource: m_objcxxSources += file; break;
- default:
- continue;
- }
- }
-
- const bool hasC = !m_cSources.isEmpty();
- const bool hasCxx = !m_cxxSources.isEmpty();
- const bool hasObjc = !m_objcSources.isEmpty();
- const bool hasObjcxx = !m_objcxxSources.isEmpty();
-
- if (hasObjcxx)
- m_objcxxSources += cxxHeaders + cHeaders;
- if (hasCxx)
- m_cxxSources += cxxHeaders + cHeaders;
- else if (!hasObjcxx)
- m_cxxSources += cxxHeaders;
- if (hasObjc)
- m_objcSources += cHeaders;
- if (hasC || (!hasObjc && !hasObjcxx && !hasCxx))
- m_cSources += cHeaders;
-
- m_partCount =
- (m_cSources.isEmpty() ? 0 : 1) +
- (m_cxxSources.isEmpty() ? 0 : 1) +
- (m_objcSources.isEmpty() ? 0 : 1) +
- (m_objcxxSources.isEmpty() ? 0 : 1);
- }
-
- bool hasCSources() const { return !m_cSources.isEmpty(); }
- bool hasCxxSources() const { return !m_cxxSources.isEmpty(); }
- bool hasObjcSources() const { return !m_objcSources.isEmpty(); }
- bool hasObjcxxSources() const { return !m_objcxxSources.isEmpty(); }
-
- QStringList cSources() const { return m_cSources; }
- QStringList cxxSources() const { return m_cxxSources; }
- QStringList objcSources() const { return m_objcSources; }
- QStringList objcxxSources() const { return m_objcxxSources; }
-
- bool hasMultipleParts() const { return m_partCount > 1; }
- bool hasNoParts() const { return m_partCount == 0; }
-
- QString partName(const QString &languageName) const
- {
- if (hasMultipleParts())
- return QString::fromLatin1("%1 (%2)").arg(m_partName).arg(languageName);
-
- return m_partName;
- }
-
-private:
- QString m_partName;
- QStringList m_cSources, m_cxxSources, m_objcSources, m_objcxxSources;
- int m_partCount;
-};
-} // anonymous namespace
-
-ProjectPartBuilder::ProjectPartBuilder(ProjectInfo &pInfo)
- : m_templatePart(new ProjectPart)
- , m_pInfo(pInfo)
-{
- m_templatePart->project = pInfo.project();
- m_templatePart->displayName = pInfo.project()->displayName();
- m_templatePart->projectFile = pInfo.project()->projectFilePath().toString();
-}
-
-void ProjectPartBuilder::setQtVersion(ProjectPart::QtVersion qtVersion)
-{
- m_templatePart->qtVersion = qtVersion;
-}
-
-void ProjectPartBuilder::setCFlags(const QStringList &flags)
-{
- m_cFlags = flags;
-}
-
-void ProjectPartBuilder::setCxxFlags(const QStringList &flags)
-{
- m_cxxFlags = flags;
-}
-
-void ProjectPartBuilder::setDefines(const QByteArray &defines)
-{
- m_templatePart->projectDefines = defines;
-}
-
-void ProjectPartBuilder::setHeaderPaths(const ProjectPartHeaderPaths &headerPaths)
-{
- m_templatePart->headerPaths = headerPaths;
-}
-
-void ProjectPartBuilder::setIncludePaths(const QStringList &includePaths)
-{
- m_templatePart->headerPaths.clear();
-
- foreach (const QString &includeFile, includePaths) {
- ProjectPartHeaderPath hp(includeFile, ProjectPartHeaderPath::IncludePath);
-
- // The simple project managers are utterly ignorant of frameworks on OSX, and won't report
- // framework paths. The work-around is to check if the include path ends in ".framework",
- // and if so, add the parent directory as framework path.
- if (includeFile.endsWith(QLatin1String(".framework"))) {
- const int slashIdx = includeFile.lastIndexOf(QLatin1Char('/'));
- if (slashIdx != -1) {
- hp = ProjectPartHeaderPath(includeFile.left(slashIdx),
- ProjectPartHeaderPath::FrameworkPath);
- }
- }
-
- m_templatePart->headerPaths += hp;
- }
-}
-
-void ProjectPartBuilder::setPreCompiledHeaders(const QStringList &pchs)
-{
- m_templatePart->precompiledHeaders = pchs;
-}
-
-void ProjectPartBuilder::setProjectFile(const QString &projectFile)
-{
- m_templatePart->projectFile = projectFile;
-}
-
-void ProjectPartBuilder::setDisplayName(const QString &displayName)
-{
- m_templatePart->displayName = displayName;
-}
-
-void ProjectPartBuilder::setConfigFileName(const QString &configFileName)
-{
- m_templatePart->projectConfigFile = configFileName;
-}
-
-QList<Core::Id> ProjectPartBuilder::createProjectPartsForFiles(const QStringList &files)
-{
- QList<Core::Id> languages;
-
- ProjectFileCategorizer cat(m_templatePart->displayName, files);
- if (cat.hasNoParts())
- return languages;
-
- using CppTools::ProjectFile;
- using CppTools::ProjectPart;
-
- if (cat.hasCSources()) {
- createProjectPart(cat.cSources(),
- cat.partName(QCoreApplication::translate("CppTools", "C11")),
- ProjectPart::C11,
- ProjectPart::NoExtensions);
- // TODO: there is no C...
-// languages += ProjectExplorer::Constants::LANG_C;
- }
- if (cat.hasObjcSources()) {
- createProjectPart(cat.objcSources(),
- cat.partName(QCoreApplication::translate("CppTools", "Obj-C11")),
- ProjectPart::C11,
- ProjectPart::ObjectiveCExtensions);
- // TODO: there is no Ojective-C...
-// languages += ProjectExplorer::Constants::LANG_OBJC;
- }
- if (cat.hasCxxSources()) {
- createProjectPart(cat.cxxSources(),
- cat.partName(QCoreApplication::translate("CppTools", "C++11")),
- ProjectPart::CXX11,
- ProjectPart::NoExtensions);
- languages += ProjectExplorer::Constants::LANG_CXX;
- }
- if (cat.hasObjcxxSources()) {
- createProjectPart(cat.objcxxSources(),
- cat.partName(QCoreApplication::translate("CppTools", "Obj-C++11")),
- ProjectPart::CXX11,
- ProjectPart::ObjectiveCExtensions);
- // TODO: there is no Objective-C++...
- languages += ProjectExplorer::Constants::LANG_CXX;
- }
-
- return languages;
-}
-
-void ProjectPartBuilder::createProjectPart(const QStringList &theSources,
- const QString &partName,
- ProjectPart::LanguageVersion languageVersion,
- ProjectPart::LanguageExtensions languageExtensions)
-{
- ProjectPart::Ptr part(m_templatePart->copy());
- part->displayName = partName;
-
- QTC_ASSERT(part->project, return);
- if (Target *activeTarget = part->project->activeTarget()) {
- if (Kit *kit = activeTarget->kit()) {
- if (ToolChain *toolChain = ToolChainKitInformation::toolChain(kit)) {
- const QStringList flags = languageVersion >= ProjectPart::CXX98 ? m_cxxFlags
- : m_cFlags;
- part->evaluateToolchain(toolChain, flags, SysRootKitInformation::sysRoot(kit));
- }
- }
- }
-
- part->languageExtensions |= languageExtensions;
-
- ProjectFileAdder adder(part->files);
- foreach (const QString &file, theSources)
- adder.maybeAdd(file);
-
- m_pInfo.appendProjectPart(part);
-}
-
-
CompilerOptionsBuilder::CompilerOptionsBuilder(const ProjectPart &projectPart)
: m_projectPart(projectPart)
{