Handle replacement into a position past the original member.
authorRafael Espindola <rafael.espindola@gmail.com>
Sun, 21 Jul 2013 12:58:07 +0000 (12:58 +0000)
committerRafael Espindola <rafael.espindola@gmail.com>
Sun, 21 Jul 2013 12:58:07 +0000 (12:58 +0000)
We were incorrectly computing where to insert a member if it was replacing
a previous member that was before the insert point.

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

test/Object/archive-replace-pos.test
tools/llvm-ar/llvm-ar.cpp

index 307f0709a796c49007c36c352f1e8a7cde6933e6..0ba9b6dd282a5bba94b65307aef98205d3bc5d54 100644 (file)
@@ -11,3 +11,16 @@ RUN: llvm-ar t %t.a | FileCheck %s
 CHECK: .foo
 CHECK-NEXT: .zed
 CHECK-NEXT: .bar
+
+RUN: llvm-ar rc %t.a %t.foo %t.bar
+RUN: llvm-ar t %t.a | FileCheck --check-prefix=CHECK2 %s
+
+CHECK2: .zed
+CHECK2-NEXT: .foo
+CHECK2-NEXT: .bar
+
+RUN: llvm-ar rca %t.foo %t.a %t.zed
+RUN: llvm-ar t %t.a | FileCheck --check-prefix=CHECK3 %s
+CHECK3: .foo
+CHECK3-NEXT: .zed
+CHECK3-NEXT: .bar
index 4ade562ad80ae42160e02eee14cd8a4c148ea6de..b1c89861340762bc9269ad50ceb844a96ff58848 100644 (file)
@@ -458,10 +458,10 @@ computeNewArchiveMembers(ArchiveOperation Operation,
   int InsertPos = -1;
   StringRef PosName = sys::path::filename(RelPos);
   if (OldArchive) {
-    int Pos = 0;
     for (object::Archive::child_iterator I = OldArchive->begin_children(),
                                          E = OldArchive->end_children();
-         I != E; ++I, ++Pos) {
+         I != E; ++I) {
+      int Pos = Ret.size();
       StringRef Name;
       failIfError(I->getName(Name));
       if (Name == PosName) {