diff options
| author | Mikhail Glushenkov <foldr@codedgers.com> | 2010-02-23 09:04:57 +0000 |
|---|---|---|
| committer | Mikhail Glushenkov <foldr@codedgers.com> | 2010-02-23 09:04:57 +0000 |
| commit | 3222d94a287d46d3a1fdc991b70ab48b7d4c0729 (patch) | |
| tree | b687f15ba17ba2b33080903521637f5a0e73b3a6 /llvm/lib/CompilerDriver | |
| parent | d76f096a5305fc4d7d776f1626499d0a1cb1d3e9 (diff) | |
| download | bcm5719-llvm-3222d94a287d46d3a1fdc991b70ab48b7d4c0729.tar.gz bcm5719-llvm-3222d94a287d46d3a1fdc991b70ab48b7d4c0729.zip | |
Implement order-preserving option forwarding.
Needed to correctly handle things like 'llvmc -framework Foo foo.o -framework
Bar bar.o' - before this commit all '-framework' options would've been grouped
together in the beginning.
Due to our dependence on CommandLine this turned out to be a giant hack; we will
migrate away from CommandLine eventually.
llvm-svn: 96922
Diffstat (limited to 'llvm/lib/CompilerDriver')
| -rw-r--r-- | llvm/lib/CompilerDriver/Tool.cpp | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/llvm/lib/CompilerDriver/Tool.cpp b/llvm/lib/CompilerDriver/Tool.cpp index 7be24147ce7..5e558ca43c8 100644 --- a/llvm/lib/CompilerDriver/Tool.cpp +++ b/llvm/lib/CompilerDriver/Tool.cpp @@ -17,6 +17,8 @@ #include "llvm/ADT/StringExtras.h" #include "llvm/System/Path.h" +#include <algorithm> + using namespace llvm; using namespace llvmc; @@ -72,11 +74,21 @@ sys::Path Tool::OutFilename(const sys::Path& In, return Out; } +namespace { + template <class A, class B> + bool CompareFirst (std::pair<A,B> p1, std::pair<A,B> p2) { + return std::less<A>()(p1.first, p2.first); + } +} + StrVector Tool::SortArgs(ArgsVector& Args) const { StrVector Out; - for (ArgsVector::iterator B = Args.begin(), E = Args.end(); B != E; ++B) + // HACK: this won't be needed when we'll migrate away from CommandLine. + std::stable_sort(Args.begin(), Args.end(), &CompareFirst<unsigned, std::string>); + for (ArgsVector::iterator B = Args.begin(), E = Args.end(); B != E; ++B) { Out.push_back(B->second); + } return Out; } |

