This is an archive of the discontinued LLVM Phabricator instance.

[clang-rename] Exit gracefully when no input provided
ClosedPublic

Authored by xgupta on Apr 15 2023, 11:32 AM.

Details

Summary

clang-rename on a non existing file segfaults

Command to run -
$ clang-rename -offset=0 -new-name=plop asdasd

Error while processing llvm-project/asdasd.
clang-rename: llvm-project/llvm/include/llvm/Support/ErrorOr.h:237:
llvm::ErrorOr<T>::storage_type* llvm::ErrorOr<T>::getStorage()
[with T = const clang::FileEntry*; llvm::ErrorOr<T>::storage_type = const clang::FileEntry*]:
Assertion `!HasError && "Cannot get value when an error exists!"' failed.

[1] 827497 IOT instruction clang-rename -offset=0 -new-name=plop asdasd

This fixes https://github.com/llvm/llvm-project/issues/36471.

Diff Detail

Event Timeline

xgupta created this revision.Apr 15 2023, 11:32 AM
Herald added a project: Restricted Project. · View Herald TranscriptApr 15 2023, 11:32 AM
xgupta requested review of this revision.Apr 15 2023, 11:32 AM
Herald added a project: Restricted Project. · View Herald TranscriptApr 15 2023, 11:32 AM
Herald added a subscriber: cfe-commits. · View Herald Transcript
xgupta edited the summary of this revision. (Show Details)Apr 15 2023, 11:32 AM

Looks good to me, but probably you want an approval from @arphaman, @klimek or @kbobyrev before committing.

kbobyrev accepted this revision.Apr 16 2023, 6:36 PM

LGTM

clang/tools/clang-rename/ClangRename.cpp
130

Probably something like "input must be provided" would be more understandable by the user, but this is also fine.

This revision is now accepted and ready to land.Apr 16 2023, 6:36 PM
xgupta updated this revision to Diff 514093.Apr 16 2023, 9:54 PM

address comment

xgupta marked an inline comment as done.Apr 16 2023, 9:54 PM
xgupta added inline comments.
clang/tools/clang-rename/ClangRename.cpp
130

Thanks for the suggestion!

This revision was landed with ongoing or failed builds.Apr 16 2023, 9:55 PM
This revision was automatically updated to reflect the committed changes.
xgupta marked an inline comment as done.
dyung added a subscriber: dyung.Apr 16 2023, 10:02 PM

Is there a reason a test was not added with this change?

Is there a reason a test was not added with this change?

Sorry, I missed that. Adding.

This change is also causing 33 test failures on a build bot https://lab.llvm.org/buildbot/#/builders/139/builds/39267

xgupta added a comment.EditedApr 16 2023, 10:07 PM

This change is also causing 33 test failures on a build bot https://lab.llvm.org/buildbot/#/builders/139/builds/39267

Yes, checking for the reason.

Oh, wait, I'm sorry, I didn't look into it closely :( Yeah, the Input file is not really needed, most of the time the users of clang-rename (not sure there are many with clangd being developed) use CLI flags for that.

It's better to revert this patch. My bad, should've looked a bit closer into this.

xgupta reopened this revision.Apr 17 2023, 8:21 AM
This revision is now accepted and ready to land.Apr 17 2023, 8:21 AM
xgupta updated this revision to Diff 514262.Apr 17 2023, 8:55 AM

adjust the return and add test case

xgupta added a comment.EditedApr 17 2023, 9:02 AM

Oh, wait, I'm sorry, I didn't look into it closely :( Yeah, the Input file is not really needed, most of the time the users of clang-rename (not sure there are many with clangd being developed) use CLI flags for that.

It's better to revert this patch. My bad, should've looked a bit closer into this.

No issue, I also consider it a straightforward fix and forget to run check-clang.

kbobyrev requested changes to this revision.Apr 18 2023, 4:32 PM

Yeah, this should be a right approach! Thanks!

clang/test/clang-rename/NonExistFile.cpp
1 ↗(On Diff #514262)

Rather than asdasd please use a meaningful name (e.g. non-existing-file).

clang/tools/clang-rename/ClangRename.cpp
236

It is worth including the filename in the error message, otherwise it won't be possible to understand which one is missing (there can be multiple IIRC, right?).

Also, it's better to put this check to the top of main, where the OP if first declared, since this is a sanity check and we want to fail if the inputs are corrupted.

This revision now requires changes to proceed.Apr 18 2023, 4:32 PM
xgupta updated this revision to Diff 514842.Apr 19 2023, 12:04 AM
xgupta marked an inline comment as done.

address comments

xgupta added inline comments.Apr 19 2023, 12:33 AM
clang/tools/clang-rename/ClangRename.cpp
236

Thanks for the suggestion, I agree, I updated the error message regarding the filename.

But I am not sure running a similar for loop again should be the correct way.
So just sharing the diff before committing, WDYT -

diff --git a/clang/tools/clang-rename/ClangRename.cpp b/clang/tools/clang-rename/ClangRename.cpp
index 24c9d8521..bc777cc01 100644
--- a/clang/tools/clang-rename/ClangRename.cpp
+++ b/clang/tools/clang-rename/ClangRename.cpp
@@ -106,6 +106,17 @@ int main(int argc, const char **argv) {
   }
   tooling::CommonOptionsParser &OP = ExpectedParser.get();
 
+  auto Files = OP.getSourcePathList();
+  tooling::RefactoringTool Tool(OP.getCompilations(), Files);
+    auto &FileMgr = Tool.getFiles();
+      for (const auto &File : Files) {
+      auto Entry = FileMgr.getFile(File);
+      if (!Entry) {
+        errs() << "clang-rename: " << File << " does not exist.\n";
+        return 1;
+      }
+    }
+
   if (!Input.empty()) {
     // Populate QualifiedNames and NewNames from a YAML file.
     ErrorOr<std::unique_ptr<MemoryBuffer>> Buffer =
@@ -162,8 +173,6 @@ int main(int argc, const char **argv) {
     return 1;
   }
 
-  auto Files = OP.getSourcePathList();
-  tooling::RefactoringTool Tool(OP.getCompilations(), Files);
   tooling::USRFindingAction FindingAction(SymbolOffsets, QualifiedNames, Force);
   Tool.run(tooling::newFrontendActionFactory(&FindingAction).get());
   const std::vector<std::vector<std::string>> &USRList =
@@ -222,7 +231,6 @@ int main(int argc, const char **argv) {
     DiagnosticsEngine Diagnostics(
         IntrusiveRefCntPtr<DiagnosticIDs>(new DiagnosticIDs()), &*DiagOpts,
         &DiagnosticPrinter, false);
-    auto &FileMgr = Tool.getFiles();
     SourceManager Sources(Diagnostics, FileMgr);
     Rewriter Rewrite(Sources, DefaultLangOptions);

Ping for reivew.

aaron.ballman accepted this revision.Apr 26 2023, 5:12 AM

LGTM, but please add a release note when landing the changes.

This revision was not accepted when it landed; it landed in state Needs Review.Apr 26 2023, 7:55 AM
This revision was automatically updated to reflect the committed changes.

LGTM, but please add a release note when landing the changes.

Thanks for the review, added a release note for change.

Thanks Aaron!

Yes, fair enough, that looks good to me, probably no need to move a sanity check to the front of main() in this case.

Also, just as a note: I don't know how many people use clang-rename anymore (especially with clangd being present), I rewrote a lot of what clang-rename has to offer for clangd with better precision and results. I think the tool is still useful, but not as much as before.

Thanks Aaron!

Yes, fair enough, that looks good to me, probably no need to move a sanity check to the front of main() in this case.

Also, just as a note: I don't know how many people use clang-rename anymore (especially with clangd being present), I rewrote a lot of what clang-rename has to offer for clangd with better precision and results. I think the tool is still useful, but not as much as before.

Should we consider deprecating clang-rename in favor of clangd, or do you think that's premature?

The difference is that clang-rename is a stand-alone binary with CLI whereas clangd isn't typically used as such (it can be, but it's a weird use-case).

I don't know if there are any existing users out there, if there are then I assume there are very few.

It was created as an intern project long ago (I guess 2014/2015?) and was in a semi-functional state, and then when I was an intern in 2016 I improved it significantly and built the integration with Vim and updated one for Emacs. We had some use-cases, but AFAIK there are none anymore at Google, and I believe most users we had were there.

Personally, I don't see any reason to keep clang-rename and support it, I don't think it's useful anymore. But this is Open-Source world so some people might object.

The difference is that clang-rename is a stand-alone binary with CLI whereas clangd isn't typically used as such (it can be, but it's a weird use-case).

I don't know if there are any existing users out there, if there are then I assume there are very few.

It was created as an intern project long ago (I guess 2014/2015?) and was in a semi-functional state, and then when I was an intern in 2016 I improved it significantly and built the integration with Vim and updated one for Emacs. We had some use-cases, but AFAIK there are none anymore at Google, and I believe most users we had were there.

Personally, I don't see any reason to keep clang-rename and support it, I don't think it's useful anymore. But this is Open-Source world so some people might object.

I think it's worth seeing if we can remove it, as it reduces around maintenance burden, build times, repo size, etc (all very, very slightly though, so I'm fine if folks push back). I'll put together an RFC to see if there is resistance to the idea.

Sounds good, thank you!