forked from qt-creator/qt-creator
CppTools: Remove dependency of RawProjectPart to ProjectFile
The feature to category files to ProjectFiles was used by the qmake project manager to specify if the file is "active", and by the Qbs project manager to avoid unnecessary MIME type checking. Make these two different use-cases explicit in the API. Change-Id: Ia5a7da37f100149366fc75060fe04687e15f2bd3 Reviewed-by: hjk <hjk@qt.io> Reviewed-by: Nikolai Kosjar <nikolai.kosjar@qt.io>
This commit is contained in:
@@ -31,10 +31,11 @@ namespace CppTools {
|
||||
|
||||
ProjectFileCategorizer::ProjectFileCategorizer(const QString &projectPartName,
|
||||
const QStringList &filePaths,
|
||||
const FileClassifier &fileClassifier)
|
||||
const FileIsActive &fileIsActive,
|
||||
const GetMimeType &getMimeType)
|
||||
: m_partName(projectPartName)
|
||||
{
|
||||
const ProjectFiles ambiguousHeaders = classifyFiles(filePaths, fileClassifier);
|
||||
const ProjectFiles ambiguousHeaders = classifyFiles(filePaths, fileIsActive, getMimeType);
|
||||
expandSourcesWithAmbiguousHeaders(ambiguousHeaders);
|
||||
|
||||
m_partCount = (m_cSources.isEmpty() ? 0 : 1)
|
||||
@@ -53,14 +54,17 @@ QString ProjectFileCategorizer::partName(const QString &languageName) const
|
||||
}
|
||||
|
||||
ProjectFiles ProjectFileCategorizer::classifyFiles(const QStringList &filePaths,
|
||||
const FileClassifier &fileClassifier)
|
||||
const FileIsActive &fileIsActive,
|
||||
const GetMimeType &getMimeType)
|
||||
{
|
||||
ProjectFiles ambiguousHeaders;
|
||||
|
||||
foreach (const QString &filePath, filePaths) {
|
||||
const ProjectFile projectFile = fileClassifier
|
||||
? fileClassifier(filePath)
|
||||
: ProjectFile(filePath, ProjectFile::classify(filePath));
|
||||
const ProjectFile projectFile(filePath,
|
||||
getMimeType
|
||||
? ProjectFile::classifyByMimeType(getMimeType(filePath))
|
||||
: ProjectFile::classify(filePath),
|
||||
fileIsActive ? fileIsActive(filePath) : true);
|
||||
|
||||
switch (projectFile.kind) {
|
||||
case ProjectFile::AmbiguousHeader:
|
||||
|
||||
Reference in New Issue
Block a user