forked from qt-creator/qt-creator
CppTools: Include "group id" in CompilerCallData
We will need the id in a follow-up change to match the corresponding project part. Change-Id: Id7686503f96fb238c9fa9857e7fde5cf94b0bcc7 Reviewed-by: Christian Kandeler <christian.kandeler@theqtcompany.com>
This commit is contained in:
@@ -323,14 +323,16 @@ static AnalyzeUnits unitsToAnalyzeFromCompilerCallData(
|
||||
|
||||
AnalyzeUnits unitsToAnalyze;
|
||||
|
||||
QHashIterator<QString, QList<QStringList> > it(compilerCallData);
|
||||
while (it.hasNext()) {
|
||||
it.next();
|
||||
const QString file = it.key();
|
||||
const QList<QStringList> compilerCalls = it.value();
|
||||
foreach (const QStringList &options, compilerCalls) {
|
||||
const QStringList arguments = tweakedArguments(file, options, extraParams);
|
||||
unitsToAnalyze << AnalyzeUnit(file, arguments);
|
||||
foreach (const ProjectInfo::CompilerCallGroup &compilerCallGroup, compilerCallData) {
|
||||
QHashIterator<QString, QList<QStringList> > it(compilerCallGroup.callsPerSourceFile);
|
||||
while (it.hasNext()) {
|
||||
it.next();
|
||||
const QString file = it.key();
|
||||
const QList<QStringList> compilerCalls = it.value();
|
||||
foreach (const QStringList &options, compilerCalls) {
|
||||
const QStringList arguments = tweakedArguments(file, options, extraParams);
|
||||
unitsToAnalyze << AnalyzeUnit(file, arguments);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@@ -36,6 +36,13 @@ ProjectInfo::ProjectInfo(QPointer<ProjectExplorer::Project> project)
|
||||
: m_project(project)
|
||||
{}
|
||||
|
||||
static bool operator==(const ProjectInfo::CompilerCallGroup &first,
|
||||
const ProjectInfo::CompilerCallGroup &second)
|
||||
{
|
||||
return first.groupId == second.groupId
|
||||
&& first.callsPerSourceFile == second.callsPerSourceFile;
|
||||
}
|
||||
|
||||
bool ProjectInfo::operator ==(const ProjectInfo &other) const
|
||||
{
|
||||
return m_project == other.m_project
|
||||
|
@@ -60,8 +60,13 @@ public:
|
||||
const QSet<QString> sourceFiles() const;
|
||||
const QByteArray defines() const;
|
||||
|
||||
// Source file --> List of compiler calls
|
||||
typedef QHash<QString, QList<QStringList>> CompilerCallData;
|
||||
struct CompilerCallGroup {
|
||||
using CallsPerSourceFile = QHash<QString, QList<QStringList>>;
|
||||
|
||||
QString groupId;
|
||||
CallsPerSourceFile callsPerSourceFile;
|
||||
};
|
||||
using CompilerCallData = QVector<CompilerCallGroup>;
|
||||
void setCompilerCallData(const CompilerCallData &data);
|
||||
CompilerCallData compilerCallData() const;
|
||||
|
||||
|
@@ -754,6 +754,14 @@ static CppTools::ProjectFile::Kind cppFileType(const qbs::SourceArtifact &source
|
||||
return CppTools::ProjectFile::Unclassified;
|
||||
}
|
||||
|
||||
static QString groupLocationToProjectFile(const qbs::CodeLocation &location)
|
||||
{
|
||||
return QString::fromLatin1("%1:%2:%3")
|
||||
.arg(location.filePath())
|
||||
.arg(location.line())
|
||||
.arg(location.column());
|
||||
}
|
||||
|
||||
void QbsProject::updateCppCodeModel()
|
||||
{
|
||||
if (!m_projectData.isValid())
|
||||
@@ -834,11 +842,7 @@ void QbsProject::updateCppCodeModel()
|
||||
ppBuilder.setPreCompiledHeaders(QStringList() << pch);
|
||||
|
||||
ppBuilder.setDisplayName(grp.name());
|
||||
ppBuilder.setProjectFile(QString::fromLatin1("%1:%2:%3")
|
||||
.arg(grp.location().filePath())
|
||||
.arg(grp.location().line())
|
||||
.arg(grp.location().column()));
|
||||
|
||||
ppBuilder.setProjectFile(groupLocationToProjectFile(grp.location()));
|
||||
|
||||
QHash<QString, qbs::SourceArtifact> filePathToSourceArtifact;
|
||||
foreach (const qbs::SourceArtifact &source, grp.allSourceArtifacts()) {
|
||||
@@ -902,6 +906,9 @@ void QbsProject::updateCppCompilerCallData()
|
||||
if (!group.isEnabled())
|
||||
continue;
|
||||
|
||||
CppTools::ProjectInfo::CompilerCallGroup compilerCallGroup;
|
||||
compilerCallGroup.groupId = groupLocationToProjectFile(group.location());
|
||||
|
||||
foreach (const qbs::SourceArtifact &file, group.allSourceArtifacts()) {
|
||||
const QString &filePath = file.filePath();
|
||||
if (!CppTools::ProjectFile::isSource(cppFileType(file)))
|
||||
@@ -920,8 +927,11 @@ void QbsProject::updateCppCompilerCallData()
|
||||
}
|
||||
|
||||
if (!calls.isEmpty())
|
||||
data.insert(filePath, calls);
|
||||
compilerCallGroup.callsPerSourceFile.insert(filePath, calls);
|
||||
}
|
||||
|
||||
if (!compilerCallGroup.callsPerSourceFile.isEmpty())
|
||||
data.append(compilerCallGroup);
|
||||
}
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user