diff options
| author | Nick Lewycky <nicholas@mxc.ca> | 2010-08-15 16:47:39 +0000 |
|---|---|---|
| committer | Nick Lewycky <nicholas@mxc.ca> | 2010-08-15 16:47:39 +0000 |
| commit | 53f1042dc1a95c226b446512ac7349d634e7e8b2 (patch) | |
| tree | 1d621a3984f9d54da31b4062ecad6dee98492305 /clang/lib | |
| parent | 8146b6ccd95f7b697f1e61dc1c1c0d9cdf078f33 (diff) | |
| download | bcm5719-llvm-53f1042dc1a95c226b446512ac7349d634e7e8b2.tar.gz bcm5719-llvm-53f1042dc1a95c226b446512ac7349d634e7e8b2.zip | |
Make the FixItOptions object required instead of optional.
llvm-svn: 111105
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/Rewrite/FixItRewriter.cpp | 6 | ||||
| -rw-r--r-- | clang/lib/Rewrite/FrontendActions.cpp | 8 |
2 files changed, 9 insertions, 5 deletions
diff --git a/clang/lib/Rewrite/FixItRewriter.cpp b/clang/lib/Rewrite/FixItRewriter.cpp index 20cefb01655..df7b60547a4 100644 --- a/clang/lib/Rewrite/FixItRewriter.cpp +++ b/clang/lib/Rewrite/FixItRewriter.cpp @@ -49,16 +49,14 @@ bool FixItRewriter::WriteFixedFile(FileID ID, llvm::raw_ostream &OS) { } bool FixItRewriter::WriteFixedFiles() { - if (NumFailures > 0 && (!FixItOpts || !FixItOpts->FixWhatYouCan)) { + if (NumFailures > 0 && !FixItOpts->FixWhatYouCan) { Diag(FullSourceLoc(), diag::warn_fixit_no_changes); return true; } for (iterator I = buffer_begin(), E = buffer_end(); I != E; ++I) { const FileEntry *Entry = Rewrite.getSourceMgr().getFileEntryForID(I->first); - std::string Filename = Entry->getName(); - if (FixItOpts) - Filename = FixItOpts->RewriteFilename(Filename); + std::string Filename = FixItOpts->RewriteFilename(Entry->getName()); std::string Err; llvm::raw_fd_ostream OS(Filename.c_str(), Err, llvm::raw_fd_ostream::F_Binary); diff --git a/clang/lib/Rewrite/FrontendActions.cpp b/clang/lib/Rewrite/FrontendActions.cpp index 6d98987a147..977e0cfba6d 100644 --- a/clang/lib/Rewrite/FrontendActions.cpp +++ b/clang/lib/Rewrite/FrontendActions.cpp @@ -42,6 +42,11 @@ ASTConsumer *FixItAction::CreateASTConsumer(CompilerInstance &CI, return new ASTConsumer(); } +class FixItRewriteInPlace : public FixItOptions { +public: + std::string RewriteFilename(const std::string &Filename) { return Filename; } +}; + class FixItActionSuffixInserter : public FixItOptions { std::string NewSuffix; @@ -67,7 +72,8 @@ bool FixItAction::BeginSourceFileAction(CompilerInstance &CI, FixItOpts.reset(new FixItActionSuffixInserter(FEOpts.FixItSuffix, FEOpts.FixWhatYouCan)); } else { - FixItOpts.reset(); + FixItOpts.reset(new FixItRewriteInPlace); + FixItOpts->FixWhatYouCan = FEOpts.FixWhatYouCan; } Rewriter.reset(new FixItRewriter(CI.getDiagnostics(), CI.getSourceManager(), CI.getLangOpts(), FixItOpts.get())); |

