diff options
| author | David Greene <greened@obbligato.org> | 2009-07-14 20:18:05 +0000 | 
|---|---|---|
| committer | David Greene <greened@obbligato.org> | 2009-07-14 20:18:05 +0000 | 
| commit | a31f96cf2bb2d4868d629b17b4e8ec106a23e776 (patch) | |
| tree | 90d314a81dfda17ca4c96c57774b0a789e25df90 /llvm/tools | |
| parent | f6a5ab9abddb9c57c116449490114ec695f7e85f (diff) | |
| download | bcm5719-llvm-a31f96cf2bb2d4868d629b17b4e8ec106a23e776.tar.gz bcm5719-llvm-a31f96cf2bb2d4868d629b17b4e8ec106a23e776.zip | |
Have asm printers use formatted_raw_ostream directly to avoid a
dynamic_cast<>.
llvm-svn: 75670
Diffstat (limited to 'llvm/tools')
| -rw-r--r-- | llvm/tools/llc/llc.cpp | 30 | ||||
| -rw-r--r-- | llvm/tools/lto/LTOCodeGenerator.cpp | 8 | ||||
| -rw-r--r-- | llvm/tools/lto/LTOCodeGenerator.h | 2 | 
3 files changed, 25 insertions, 15 deletions
| diff --git a/llvm/tools/llc/llc.cpp b/llvm/tools/llc/llc.cpp index 42d158cf5ec..8e7e17cbbfa 100644 --- a/llvm/tools/llc/llc.cpp +++ b/llvm/tools/llc/llc.cpp @@ -30,12 +30,12 @@  #include "llvm/Pass.h"  #include "llvm/Support/CommandLine.h"  #include "llvm/Support/FileUtilities.h" +#include "llvm/Support/FormattedStream.h"  #include "llvm/Support/ManagedStatic.h"  #include "llvm/Support/MemoryBuffer.h"  #include "llvm/Support/PluginLoader.h"  #include "llvm/Support/PrettyStackTrace.h"  #include "llvm/Support/RegistryParser.h" -#include "llvm/Support/raw_ostream.h"  #include "llvm/Analysis/Verifier.h"  #include "llvm/System/Signals.h"  #include "llvm/Config/config.h" @@ -128,10 +128,10 @@ GetFileNameRoot(const std::string &InputFilename) {    return outputFilename;  } -static raw_ostream *GetOutputStream(const char *ProgName) { +static formatted_raw_ostream *GetOutputStream(const char *ProgName) {    if (OutputFilename != "") {      if (OutputFilename == "-") -      return &outs(); +      return &fouts();      // Specified an output filename?      if (!Force && std::ifstream(OutputFilename.c_str())) { @@ -146,7 +146,10 @@ static raw_ostream *GetOutputStream(const char *ProgName) {      sys::RemoveFileOnSignal(sys::Path(OutputFilename));      std::string error; -    raw_ostream *Out = new raw_fd_ostream(OutputFilename.c_str(), true, error); +    raw_fd_ostream *FDOut = new raw_fd_ostream(OutputFilename.c_str(), +                                               true, error); +    formatted_raw_ostream *Out = +      new formatted_raw_ostream(*FDOut, formatted_raw_ostream::DELETE_STREAM);      if (!error.empty()) {        std::cerr << error << '\n';        delete Out; @@ -158,7 +161,7 @@ static raw_ostream *GetOutputStream(const char *ProgName) {    if (InputFilename == "-") {      OutputFilename = "-"; -    return &outs(); +    return &fouts();    }    OutputFilename = GetFileNameRoot(InputFilename); @@ -199,7 +202,10 @@ static raw_ostream *GetOutputStream(const char *ProgName) {    sys::RemoveFileOnSignal(sys::Path(OutputFilename));    std::string error; -  raw_ostream *Out = new raw_fd_ostream(OutputFilename.c_str(), Binary, error); +  raw_fd_ostream *FDOut = new raw_fd_ostream(OutputFilename.c_str(), +                                             Binary, error); +  formatted_raw_ostream *Out = +    new formatted_raw_ostream(*FDOut, formatted_raw_ostream::DELETE_STREAM);    if (!error.empty()) {      std::cerr << error << '\n';      delete Out; @@ -268,7 +274,7 @@ int main(int argc, char **argv) {    TargetMachine &Target = *target.get();    // Figure out where we are going to send the output... -  raw_ostream *Out = GetOutputStream(argv[0]); +  formatted_raw_ostream *Out = GetOutputStream(argv[0]);    if (Out == 0) return 1;    CodeGenOpt::Level OLvl = CodeGenOpt::Default; @@ -295,7 +301,7 @@ int main(int argc, char **argv) {      if (Target.addPassesToEmitWholeFile(PM, *Out, FileType, OLvl)) {        std::cerr << argv[0] << ": target does not support generation of this"                  << " file type!\n"; -      if (Out != &outs()) delete Out; +      if (Out != &fouts()) delete Out;        // And the Out file is empty and useless, so remove it now.        sys::Path(OutputFilename).eraseFromDisk();        return 1; @@ -325,7 +331,7 @@ int main(int argc, char **argv) {      case FileModel::Error:        std::cerr << argv[0] << ": target does not support generation of this"                  << " file type!\n"; -      if (Out != &outs()) delete Out; +      if (Out != &fouts()) delete Out;        // And the Out file is empty and useless, so remove it now.        sys::Path(OutputFilename).eraseFromDisk();        return 1; @@ -342,7 +348,7 @@ int main(int argc, char **argv) {      if (Target.addPassesToEmitFileFinish(Passes, OCE, OLvl)) {        std::cerr << argv[0] << ": target does not support generation of this"                  << " file type!\n"; -      if (Out != &outs()) delete Out; +      if (Out != &fouts()) delete Out;        // And the Out file is empty and useless, so remove it now.        sys::Path(OutputFilename).eraseFromDisk();        return 1; @@ -364,8 +370,10 @@ int main(int argc, char **argv) {      Passes.doFinalization();    } +  Out->flush(); +    // Delete the ostream if it's not a stdout stream -  if (Out != &outs()) delete Out; +  if (Out != &fouts()) delete Out;    return 0;  } diff --git a/llvm/tools/lto/LTOCodeGenerator.cpp b/llvm/tools/lto/LTOCodeGenerator.cpp index 26effa55277..b4c4e7767b9 100644 --- a/llvm/tools/lto/LTOCodeGenerator.cpp +++ b/llvm/tools/lto/LTOCodeGenerator.cpp @@ -30,11 +30,11 @@  #include "llvm/Bitcode/ReaderWriter.h"  #include "llvm/CodeGen/FileWriters.h"  #include "llvm/Support/CommandLine.h" +#include "llvm/Support/FormattedStream.h"  #include "llvm/Support/Mangler.h"  #include "llvm/Support/MemoryBuffer.h"  #include "llvm/Support/StandardPasses.h"  #include "llvm/Support/SystemUtils.h" -#include "llvm/Support/raw_ostream.h"  #include "llvm/System/Signals.h"  #include "llvm/Target/SubtargetFeature.h"  #include "llvm/Target/TargetOptions.h" @@ -185,7 +185,9 @@ const void* LTOCodeGenerator::compile(size_t* length, std::string& errMsg)      // generate assembly code      bool genResult = false;      { -      raw_fd_ostream asmFile(uniqueAsmPath.c_str(), false, errMsg); +      raw_fd_ostream asmFD(raw_fd_ostream(uniqueAsmPath.c_str(), +                                          false, errMsg)); +      formatted_raw_ostream asmFile(asmFD);        if (!errMsg.empty())          return NULL;        genResult = this->generateAssemblyCode(asmFile, errMsg); @@ -390,7 +392,7 @@ void LTOCodeGenerator::applyScopeRestrictions()  }  /// Optimize merged modules using various IPO passes -bool LTOCodeGenerator::generateAssemblyCode(raw_ostream& out, +bool LTOCodeGenerator::generateAssemblyCode(formatted_raw_ostream& out,                                              std::string& errMsg)  {      if (  this->determineTarget(errMsg) )  diff --git a/llvm/tools/lto/LTOCodeGenerator.h b/llvm/tools/lto/LTOCodeGenerator.h index 5548050fda0..ef763642124 100644 --- a/llvm/tools/lto/LTOCodeGenerator.h +++ b/llvm/tools/lto/LTOCodeGenerator.h @@ -45,7 +45,7 @@ public:      const void*         compile(size_t* length, std::string& errMsg);      void                setCodeGenDebugOptions(const char *opts);   private: -    bool                generateAssemblyCode(llvm::raw_ostream& out,  +    bool                generateAssemblyCode(llvm::formatted_raw_ostream& out,                                                std::string& errMsg);      bool                assemble(const std::string& asmPath,                               const std::string& objPath, std::string& errMsg); | 

