mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-04 23:32:00 +00:00
simplify output file selection, fixing two FIXMEs about binary output
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@79808 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
17e9edc4a7
commit
51a1132403
@ -110,29 +110,20 @@ int main(int argc, char **argv) {
|
|||||||
Passes.add(createDeadTypeEliminationPass()); // Remove dead types...
|
Passes.add(createDeadTypeEliminationPass()); // Remove dead types...
|
||||||
Passes.add(createStripDeadPrototypesPass()); // Remove dead func decls
|
Passes.add(createStripDeadPrototypesPass()); // Remove dead func decls
|
||||||
|
|
||||||
raw_ostream *Out = 0;
|
|
||||||
|
|
||||||
if (OutputFilename != "-") { // Not stdout?
|
|
||||||
std::string ErrorInfo;
|
std::string ErrorInfo;
|
||||||
Out = new raw_fd_ostream(OutputFilename.c_str(), ErrorInfo,
|
std::auto_ptr<raw_fd_ostream>
|
||||||
|
Out(new raw_fd_ostream(OutputFilename.c_str(), ErrorInfo,
|
||||||
raw_fd_ostream::F_Binary |
|
raw_fd_ostream::F_Binary |
|
||||||
(Force ? raw_fd_ostream::F_Force : 0));
|
(Force ? raw_fd_ostream::F_Force : 0)));
|
||||||
if (!ErrorInfo.empty()) {
|
if (!ErrorInfo.empty()) {
|
||||||
errs() << ErrorInfo << '\n';
|
errs() << ErrorInfo << '\n';
|
||||||
if (!Force)
|
if (!Force)
|
||||||
errs() << "Use -f command line argument to force output\n";
|
errs() << "Use -f command line argument to force output\n";
|
||||||
delete Out;
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
} else { // Specified stdout
|
|
||||||
// FIXME: outs() is not binary!
|
|
||||||
Out = &outs();
|
|
||||||
}
|
|
||||||
|
|
||||||
Passes.add(createBitcodeWriterPass(*Out));
|
Passes.add(createBitcodeWriterPass(*Out));
|
||||||
Passes.run(*M.get());
|
Passes.run(*M.get());
|
||||||
|
|
||||||
if (Out != &outs())
|
|
||||||
delete Out;
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -118,25 +118,22 @@ int main(int argc, char **argv) {
|
|||||||
|
|
||||||
if (DumpAsm) errs() << "Here's the assembly:\n" << *Composite.get();
|
if (DumpAsm) errs() << "Here's the assembly:\n" << *Composite.get();
|
||||||
|
|
||||||
// FIXME: outs() is not binary!
|
|
||||||
raw_ostream *Out = &outs(); // Default to printing to stdout...
|
|
||||||
if (OutputFilename != "-") {
|
|
||||||
std::string ErrorInfo;
|
std::string ErrorInfo;
|
||||||
Out = new raw_fd_ostream(OutputFilename.c_str(), ErrorInfo,
|
std::auto_ptr<raw_ostream>
|
||||||
|
Out(new raw_fd_ostream(OutputFilename.c_str(), ErrorInfo,
|
||||||
raw_fd_ostream::F_Binary |
|
raw_fd_ostream::F_Binary |
|
||||||
(Force ? raw_fd_ostream::F_Force : 0));
|
(Force ? raw_fd_ostream::F_Force : 0)));
|
||||||
if (!ErrorInfo.empty()) {
|
if (!ErrorInfo.empty()) {
|
||||||
errs() << ErrorInfo << '\n';
|
errs() << ErrorInfo << '\n';
|
||||||
if (!Force)
|
if (!Force)
|
||||||
errs() << "Use -f command line argument to force output\n";
|
errs() << "Use -f command line argument to force output\n";
|
||||||
delete Out;
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Make sure that the Out file gets unlinked from the disk if we get a
|
// Make sure that the Out file gets unlinked from the disk if we get a
|
||||||
// SIGINT
|
// SIGINT
|
||||||
|
if (OutputFilename != "-")
|
||||||
sys::RemoveFileOnSignal(sys::Path(OutputFilename));
|
sys::RemoveFileOnSignal(sys::Path(OutputFilename));
|
||||||
}
|
|
||||||
|
|
||||||
if (verifyModule(*Composite.get())) {
|
if (verifyModule(*Composite.get())) {
|
||||||
errs() << argv[0] << ": linked module is broken!\n";
|
errs() << argv[0] << ": linked module is broken!\n";
|
||||||
@ -146,6 +143,5 @@ int main(int argc, char **argv) {
|
|||||||
if (Verbose) errs() << "Writing bitcode...\n";
|
if (Verbose) errs() << "Writing bitcode...\n";
|
||||||
WriteBitcodeToFile(Composite.get(), *Out);
|
WriteBitcodeToFile(Composite.get(), *Out);
|
||||||
|
|
||||||
if (Out != &outs()) delete Out;
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user