diff options
author | Dan Gohman <gohman@apple.com> | 2009-07-15 17:29:42 +0000 |
---|---|---|
committer | Dan Gohman <gohman@apple.com> | 2009-07-15 17:29:42 +0000 |
commit | 607818a2c17267f5c49745fe987ec6a43145b059 (patch) | |
tree | c6924b900aaddd14027ca45a60bd73d57f887c18 /llvm/tools/llvm-as | |
parent | 338191cd67a0a3e324c8b1475c975fed5ffa9e94 (diff) | |
download | bcm5719-llvm-607818a2c17267f5c49745fe987ec6a43145b059.tar.gz bcm5719-llvm-607818a2c17267f5c49745fe987ec6a43145b059.zip |
Add a Force option to raw_fd_ostream to specify whether opening
an existing file is considered an error. Convert several tools
to use raw_fd_ostream instead of std::ostream, and to use this
new option instead of doing a manual check.
llvm-svn: 75801
Diffstat (limited to 'llvm/tools/llvm-as')
-rw-r--r-- | llvm/tools/llvm-as/llvm-as.cpp | 48 |
1 files changed, 21 insertions, 27 deletions
diff --git a/llvm/tools/llvm-as/llvm-as.cpp b/llvm/tools/llvm-as/llvm-as.cpp index eccabd5d14a..1d572f15784 100644 --- a/llvm/tools/llvm-as/llvm-as.cpp +++ b/llvm/tools/llvm-as/llvm-as.cpp @@ -28,8 +28,6 @@ #include "llvm/Support/SystemUtils.h" #include "llvm/Support/raw_ostream.h" #include "llvm/System/Signals.h" -#include <fstream> -#include <iostream> #include <memory> using namespace llvm; @@ -62,7 +60,7 @@ int main(int argc, char **argv) { cl::ParseCommandLineOptions(argc, argv, "llvm .ll -> .bc assembler\n"); int exitCode = 0; - std::ostream *Out = 0; + raw_ostream *Out = 0; try { // Parse the file now... SMDiagnostic Err; @@ -86,23 +84,24 @@ int main(int argc, char **argv) { if (OutputFilename != "") { // Specified an output filename? if (OutputFilename != "-") { // Not stdout? - if (!Force && std::ifstream(OutputFilename.c_str())) { - // If force is not specified, make sure not to overwrite a file! - cerr << argv[0] << ": error opening '" << OutputFilename - << "': file exists!\n" - << "Use -f command line argument to force output\n"; + std::string ErrorInfo; + Out = new raw_fd_ostream(OutputFilename.c_str(), /*Binary=*/true, + Force, ErrorInfo); + if (!ErrorInfo.empty()) { + errs() << ErrorInfo << '\n'; + if (!Force) + errs() << "Use -f command line argument to force output\n"; + delete Out; return 1; } - Out = new std::ofstream(OutputFilename.c_str(), std::ios::out | - std::ios::trunc | std::ios::binary); } else { // Specified stdout - // FIXME: cout is not binary! - Out = &std::cout; + // FIXME: outs() is not binary! + Out = &outs(); } } else { if (InputFilename == "-") { OutputFilename = "-"; - Out = &std::cout; + Out = &outs(); } else { std::string IFN = InputFilename; int Len = IFN.length(); @@ -114,27 +113,22 @@ int main(int argc, char **argv) { } OutputFilename += ".bc"; - if (!Force && std::ifstream(OutputFilename.c_str())) { - // If force is not specified, make sure not to overwrite a file! - cerr << argv[0] << ": error opening '" << OutputFilename - << "': file exists!\n" - << "Use -f command line argument to force output\n"; + std::string ErrorInfo; + Out = new raw_fd_ostream(OutputFilename.c_str(), /*Binary=*/true, + Force, ErrorInfo); + if (!ErrorInfo.empty()) { + errs() << ErrorInfo << '\n'; + if (!Force) + errs() << "Use -f command line argument to force output\n"; + delete Out; return 1; } - - Out = new std::ofstream(OutputFilename.c_str(), std::ios::out | - std::ios::trunc | std::ios::binary); // Make sure that the Out file gets unlinked from the disk if we get a // SIGINT sys::RemoveFileOnSignal(sys::Path(OutputFilename)); } } - if (!Out->good()) { - cerr << argv[0] << ": error opening " << OutputFilename << "!\n"; - return 1; - } - if (!DisableOutput) if (Force || !CheckBitcodeOutputToConsole(Out,true)) WriteBitcodeToFile(M.get(), *Out); @@ -146,7 +140,7 @@ int main(int argc, char **argv) { exitCode = 1; } - if (Out != &std::cout) delete Out; + if (Out != &outs()) delete Out; return exitCode; } |