boottool: add a common method to build the new kernel cmdline v2

We have two different implementations of the kernel cmdline editor; the
code which implements --args= --remove-args=.  One of these implement
addition as replace where the argument already exists, the other does not.

From the code it appears that they are really intended to work on
independant keyword=value sets, and a single one at a time.  However,
this means that to remove the current args and add a set of new ones
you may have to perform a large number of removes followed by adds,
each rewriting the config.

This patch pulls out this processing to _build_args on the base class.
This new implementation treats the arguments to --args= and --remove-args=
as multiple keyword=value pairs and applies all of them, removes first
then additions.

Signed-off-by: Andy Whitcroft <apw@shadowen.org>


git-svn-id: http://test.kernel.org/svn/autotest/trunk@779 592f7852-d20e-0410-864c-8624ca9c26a4
diff --git a/client/tools/boottool b/client/tools/boottool
index 077b941..bab6a5c 100755
--- a/client/tools/boottool
+++ b/client/tools/boottool
@@ -447,8 +447,7 @@
         my $append = $1;
         my $args = $2;
         $args =~ s/\"|\'//g;
-        $args =~ s/\s*$params{'remove-args'}\=*\S*//ig if defined $params{'remove-args'};
-        $args = $args . " ". $params{'args'} if defined $params{'args'};
+	$args = $self->_build_args($args, $params{'remove-args'}, $params{'args'});
         if ($_ eq "$append\"$args\"\n") {
           warn "WARNING:  No change made to args.\n";
           return undef;
@@ -643,6 +642,31 @@
   return undef;
 }
 
+sub _build_args {
+  my ($self, $args, $toremove, $toadd) = @_;
+
+  if (defined $toremove) {
+    my $base;
+    foreach my $remove (split(' ', $toremove)) {
+      $base = $remove; $base =~ s/\=.*//;
+      $args =~ s/(^|\s+)$base(\=\S+|\s+|$)/$1/ig;
+    }
+  }
+
+  if (defined $toadd) {
+    my $base;
+    foreach my $add (split(' ', $toadd)) {
+      $base = $add; $base =~ s/\=.*//;
+      if (!($args =~ s/(^|\s+)$base(\=\S+)?(\s+|$)/$1$add$3/ig)) {
+        $args .= " $add";
+      }
+    }
+  }
+
+  $args =~ s/\s+/ /g;
+  return $args;
+}
+
 
 =head1 AUTHOR
 
@@ -1452,14 +1476,7 @@
       if (defined $params{'args'} or defined $params{'remove-args'}){
         if ( $line =~ /$kregex/i ) {
           my $kernel = $1;
-          my $args = $2;
-          $args =~ s/\s+$params{'remove-args'}(\=\S+|\s+|$)/ /ig if defined $params{'remove-args'};
-          if ( defined $params{'args'} ) {
-              my $base_arg = $params{'args'};
-              $base_arg =~ s/\=.*//;
-              $args =~ s/\s+$base_arg(\=\S+|\s+|$)/ /ig;
-              $args = $args . " " . $params{'args'};
-          }
+          my $args = $self->_build_args($2, $params{'remove-args'}, $params{'args'});
           if ($line eq $kernel . $args . "\n") {
             warn "WARNING:  No change made to args.\n";
             return undef;