project: support %cu directive and strip -M* options

This commit is contained in:
Fangrui Song 2019-06-27 19:11:38 -07:00
parent cc7e0dde33
commit 796c75794e
2 changed files with 23 additions and 8 deletions

View File

@ -261,6 +261,13 @@ struct ShowMessageParam {
// Used to identify the language at a file level. The ordering is important, as // Used to identify the language at a file level. The ordering is important, as
// a file previously identified as `C`, will be changed to `Cpp` if it // a file previously identified as `C`, will be changed to `Cpp` if it
// encounters a c++ declaration. // encounters a c++ declaration.
enum class LanguageId { Unknown = -1, C = 0, Cpp = 1, ObjC = 2, ObjCpp = 3 }; enum class LanguageId {
Unknown = -1,
C = 0,
Cpp = 1,
ObjC = 2,
ObjCpp = 3,
Cuda = 4,
};
} // namespace ccls } // namespace ccls

View File

@ -60,7 +60,8 @@ std::pair<LanguageId, bool> lookupExtension(std::string_view filename) {
bool objc = types::isObjC(I); bool objc = types::isObjC(I);
LanguageId ret; LanguageId ret;
if (types::isCXX(I)) if (types::isCXX(I))
ret = objc ? LanguageId::ObjCpp : LanguageId::Cpp; ret = types::isCuda(I) ? LanguageId::Cuda
: objc ? LanguageId::ObjCpp : LanguageId::Cpp;
else if (objc) else if (objc)
ret = LanguageId::ObjC; ret = LanguageId::ObjC;
else if (I == types::TY_C || I == types::TY_CHeader) else if (I == types::TY_C || I == types::TY_CHeader)
@ -95,7 +96,12 @@ struct ProjectProcessor {
LOG_S(WARNING) << toString(glob_or_err.takeError()); LOG_S(WARNING) << toString(glob_or_err.takeError());
} }
bool ExcludesArg(StringRef arg) { bool ExcludesArg(StringRef arg, int &i) {
if (arg.startswith("-M")) {
if (arg == "-MF" || arg == "-MT" || arg == "-MQ")
i++;
return true;
}
return exclude_args.count(arg) || any_of(exclude_globs, return exclude_args.count(arg) || any_of(exclude_globs,
[&](const GlobPattern &glob) { return glob.match(arg); }); [&](const GlobPattern &glob) { return glob.match(arg); });
} }
@ -117,6 +123,8 @@ struct ProjectProcessor {
ok |= lang == LanguageId::C && header; ok |= lang == LanguageId::C && header;
else if (A.consume_front("%cpp ")) else if (A.consume_front("%cpp "))
ok |= lang == LanguageId::Cpp; ok |= lang == LanguageId::Cpp;
else if (A.consume_front("%cu "))
ok |= lang == LanguageId::Cuda;
else if (A.consume_front("%hpp ")) else if (A.consume_front("%hpp "))
ok |= lang == LanguageId::Cpp && header; ok |= lang == LanguageId::Cpp && header;
else if (A.consume_front("%objective-c ")) else if (A.consume_front("%objective-c "))
@ -128,7 +136,7 @@ struct ProjectProcessor {
} }
if (ok) if (ok)
args.push_back(A.data()); args.push_back(A.data());
} else if (!ExcludesArg(A)) { } else if (!ExcludesArg(A, i)) {
args.push_back(arg); args.push_back(arg);
} }
} }
@ -411,10 +419,10 @@ void Project::LoadDirectory(const std::string &root, Project::Folder &folder) {
std::vector<std::string> args = std::move(Cmd.CommandLine); std::vector<std::string> args = std::move(Cmd.CommandLine);
entry.args.reserve(args.size()); entry.args.reserve(args.size());
for (std::string &arg : args) { for (int i = 0; i < args.size(); i++) {
DoPathMapping(arg); DoPathMapping(args[i]);
if (!proc.ExcludesArg(arg)) if (!proc.ExcludesArg(args[i], i))
entry.args.push_back(Intern(arg)); entry.args.push_back(Intern(args[i]));
} }
entry.compdb_size = entry.args.size(); entry.compdb_size = entry.args.size();