summaryrefslogtreecommitdiffstats
path: root/clang/lib
diff options
context:
space:
mode:
authorNick Lewycky <nicholas@mxc.ca>2010-08-15 16:47:39 +0000
committerNick Lewycky <nicholas@mxc.ca>2010-08-15 16:47:39 +0000
commit53f1042dc1a95c226b446512ac7349d634e7e8b2 (patch)
tree1d621a3984f9d54da31b4062ecad6dee98492305 /clang/lib
parent8146b6ccd95f7b697f1e61dc1c1c0d9cdf078f33 (diff)
downloadbcm5719-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.cpp6
-rw-r--r--clang/lib/Rewrite/FrontendActions.cpp8
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()));
OpenPOWER on IntegriCloud