diff options
author | Chris Lattner <sabre@nondot.org> | 2009-08-23 02:51:22 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2009-08-23 02:51:22 +0000 |
commit | 17e9edc4a7bbeadf756494cf39fcacc9eff72202 (patch) | |
tree | 9aace188da0c44dfbbedde8b592702b9dcbc2cc0 /tools/llvm-mc | |
parent | 1d7fb4eae53c7ec5f9c5c18d603b50dfb9425862 (diff) | |
download | external_llvm-17e9edc4a7bbeadf756494cf39fcacc9eff72202.zip external_llvm-17e9edc4a7bbeadf756494cf39fcacc9eff72202.tar.gz external_llvm-17e9edc4a7bbeadf756494cf39fcacc9eff72202.tar.bz2 |
Change raw_fd_ostream to take flags as an optional bitmask
instead of as two bools. Use this to add a F_Append flag
which has the obvious behavior.
Other unrelated changes conflated into this patch:
1. REmove EH stuff from llvm-dis and llvm-as, the try blocks
are dead.
2. Simplify the filename inference code in llvm-as/llvm-dis,
because raw_fd_ostream does the right thing with '-'.
3. Switch machine verifier to use raw_ostream instead of ostream
(Which is the thing that needed append in the first place).
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@79807 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'tools/llvm-mc')
-rw-r--r-- | tools/llvm-mc/llvm-mc.cpp | 14 |
1 files changed, 8 insertions, 6 deletions
diff --git a/tools/llvm-mc/llvm-mc.cpp b/tools/llvm-mc/llvm-mc.cpp index 4f5b8a0..af72fbc 100644 --- a/tools/llvm-mc/llvm-mc.cpp +++ b/tools/llvm-mc/llvm-mc.cpp @@ -174,16 +174,18 @@ static const Target *GetTarget(const char *ProgName) { } static formatted_raw_ostream *GetOutputStream() { - if (OutputFilename == "" || OutputFilename == "-") - return &fouts(); + if (OutputFilename == "") + OutputFilename = "-"; // Make sure that the Out file gets unlinked from the disk if we get a - // SIGINT - sys::RemoveFileOnSignal(sys::Path(OutputFilename)); + // SIGINT. + if (OutputFilename != "-") + sys::RemoveFileOnSignal(sys::Path(OutputFilename)); std::string Err; - raw_fd_ostream *Out = new raw_fd_ostream(OutputFilename.c_str(), - /*Binary=*/false, Force, Err); + raw_fd_ostream *Out = new raw_fd_ostream(OutputFilename.c_str(), Err, + raw_fd_ostream::F_Binary | + (Force ? raw_fd_ostream::F_Force : 0)); if (!Err.empty()) { errs() << Err << '\n'; if (!Force) |