From 1d8b300a4ac71c866d111ddc406804a07c177de5 Mon Sep 17 00:00:00 2001 From: Martin Storsjo Date: Thu, 6 Sep 2018 18:10:45 +0000 Subject: [PATCH] [llvm-ar] Support * as comment char in MRI scripts MRI scripts have two comment chars, * and ;, but only the latter was supported before. Also allow leading spaces before comment chars (and before any command string), and allow comments after a command. Differential Revision: https://reviews.llvm.org/D51338 llvm-svn: 341571 --- test/tools/llvm-ar/mri-delete.test | 12 +++++++++--- tools/llvm-ar/llvm-ar.cpp | 7 ++++++- 2 files changed, 15 insertions(+), 4 deletions(-) diff --git a/test/tools/llvm-ar/mri-delete.test b/test/tools/llvm-ar/mri-delete.test index 82ebc54b66b..bb829ce13c7 100644 --- a/test/tools/llvm-ar/mri-delete.test +++ b/test/tools/llvm-ar/mri-delete.test @@ -1,11 +1,17 @@ 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 "create %t.ar;comment" > %t.mri +RUN: echo "addmod %t.o * comment" >> %t.mri +RUN: echo "; comment" >> %t.mri +RUN: echo " ;comment" >> %t.mri +RUN: echo "* comment" >> %t.mri +RUN: echo " *comment" >> %t.mri +RUN: echo "" >> %t.mri +RUN: echo " " >> %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 " save" >> %t.mri RUN: echo "end" >> %t.mri RUN: llvm-ar -M < %t.mri diff --git a/tools/llvm-ar/llvm-ar.cpp b/tools/llvm-ar/llvm-ar.cpp index 16fee89d89d..1751bad5119 100644 --- a/tools/llvm-ar/llvm-ar.cpp +++ b/tools/llvm-ar/llvm-ar.cpp @@ -789,9 +789,14 @@ static void runMRIScript() { std::vector> ArchiveBuffers; std::vector> Archives; - for (line_iterator I(Ref, /*SkipBlanks*/ true, ';'), E; I != E; ++I) { + for (line_iterator I(Ref, /*SkipBlanks*/ false), E; I != E; ++I) { StringRef Line = *I; StringRef CommandStr, Rest; + Line = Line.split(';').first; + Line = Line.split('*').first; + Line = Line.trim(); + if (Line.empty()) + continue; std::tie(CommandStr, Rest) = Line.split(' '); Rest = Rest.trim(); if (!Rest.empty() && Rest.front() == '"' && Rest.back() == '"')