[PATCH] D157011: [Clang][Tooling] Accept preprocessed input files
J. Ryan Stinnett via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Thu Aug 3 09:30:32 PDT 2023
jryans created this revision.
Herald added a project: All.
jryans added reviewers: dexonsmith, jansvoboda11.
jryans added a project: clang.
jryans published this revision for review.
Herald added a subscriber: cfe-commits.
This restores the tooling library's ability to accept invocations that take a
preprocessed file as the primary input.
Regressed by https://reviews.llvm.org/D105695
Fixes https://github.com/llvm/llvm-project/issues/63941
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D157011
Files:
clang/lib/Tooling/Tooling.cpp
clang/unittests/Tooling/ToolingTest.cpp
Index: clang/unittests/Tooling/ToolingTest.cpp
===================================================================
--- clang/unittests/Tooling/ToolingTest.cpp
+++ clang/unittests/Tooling/ToolingTest.cpp
@@ -449,6 +449,13 @@
EXPECT_NE(extractCC1Arguments(Args), nullptr);
}
+TEST_F(CommandLineExtractorTest, AcceptPreprocessedInputFile) {
+ addFile("test.i", "int main() {}\n");
+ const char *Args[] = {"clang", "-target", "arm64-apple-macosx11.0.0",
+ "-c", "test.i"};
+ EXPECT_NE(extractCC1Arguments(Args), nullptr);
+}
+
TEST_F(CommandLineExtractorTest, RejectMultipleArchitectures) {
addFile("test.c", "int main() {}\n");
const char *Args[] = {"clang", "-target", "arm64-apple-macosx11.0.0",
Index: clang/lib/Tooling/Tooling.cpp
===================================================================
--- clang/lib/Tooling/Tooling.cpp
+++ clang/lib/Tooling/Tooling.cpp
@@ -147,6 +147,13 @@
if (IsCC1Command(Job) && llvm::all_of(Job.getInputInfos(), IsSrcFile))
CC1Jobs.push_back(&Job);
+ // If there are no jobs for source files, try checking again for a single job
+ // with any file type. This accepts a preprocessed file as input.
+ if (CC1Jobs.empty())
+ for (const driver::Command &Job : Jobs)
+ if (IsCC1Command(Job))
+ CC1Jobs.push_back(&Job);
+
if (CC1Jobs.empty() ||
(CC1Jobs.size() > 1 && !ignoreExtraCC1Commands(Compilation))) {
SmallString<256> error_msg;
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D157011.546907.patch
Type: text/x-patch
Size: 1460 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20230803/94a15774/attachment.bin>
More information about the cfe-commits
mailing list