diff options
author | Daniel Dunbar <daniel@zuster.org> | 2009-06-16 23:25:22 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2009-06-16 23:25:22 +0000 |
commit | 1b3ec3a0003aaa154a93b923c0944063d4c2ed59 (patch) | |
tree | 079b621fcf758afadc3a17b58222a50481955e50 /clang/lib/Driver/Driver.cpp | |
parent | 655908aaf79070b270a9b0c746a629e04be86ea8 (diff) | |
download | bcm5719-llvm-1b3ec3a0003aaa154a93b923c0944063d4c2ed59.tar.gz bcm5719-llvm-1b3ec3a0003aaa154a93b923c0944063d4c2ed59.zip |
Fake support for -print-multi-*
- I think we will eventually need to support this for realz, and some build
processes seem to depend on these options.
llvm-svn: 73581
Diffstat (limited to 'clang/lib/Driver/Driver.cpp')
-rw-r--r-- | clang/lib/Driver/Driver.cpp | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/clang/lib/Driver/Driver.cpp b/clang/lib/Driver/Driver.cpp index d9a2c2c3935..54704d48276 100644 --- a/clang/lib/Driver/Driver.cpp +++ b/clang/lib/Driver/Driver.cpp @@ -429,6 +429,47 @@ bool Driver::HandleImmediateArgs(const Compilation &C) { return false; } + if (C.getArgs().hasArg(options::OPT_print_multi_lib)) { + // FIXME: We need tool chain support for this. + llvm::outs() << ".;\n"; + + switch (C.getDefaultToolChain().getTriple().getArch()) { + default: + break; + + case llvm::Triple::x86_64: + llvm::outs() << "x86_64;@m64" << "\n"; + break; + + case llvm::Triple::ppc64: + llvm::outs() << "ppc64;@m64" << "\n"; + break; + } + return false; + } + + // FIXME: What is the difference between print-multi-directory and + // print-multi-os-directory? + if (C.getArgs().hasArg(options::OPT_print_multi_directory) || + C.getArgs().hasArg(options::OPT_print_multi_os_directory)) { + switch (C.getDefaultToolChain().getTriple().getArch()) { + default: + case llvm::Triple::x86: + case llvm::Triple::ppc: + llvm::outs() << "." << "\n"; + break; + + case llvm::Triple::x86_64: + llvm::outs() << "x86_64" << "\n"; + break; + + case llvm::Triple::ppc64: + llvm::outs() << "ppc64" << "\n"; + break; + } + return false; + } + return true; } |