CppTools: Use CompilerOptionsBuilder as an object

Makes the client code more readable.

Change-Id: Ie98ba93c758643039d3ebdc7550b1c4ac9473298
Reviewed-by: Marco Bubke <marco.bubke@theqtcompany.com>
Reviewed-by: Christian Kandeler <christian.kandeler@theqtcompany.com>
This commit is contained in:
Nikolai Kosjar
2015-06-25 13:46:22 +02:00
parent d41c634be0
commit dcccb4cb8d
3 changed files with 83 additions and 73 deletions

View File

@@ -139,49 +139,53 @@ static bool maybeIncludeBorlandExtensions()
*/ */
QStringList createClangOptions(const ProjectPart::Ptr &pPart, ProjectFile::Kind fileKind) QStringList createClangOptions(const ProjectPart::Ptr &pPart, ProjectFile::Kind fileKind)
{ {
QStringList result;
if (pPart.isNull()) if (pPart.isNull())
return result; return QStringList();
CompilerOptionsBuilder optionsBuilder(pPart);
if (verboseRunLog().isDebugEnabled()) if (verboseRunLog().isDebugEnabled())
result << QLatin1String("-v"); optionsBuilder.add(QLatin1String("-v"));
const bool objcExt = pPart->languageExtensions & ProjectPart::ObjectiveCExtensions; optionsBuilder.addLanguageOption(fileKind);
result << CompilerOptionsBuilder::createLanguageOption(fileKind, objcExt); optionsBuilder.addOptionsForLanguage(maybeIncludeBorlandExtensions());
result << CompilerOptionsBuilder::createOptionsForLanguage( optionsBuilder.addToolchainAndProjectDefines();
pPart->languageVersion,
pPart->languageExtensions,
maybeIncludeBorlandExtensions());
result << CompilerOptionsBuilder::createDefineOptions(pPart->toolchainDefines);
result << CompilerOptionsBuilder::createDefineOptions(pPart->projectDefines);
static const QString resourceDir = getResourceDir(); static const QString resourceDir = getResourceDir();
if (!resourceDir.isEmpty()) { if (!resourceDir.isEmpty()) {
result << QLatin1String("-nostdlibinc"); optionsBuilder.add(QLatin1String("-nostdlibinc"));
result << (QLatin1String("-I") + resourceDir); optionsBuilder.add(QLatin1String("-I") + resourceDir);
result << QLatin1String("-undef"); optionsBuilder.add(QLatin1String("-undef"));
} }
result << CompilerOptionsBuilder::createHeaderPathOptions(pPart->headerPaths, isBlacklisted); optionsBuilder.addHeaderPathOptions(isBlacklisted);
// Inject header file // Inject header file
static const QString injectedHeader = ICore::instance()->resourcePath() static const QString injectedHeader = ICore::instance()->resourcePath()
+ QLatin1String("/cplusplus/qt%1-qobjectdefs-injected.h"); + QLatin1String("/cplusplus/qt%1-qobjectdefs-injected.h");
// if (qtVersion == ProjectPart::Qt4)
// opts << QLatin1String("-include") << injectedHeader.arg(QLatin1Char('4'));
if (pPart->qtVersion == ProjectPart::Qt5)
result << QLatin1String("-include") << injectedHeader.arg(QLatin1Char('5'));
if (!pPart->projectConfigFile.isEmpty()) // if (pPart->qtVersion == ProjectPart::Qt4) {
result << QLatin1String("-include") << pPart->projectConfigFile; // builder.addOption(QLatin1String("-include"));
// builder.addOption(injectedHeader.arg(QLatin1Char('4')));
// }
result << QLatin1String("-fmessage-length=0"); if (pPart->qtVersion == ProjectPart::Qt5) {
result << QLatin1String("-fdiagnostics-show-note-include-stack"); optionsBuilder.add(QLatin1String("-include"));
result << QLatin1String("-fmacro-backtrace-limit=0"); optionsBuilder.add(injectedHeader.arg(QLatin1Char('5')));
result << QLatin1String("-fretain-comments-from-system-headers"); }
if (!pPart->projectConfigFile.isEmpty()) {
optionsBuilder.add(QLatin1String("-include"));
optionsBuilder.add(pPart->projectConfigFile);
}
optionsBuilder.add(QLatin1String("-fmessage-length=0"));
optionsBuilder.add(QLatin1String("-fdiagnostics-show-note-include-stack"));
optionsBuilder.add(QLatin1String("-fmacro-backtrace-limit=0"));
optionsBuilder.add(QLatin1String("-fretain-comments-from-system-headers"));
// TODO: -Xclang -ferror-limit -Xclang 0 ? // TODO: -Xclang -ferror-limit -Xclang 0 ?
return result; return optionsBuilder.options();
} }
/// @return Option to speed up parsing with precompiled header /// @return Option to speed up parsing with precompiled header

