ProjectPart: Allow for line/column information in project file

Keep this information separate so that plugins using the information
do not need to start parsing the project file.

Change-Id: Ibecf431de1b12bbe820c6f8f9c986cffeb4972d2
Reviewed-by: Tim Jenssen <tim.jenssen@qt.io>
Reviewed-by: Christian Stenger <christian.stenger@qt.io>
Reviewed-by: Nikolai Kosjar <nikolai.kosjar@qt.io>
This commit is contained in:
Tobias Hunger
2017-02-27 14:02:38 +01:00
parent 8187141b4a
commit cee92463f7
8 changed files with 29 additions and 6 deletions

View File

@@ -405,7 +405,12 @@ static QHash<QString, ProjectPart::Ptr> generateProjectFileToProjectPartMapping(
foreach (const ProjectPart::Ptr &projectPart, projectParts) {
QTC_ASSERT(projectPart, continue);
mapping[projectPart->projectFile] = projectPart;
QString projectFile = projectPart->projectFile;
if (projectPart->projectFileLine >= 0)
projectFile += ':' + QString::number(projectPart->projectFileLine);
if (projectPart->projectFileColumn >= 0)
projectFile += ':' + QString::number(projectPart->projectFileColumn);
mapping[projectFile] = projectPart;
}
return mapping;

View File

@@ -1777,10 +1777,15 @@ void CppCodeModelInspectorDialog::updateProjectPartData(const ProjectPart::Ptr &
projectName = project->displayName();
projectFilePath = project->projectFilePath().toUserOutput();
}
QString projectFileLocation = QDir::toNativeSeparators(part->projectFile);
if (part->projectFileLine > 0)
projectFileLocation += ":" + QString::number(part->projectFileLine);
if (part->projectFileColumn > 0)
projectFileLocation += ":" + QString::number(part->projectFileColumn);
KeyValueModel::Table table = KeyValueModel::Table()
<< qMakePair(QString::fromLatin1("Project Part Name"), part->displayName)
<< qMakePair(QString::fromLatin1("Project Part File"),
QDir::toNativeSeparators(part->projectFile))
<< qMakePair(QString::fromLatin1("Project Part File"), projectFileLocation)
<< qMakePair(QString::fromLatin1("Project Name"), projectName)
<< qMakePair(QString::fromLatin1("Project File"), projectFilePath)
<< qMakePair(QString::fromLatin1("Selected For Building"),

View File

@@ -182,6 +182,8 @@ static ProjectPart::Ptr projectPartFromRawProjectPart(const RawProjectPart &rawP
part->project = project;
part->projectFile = rawProjectPart.projectFile;
part->projectConfigFile = rawProjectPart.projectConfigFile;
part->projectFileLine = rawProjectPart.projectFileLine;
part->projectFileColumn = rawProjectPart.projectFileColumn;
part->qtVersion = rawProjectPart.qtVersion;
part->projectDefines = rawProjectPart.projectDefines;
part->headerPaths = rawProjectPart.headerPaths;

View File

@@ -54,9 +54,11 @@ void RawProjectPart::setFiles(const QStringList &files, FileClassifier fileClass
this->fileClassifier = fileClassifier;
}
void RawProjectPart::setProjectFile(const QString &projectFile)
void RawProjectPart::setProjectFile(const QString &projectFile, int line, int column)
{
this->projectFile = projectFile;
projectFileLine = line;
projectFileColumn = column;
}
void RawProjectPart::setConfigFileName(const QString &configFileName)

View File

@@ -60,7 +60,7 @@ public:
using FileClassifier = std::function<ProjectFile::Kind (const QString &filePath)>;
void setFiles(const QStringList &files, FileClassifier fileClassifier = FileClassifier());
void setProjectFile(const QString &projectFile);
void setProjectFile(const QString &projectFile, int line = -1, int column = -1);
void setConfigFileName(const QString &configFileName);
void setQtVersion(ProjectPart::QtVersion qtVersion);
@@ -79,6 +79,8 @@ public:
public:
QString displayName;
QString projectFile;
int projectFileLine = -1;
int projectFileColumn = -1;
QString projectConfigFile; // currently only used by the Generic Project Manager
QStringList precompiledHeaders;
ProjectPartHeaderPaths headerPaths;

View File

@@ -64,6 +64,10 @@ ProjectPart::Ptr ProjectPart::copy() const
QString ProjectPart::id() const
{
QString projectPartId = QDir::fromNativeSeparators(projectFile);
if (projectFileLine > 0)
projectPartId += ":" + QString::number(projectFileLine);
if (projectFileColumn > 0)
projectPartId += ":" + QString::number(projectFileColumn);
if (!displayName.isEmpty())
projectPartId.append(QLatin1Char(' ') + displayName);
return projectPartId;

View File

@@ -105,6 +105,8 @@ public:
QString displayName;
QString projectFile;
int projectFileLine = -1;
int projectFileColumn = -1;
QString projectConfigFile; // currently only used by the Generic Project Manager
ProjectFiles files;

View File

@@ -996,7 +996,8 @@ void QbsProject::updateCppCodeModel()
rpp.setHeaderPaths(grpHeaderPaths);
rpp.setDisplayName(grp.name());
rpp.setProjectFile(groupLocationToProjectFile(grp.location()));
rpp.setProjectFile(grp.location().filePath(),
grp.location().line(), grp.location().column());
QHash<QString, qbs::ArtifactData> filePathToSourceArtifact;
bool hasCFiles = false;