]> granicus.if.org Git - clang/commitdiff
Driver: ArgList::getLastArg was in fact returning the first matching arg.
authorDaniel Dunbar <daniel@zuster.org>
Tue, 24 Mar 2009 17:31:30 +0000 (17:31 +0000)
committerDaniel Dunbar <daniel@zuster.org>
Tue, 24 Mar 2009 17:31:30 +0000 (17:31 +0000)
 - <rdar://problem/6715818> clang doesn't honor gcc semantic that last
    -O optimization option wins.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@67628 91177308-0d34-0410-b5e6-96231b3b80d8

include/clang/Driver/ArgList.h
lib/Driver/ArgList.cpp
test/Driver/clang-translation.c

index cf67295241b3f006ff70661ae0f461e057a4f9fd..e2b4cf47fdd9b54f8a9f41784833f765b6fa5b66 100644 (file)
@@ -32,6 +32,8 @@ namespace driver {
     typedef llvm::SmallVector<Arg*, 16> arglist_type;
     typedef arglist_type::iterator iterator;
     typedef arglist_type::const_iterator const_iterator;
+    typedef arglist_type::reverse_iterator reverse_iterator;
+    typedef arglist_type::const_reverse_iterator const_reverse_iterator;
 
   private:
     /// List of argument strings used by the contained Args.
@@ -64,9 +66,15 @@ namespace driver {
     iterator begin() { return Args.begin(); }
     iterator end() { return Args.end(); }
 
+    reverse_iterator rbegin() { return Args.rbegin(); }
+    reverse_iterator rend() { return Args.rend(); }
+
     const_iterator begin() const { return Args.begin(); }
     const_iterator end() const { return Args.end(); }
     
+    const_reverse_iterator rbegin() const { return Args.rbegin(); }
+    const_reverse_iterator rend() const { return Args.rend(); }
+    
     /// append - Append \arg A to the arg list, taking ownership.
     void append(Arg *A);
 
index 7653daf7ee17f756701031b652b5748fecaf945c..d74e3bd59d73ef95bb091e5d6383bea5fe1be1d1 100644 (file)
@@ -34,9 +34,7 @@ void ArgList::append(Arg *A) {
 
 Arg *ArgList::getLastArg(options::ID Id, bool Claim) const {
   // FIXME: Make search efficient?
-
-  // FIXME: This needs to not require loading of the option.
-  for (const_iterator it = begin(), ie = end(); it != ie; ++it) {
+  for (const_reverse_iterator it = rbegin(), ie = rend(); it != ie; ++it) {
     if ((*it)->getOption().matches(Id)) {
       if (Claim) (*it)->claim();
       return *it;
index e81dcb97ad5f054d47301ace31faf56c2569c5d0..eac05943ebe8dcafac5d6bd6aafd7acc7b89372e 100644 (file)
@@ -1,4 +1,4 @@
-// RUN: clang -ccc-host-triple i386-unknown-unknown -### -S -Os %s -o %t.s 2> %t.log
+// RUN: clang -ccc-host-triple i386-unknown-unknown -### -S -O0 -Os %s -o %t.s 2> %t.log
 // RUN: grep '"-S"' %t.log &&
 // RUN: grep '"-disable-free"' %t.log &&
 // RUN: grep '"--relocation-model" "static"' %t.log &&