View File

@@ -501,9 +501,23 @@ void ProjectPartBuilder::createProjectPart(const QStringList &theSources,
} }
QStringList CompilerOptionsBuilder::createHeaderPathOptions( CompilerOptionsBuilder::CompilerOptionsBuilder(const ProjectPart::Ptr &projectPart)
const ProjectPart::HeaderPaths &headerPaths, : m_projectPart(projectPart)
IsBlackListed isBlackListed, const QString &toolchainType) {
}
QStringList CompilerOptionsBuilder::options() const
{
return m_options;
}
void CompilerOptionsBuilder::add(const QString &option)
{
m_options.append(option);
}
void CompilerOptionsBuilder::addHeaderPathOptions(IsBlackListed isBlackListed,
const QString &toolchainType)
{ {
typedef ProjectPart::HeaderPath HeaderPath; typedef ProjectPart::HeaderPath HeaderPath;
const QString defaultPrefix const QString defaultPrefix
@@ -511,7 +525,7 @@ QStringList CompilerOptionsBuilder::createHeaderPathOptions(
QStringList result; QStringList result;
foreach (const HeaderPath &headerPath , headerPaths) { foreach (const HeaderPath &headerPath , m_projectPart->headerPaths) {
if (headerPath.path.isEmpty()) if (headerPath.path.isEmpty())
continue; continue;
@@ -533,14 +547,12 @@ QStringList CompilerOptionsBuilder::createHeaderPathOptions(
result.append(prefix + headerPath.path); result.append(prefix + headerPath.path);
} }
return result; m_options.append(result);
} }
QStringList CompilerOptionsBuilder::createDefineOptions(const QByteArray &defines, void CompilerOptionsBuilder::addToolchainAndProjectDefines(const QString &toolchainType)
bool toolchainDefines,
const QString &toolchainType)
{ {
QByteArray extendedDefines = defines; QByteArray extendedDefines = m_projectPart->toolchainDefines + m_projectPart->projectDefines;
QStringList result; QStringList result;
// In gcc headers, lots of built-ins are referenced that clang does not understand. // In gcc headers, lots of built-ins are referenced that clang does not understand.
@@ -559,17 +571,6 @@ QStringList CompilerOptionsBuilder::createDefineOptions(const QByteArray &define
if (def.startsWith("#define __cplusplus")) if (def.startsWith("#define __cplusplus"))
continue; continue;
// TODO: verify if we can pass compiler-defined macros when also passing -undef.
if (toolchainDefines) {
//### FIXME: the next 3 check shouldn't be needed: we probably don't want to get the compiler-defined defines in.
if (!def.startsWith("#define "))
continue;
if (def.startsWith("#define _"))
continue;
if (def.startsWith("#define OBJC_NEW_PROPERTIES"))
continue;
}
// gcc 4.9 has: // gcc 4.9 has:
// #define __has_include(STR) __has_include__(STR) // #define __has_include(STR) __has_include__(STR)
// #define __has_include_next(STR) __has_include_next__(STR) // #define __has_include_next(STR) __has_include_next__(STR)
@@ -590,7 +591,7 @@ QStringList CompilerOptionsBuilder::createDefineOptions(const QByteArray &define
result.append(arg); result.append(arg);
} }
return result; m_options.append(result);
} }
static QStringList createLanguageOptionGcc(ProjectFile::Kind fileKind, bool objcExt) static QStringList createLanguageOptionGcc(ProjectFile::Kind fileKind, bool objcExt)
@@ -668,24 +669,26 @@ static QStringList createLanguageOptionMsvc(ProjectFile::Kind fileKind)
return opts; return opts;
} }
QStringList CompilerOptionsBuilder::createLanguageOption(ProjectFile::Kind fileKind, bool objcExt, void CompilerOptionsBuilder::addLanguageOption(ProjectFile::Kind fileKind,
const QString &toolchainType) const QString &toolchainType)
{ {
return toolchainType == QLatin1String("msvc") ? createLanguageOptionMsvc(fileKind) const bool objcExt = m_projectPart->languageExtensions & ProjectPart::ObjectiveCExtensions;
const QStringList options = toolchainType == QLatin1String("msvc")
? createLanguageOptionMsvc(fileKind)
: createLanguageOptionGcc(fileKind, objcExt); : createLanguageOptionGcc(fileKind, objcExt);
m_options.append(options);
} }
QStringList CompilerOptionsBuilder::createOptionsForLanguage( void CompilerOptionsBuilder::addOptionsForLanguage(bool checkForBorlandExtensions,
ProjectPart::LanguageVersion languageVersion,
ProjectPart::LanguageExtensions languageExtensions,
bool checkForBorlandExtensions,
const QString &toolchainType) const QString &toolchainType)
{ {
QStringList opts; QStringList opts;
if (toolchainType == QLatin1String("msvc")) if (toolchainType == QLatin1String("msvc"))
return opts; return;
bool gnuExtensions = languageExtensions & ProjectPart::GnuExtensions;
switch (languageVersion) { const ProjectPart::LanguageExtensions languageExtensions = m_projectPart->languageExtensions;
const bool gnuExtensions = languageExtensions & ProjectPart::GnuExtensions;
switch (m_projectPart->languageVersion) {
case ProjectPart::C89: case ProjectPart::C89:
opts << (gnuExtensions ? QLatin1String("-std=gnu89") : QLatin1String("-std=c89")); opts << (gnuExtensions ? QLatin1String("-std=gnu89") : QLatin1String("-std=c89"));
break; break;
@@ -718,5 +721,5 @@ QStringList CompilerOptionsBuilder::createOptionsForLanguage(
if (checkForBorlandExtensions && (languageExtensions & ProjectPart::BorlandExtensions)) if (checkForBorlandExtensions && (languageExtensions & ProjectPart::BorlandExtensions))
opts << QLatin1String("-fborland-extensions"); opts << QLatin1String("-fborland-extensions");
return opts; m_options.append(opts);
} }

View File

@@ -214,21 +214,24 @@ private:
class CPPTOOLS_EXPORT CompilerOptionsBuilder class CPPTOOLS_EXPORT CompilerOptionsBuilder
{ {
public: public:
CompilerOptionsBuilder(const ProjectPart::Ptr &projectPart);
QStringList options() const;
void add(const QString &option);
typedef std::function<bool (const QString &)> IsBlackListed; typedef std::function<bool (const QString &)> IsBlackListed;
static QStringList createHeaderPathOptions(const ProjectPart::HeaderPaths &headerPaths, void addHeaderPathOptions(IsBlackListed isBlackListed = IsBlackListed(),
IsBlackListed isBlackListed = IsBlackListed(), const QString &toolchainType = QLatin1String("clang"));
void addToolchainAndProjectDefines(const QString &toolchainType = QLatin1String("clang"));
void addLanguageOption(ProjectFile::Kind fileKind,
const QString &toolchainType = QLatin1String("clang"));
void addOptionsForLanguage(bool checkForBorlandExtensions = true,
const QString &toolchainType = QLatin1String("clang")); const QString &toolchainType = QLatin1String("clang"));
static QStringList createDefineOptions(const QByteArray &defines, private:
bool toolchainDefines = false, ProjectPart::Ptr m_projectPart;
const QString &toolchainType = QLatin1String("clang")); QStringList m_options;
static QStringList createLanguageOption(ProjectFile::Kind fileKind, bool objcExt,
const QString &toolchainType = QLatin1String("clang"));
static QStringList createOptionsForLanguage(ProjectPart::LanguageVersion languageVersion,
ProjectPart::LanguageExtensions languageExtensions,
bool checkForBorlandExtensions = true,
const QString &toolchainType = QLatin1String("clang"));
}; };
} // namespace CppTools } // namespace CppTools