1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
|
// Copyright (C) 2016 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0+ OR GPL-3.0 WITH Qt-GPL-exception-1.0
#include "cppprojectfilecategorizer.h"
#include <utils/algorithm.h>
namespace CppEditor {
ProjectFileCategorizer::ProjectFileCategorizer(const QString &projectPartName,
const QStringList &filePaths,
const FileIsActive &fileIsActive,
const GetMimeType &getMimeType)
: m_partName(projectPartName)
{
const ProjectFiles ambiguousHeaders = classifyFiles(filePaths, fileIsActive, getMimeType);
expandSourcesWithAmbiguousHeaders(ambiguousHeaders);
m_partCount = (m_cSources.isEmpty() ? 0 : 1)
+ (m_cxxSources.isEmpty() ? 0 : 1)
+ (m_objcSources.isEmpty() ? 0 : 1)
+ (m_objcxxSources.isEmpty() ? 0 : 1);
}
// TODO: Always tell the language version?
QString ProjectFileCategorizer::partName(const QString &languageName) const
{
if (hasMultipleParts())
return QString::fromLatin1("%1 (%2)").arg(m_partName, languageName);
return m_partName;
}
ProjectFiles ProjectFileCategorizer::classifyFiles(const QStringList &filePaths,
const FileIsActive &fileIsActive,
const GetMimeType &getMimeType)
{
ProjectFiles ambiguousHeaders;
for (const QString &filePath : filePaths) {
const ProjectFile projectFile(filePath,
getMimeType
? ProjectFile::classifyByMimeType(getMimeType(filePath))
: ProjectFile::classify(filePath),
fileIsActive ? fileIsActive(filePath) : true);
switch (projectFile.kind) {
case ProjectFile::AmbiguousHeader:
ambiguousHeaders += projectFile;
break;
case ProjectFile::CXXSource:
case ProjectFile::CXXHeader:
case ProjectFile::CudaSource:
case ProjectFile::OpenCLSource:
m_cxxSources += projectFile;
break;
case ProjectFile::ObjCXXSource:
case ProjectFile::ObjCXXHeader:
m_objcxxSources += projectFile;
break;
case ProjectFile::CSource:
case ProjectFile::CHeader:
m_cSources += projectFile;
break;
case ProjectFile::ObjCSource:
case ProjectFile::ObjCHeader:
m_objcSources += projectFile;
break;
case ProjectFile::Unclassified:
case ProjectFile::Unsupported:
continue;
}
}
return ambiguousHeaders;
}
static ProjectFiles toProjectFilesWithKind(const ProjectFiles &ambiguousHeaders,
const ProjectFile::Kind overriddenKind)
{
return Utils::transform(ambiguousHeaders, [overriddenKind](const ProjectFile &projectFile) {
return ProjectFile(projectFile.path, overriddenKind, projectFile.active);
});
}
void ProjectFileCategorizer::expandSourcesWithAmbiguousHeaders(const ProjectFiles &ambiguousHeaders)
{
const bool hasC = !m_cSources.isEmpty();
const bool hasCxx = !m_cxxSources.isEmpty();
const bool hasObjc = !m_objcSources.isEmpty();
const bool hasObjcxx = !m_objcxxSources.isEmpty();
const bool hasOnlyAmbiguousHeaders
= !hasC
&& !hasCxx
&& !hasObjc
&& !hasObjcxx
&& !ambiguousHeaders.isEmpty();
if (hasC || hasOnlyAmbiguousHeaders)
m_cSources += toProjectFilesWithKind(ambiguousHeaders, ProjectFile::CHeader);
if (hasCxx || hasOnlyAmbiguousHeaders)
m_cxxSources += toProjectFilesWithKind(ambiguousHeaders, ProjectFile::CXXHeader);
if (hasObjc || hasOnlyAmbiguousHeaders)
m_objcSources += toProjectFilesWithKind(ambiguousHeaders, ProjectFile::ObjCHeader);
if (hasObjcxx || hasOnlyAmbiguousHeaders)
m_objcxxSources += toProjectFilesWithKind(ambiguousHeaders, ProjectFile::ObjCXXHeader);
}
} // namespace CppEditor
|