diff options
| author | Luqman Aden <laden@csclub.uwaterloo.ca> | 2014-09-30 17:20:22 -0400 |
|---|---|---|
| committer | Luqman Aden <laden@csclub.uwaterloo.ca> | 2014-10-04 13:28:57 -0400 |
| commit | 4b22178d325704d81522c15570498b7467b3152d (patch) | |
| tree | 277fbb7ca36b075541c3df33928e8f48147f05d2 /src/rustllvm/PassWrapper.cpp | |
| parent | 20f4c45bade89f0a8df5297811af3d9f8b91d075 (diff) | |
| download | rust-4b22178d325704d81522c15570498b7467b3152d.tar.gz rust-4b22178d325704d81522c15570498b7467b3152d.zip | |
Update LLVM.
Diffstat (limited to 'src/rustllvm/PassWrapper.cpp')
| -rw-r--r-- | src/rustllvm/PassWrapper.cpp | 18 |
1 files changed, 15 insertions, 3 deletions
diff --git a/src/rustllvm/PassWrapper.cpp b/src/rustllvm/PassWrapper.cpp index 195b044ccdc..eb074001d58 100644 --- a/src/rustllvm/PassWrapper.cpp +++ b/src/rustllvm/PassWrapper.cpp @@ -118,7 +118,9 @@ LLVMRustAddAnalysisPasses(LLVMTargetMachineRef TM, LLVMPassManagerRef PMR, LLVMModuleRef M) { PassManagerBase *PM = unwrap(PMR); -#if LLVM_VERSION_MINOR >= 5 +#if LLVM_VERSION_MINOR >= 6 + PM->add(new DataLayoutPass()); +#elif LLVM_VERSION_MINOR == 5 PM->add(new DataLayoutPass(unwrap(M))); #else PM->add(new DataLayout(unwrap(M))); @@ -187,7 +189,12 @@ LLVMRustWriteOutputFile(LLVMTargetMachineRef Target, PassManager *PM = unwrap<PassManager>(PMR); std::string ErrorInfo; -#if LLVM_VERSION_MINOR >= 4 +#if LLVM_VERSION_MINOR >= 6 + std::error_code EC; + raw_fd_ostream OS(path, EC, sys::fs::F_None); + if (EC) + ErrorInfo = EC.message(); +#elif LLVM_VERSION_MINOR >= 4 raw_fd_ostream OS(path, ErrorInfo, sys::fs::F_None); #else raw_fd_ostream OS(path, ErrorInfo, raw_fd_ostream::F_Binary); @@ -210,7 +217,12 @@ LLVMRustPrintModule(LLVMPassManagerRef PMR, PassManager *PM = unwrap<PassManager>(PMR); std::string ErrorInfo; -#if LLVM_VERSION_MINOR >= 4 +#if LLVM_VERSION_MINOR >= 6 + std::error_code EC; + raw_fd_ostream OS(path, EC, sys::fs::F_None); + if (EC) + ErrorInfo = EC.message(); +#elif LLVM_VERSION_MINOR >= 4 raw_fd_ostream OS(path, ErrorInfo, sys::fs::F_None); #else raw_fd_ostream OS(path, ErrorInfo, raw_fd_ostream::F_Binary); |
