[PATCH] D43989: MRI delete command

Dmitry Mikulin via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Fri Mar 2 12:55:38 PST 2018


dmikulin updated this revision to Diff 136834.
dmikulin added a comment.

Changed the implementation to avoid writing the archive twice.


https://reviews.llvm.org/D43989

Files:
  llvm/test/tools/llvm-ar/mri-delete.test
  llvm/tools/llvm-ar/llvm-ar.cpp


Index: llvm/tools/llvm-ar/llvm-ar.cpp
===================================================================
--- llvm/tools/llvm-ar/llvm-ar.cpp
+++ llvm/tools/llvm-ar/llvm-ar.cpp
@@ -488,6 +488,17 @@
     Members[Pos] = std::move(*NMOrErr);
 }
 
+static void deleteMember(std::vector<NewArchiveMember> &Members,
+                         StringRef FileName) {
+  StringRef MemberName = sys::path::filename(FileName);
+  for (auto Member = Members.begin(); Member != Members.end();) {
+    if (Member->MemberName == MemberName)
+      Member = Members.erase(Member);
+    else
+      ++Member;
+  }
+}
+
 enum InsertAction {
   IA_AddOldMember,
   IA_AddNewMember,
@@ -758,7 +769,7 @@
 }
 
 static void runMRIScript() {
-  enum class MRICommand { AddLib, AddMod, Create, Save, End, Invalid };
+  enum class MRICommand { AddLib, AddMod, Create, Delete, Save, End, Invalid };
 
   ErrorOr<std::unique_ptr<MemoryBuffer>> Buf = MemoryBuffer::getSTDIN();
   failIfError(Buf.getError());
@@ -779,6 +790,7 @@
                        .Case("addlib", MRICommand::AddLib)
                        .Case("addmod", MRICommand::AddMod)
                        .Case("create", MRICommand::Create)
+                       .Case("delete", MRICommand::Delete)
                        .Case("save", MRICommand::Save)
                        .Case("end", MRICommand::End)
                        .Default(MRICommand::Invalid);
@@ -813,6 +825,9 @@
         fail("File already saved");
       ArchiveName = Rest;
       break;
+    case MRICommand::Delete:
+      deleteMember(NewMembers, Rest);
+      break;
     case MRICommand::Save:
       Saved = true;
       break;
Index: llvm/test/tools/llvm-ar/mri-delete.test
===================================================================
--- /dev/null
+++ llvm/test/tools/llvm-ar/mri-delete.test
@@ -0,0 +1,14 @@
+RUN: yaml2obj %S/Inputs/elf.yaml -o %t.o
+RUN: rm -f %t.ar
+
+RUN: echo "create %t.ar" > %t.mri
+RUN: echo "addmod %t.o" >> %t.mri
+RUN: echo "addmod %S/Inputs/elf.yaml" >> %t.mri
+RUN: echo "delete %t.o" >> %t.mri
+RUN: echo "save" >> %t.mri
+RUN: echo "end" >> %t.mri
+
+RUN: llvm-ar -M < %t.mri
+RUN: llvm-ar tv %t.ar | FileCheck %s
+
+CHECK-NOT: mri-delete.test{{.*}}.o


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D43989.136834.patch
Type: text/x-patch
Size: 2212 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20180302/e6fa729a/attachment.bin>


More information about the llvm-commits mailing list