diff options
author | Yitzhak Mandelbaum <yitzhakm@google.com> | 2019-04-30 16:48:33 +0000 |
---|---|---|
committer | Yitzhak Mandelbaum <yitzhakm@google.com> | 2019-04-30 16:48:33 +0000 |
commit | aecc59c5f948dfc5f438b397baea00804934a517 (patch) | |
tree | 540132b0ffa8dbc6a943432cc1bbd159e1afa2b1 /clang/lib/Tooling/Refactoring | |
parent | be323ef5718b759fffb1b329ba9e2c6af6e5d958 (diff) | |
download | bcm5719-llvm-aecc59c5f948dfc5f438b397baea00804934a517.tar.gz bcm5719-llvm-aecc59c5f948dfc5f438b397baea00804934a517.zip |
[LibTooling] Change Transformer's TextGenerator to a partial function.
Summary:
Changes the signature of the TextGenerator std::function to return an Expected<std::string>
instead of std::string to allow for (non-fatal) failures. Previously, we
expected that any failures would be expressed with assertions. However, that's
unfriendly to running the code in servers or other places that don't want their
library calls to crash the program.
Correspondingly, updates Transformer's handling of failures in TextGenerators
and the signature of `ChangeConsumer`.
Reviewers: ilya-biryukov
Subscribers: cfe-commits
Tags: #clang
Differential Revision: https://reviews.llvm.org/D61015
llvm-svn: 359574
Diffstat (limited to 'clang/lib/Tooling/Refactoring')
-rw-r--r-- | clang/lib/Tooling/Refactoring/Transformer.cpp | 40 |
1 files changed, 21 insertions, 19 deletions
diff --git a/clang/lib/Tooling/Refactoring/Transformer.cpp b/clang/lib/Tooling/Refactoring/Transformer.cpp index 57f66598570..57a836567df 100644 --- a/clang/lib/Tooling/Refactoring/Transformer.cpp +++ b/clang/lib/Tooling/Refactoring/Transformer.cpp @@ -153,16 +153,19 @@ tooling::translateEdits(const MatchResult &Result, auto It = NodesMap.find(Edit.Target); assert(It != NodesMap.end() && "Edit target must be bound in the match."); - Expected<CharSourceRange> RangeOrErr = getTargetRange( + Expected<CharSourceRange> Range = getTargetRange( Edit.Target, It->second, Edit.Kind, Edit.Part, *Result.Context); - if (auto Err = RangeOrErr.takeError()) - return std::move(Err); - Transformation T; - T.Range = *RangeOrErr; - if (T.Range.isInvalid() || - isOriginMacroBody(*Result.SourceManager, T.Range.getBegin())) + if (!Range) + return Range.takeError(); + if (Range->isInvalid() || + isOriginMacroBody(*Result.SourceManager, Range->getBegin())) return SmallVector<Transformation, 0>(); - T.Replacement = Edit.Replacement(Result); + auto Replacement = Edit.Replacement(Result); + if (!Replacement) + return Replacement.takeError(); + Transformation T; + T.Range = *Range; + T.Replacement = std::move(*Replacement); Transformations.push_back(std::move(T)); } return Transformations; @@ -194,14 +197,13 @@ void Transformer::run(const MatchResult &Result) { Root->second.getSourceRange().getBegin()); assert(RootLoc.isValid() && "Invalid location for Root node of match."); - auto TransformationsOrErr = translateEdits(Result, Rule.Edits); - if (auto Err = TransformationsOrErr.takeError()) { - llvm::errs() << "Transformation failed: " << llvm::toString(std::move(Err)) - << "\n"; + auto Transformations = translateEdits(Result, Rule.Edits); + if (!Transformations) { + Consumer(Transformations.takeError()); return; } - auto &Transformations = *TransformationsOrErr; - if (Transformations.empty()) { + + if (Transformations->empty()) { // No rewrite applied (but no error encountered either). RootLoc.print(llvm::errs() << "note: skipping match at loc ", *Result.SourceManager); @@ -209,14 +211,14 @@ void Transformer::run(const MatchResult &Result) { return; } - // Convert the result to an AtomicChange. + // Record the results in the AtomicChange. AtomicChange AC(*Result.SourceManager, RootLoc); - for (const auto &T : Transformations) { + for (const auto &T : *Transformations) { if (auto Err = AC.replace(*Result.SourceManager, T.Range, T.Replacement)) { - AC.setError(llvm::toString(std::move(Err))); - break; + Consumer(std::move(Err)); + return; } } - Consumer(AC); + Consumer(std::move(AC)); } |