summaryrefslogtreecommitdiff
path: root/src/plugins/cpptools/cppprojectfile.cpp
diff options
context:
space:
mode:
authorEike Ziller <eike.ziller@qt.io>2019-08-28 12:23:37 +0200
committerEike Ziller <eike.ziller@qt.io>2019-09-03 13:15:31 +0000
commitc7e3bbcd118f4b7aec7f56f2e8301d91a418703d (patch)
treeedc69ed3e0265048539c175bd040e1f6ce63cd68 /src/plugins/cpptools/cppprojectfile.cpp
parentb4dd2ea2cc29458a4d5e5746da7707f88b81af25 (diff)
downloadqt-creator-c7e3bbcd118f4b7aec7f56f2e8301d91a418703d.tar.gz
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>
Diffstat (limited to 'src/plugins/cpptools/cppprojectfile.cpp')
-rw-r--r--src/plugins/cpptools/cppprojectfile.cpp34
1 files changed, 20 insertions, 14 deletions
diff --git a/src/plugins/cpptools/cppprojectfile.cpp b/src/plugins/cpptools/cppprojectfile.cpp
index 52c599d10b..3f1e590619 100644
--- a/src/plugins/cpptools/cppprojectfile.cpp
+++ b/src/plugins/cpptools/cppprojectfile.cpp
@@ -47,32 +47,38 @@ bool ProjectFile::operator==(const ProjectFile &other) const
&& path == other.path;
}
-ProjectFile::Kind ProjectFile::classify(const QString &filePath)
+ProjectFile::Kind ProjectFile::classifyByMimeType(const QString &mt)
{
- if (isAmbiguousHeader(filePath))
- return AmbiguousHeader;
-
- const Utils::MimeType mimeType = Utils::mimeTypeForFile(filePath);
- const QString mt = mimeType.name();
- if (mt == QLatin1String(CppTools::Constants::C_SOURCE_MIMETYPE))
+ if (mt == CppTools::Constants::C_SOURCE_MIMETYPE)
return CSource;
- if (mt == QLatin1String(CppTools::Constants::C_HEADER_MIMETYPE))
+ if (mt == CppTools::Constants::C_HEADER_MIMETYPE)
return CHeader;
- if (mt == QLatin1String(CppTools::Constants::CPP_SOURCE_MIMETYPE))
+ if (mt == CppTools::Constants::CPP_SOURCE_MIMETYPE)
return CXXSource;
- if (mt == QLatin1String(CppTools::Constants::CPP_HEADER_MIMETYPE))
+ if (mt == CppTools::Constants::CPP_HEADER_MIMETYPE)
return CXXHeader;
- if (mt == QLatin1String(CppTools::Constants::OBJECTIVE_C_SOURCE_MIMETYPE))
+ if (mt == CppTools::Constants::OBJECTIVE_C_SOURCE_MIMETYPE)
return ObjCSource;
- if (mt == QLatin1String(CppTools::Constants::OBJECTIVE_CPP_SOURCE_MIMETYPE))
+ if (mt == CppTools::Constants::OBJECTIVE_CPP_SOURCE_MIMETYPE)
return ObjCXXSource;
- if (mt == QLatin1String(CppTools::Constants::QDOC_MIMETYPE))
+ if (mt == CppTools::Constants::QDOC_MIMETYPE)
return CXXSource;
- if (mt == QLatin1String(CppTools::Constants::MOC_MIMETYPE))
+ if (mt == CppTools::Constants::MOC_MIMETYPE)
return CXXSource;
+ if (mt == CppTools::Constants::AMBIGUOUS_HEADER_MIMETYPE)
+ return AmbiguousHeader;
return Unsupported;
}
+ProjectFile::Kind ProjectFile::classify(const QString &filePath)
+{
+ if (isAmbiguousHeader(filePath))
+ return AmbiguousHeader;
+
+ const Utils::MimeType mimeType = Utils::mimeTypeForFile(filePath);
+ return classifyByMimeType(mimeType.name());
+}
+
bool ProjectFile::isAmbiguousHeader(const QString &filePath)
{
return filePath.endsWith(".h");