From a8864fba9fd21f412cd0e2c6e072deeb204049bb Mon Sep 17 00:00:00 2001 From: Zhiguang Li Date: Fri, 15 Mar 2013 10:32:10 +0800 Subject: Add regex support for subcommand forall Filter the project list based on regex or wildcard matching of strings, then we can handle subset of all projects. Change-Id: Ib6c23aec79e7d981f7b6a5eb0ae93c44effec467 Signed-off-by: Zhiguang Li --- subcmds/forall.py | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) (limited to 'subcmds/forall.py') diff --git a/subcmds/forall.py b/subcmds/forall.py index 4c1c9ff8..7d5f7794 100644 --- a/subcmds/forall.py +++ b/subcmds/forall.py @@ -42,10 +42,14 @@ class Forall(Command, MirrorSafeCommand): helpSummary = "Run a shell command in each project" helpUsage = """ %prog [...] -c [...] +%prog -r str1 [str2] ... -c [...]" """ helpDescription = """ Executes the same shell command in each project. +The -r option allows running the command only on projects matching +regex or wildcard expression. + Output Formatting ----------------- @@ -103,6 +107,9 @@ without iterating through the remaining projects. setattr(parser.values, option.dest, list(parser.rargs)) while parser.rargs: del parser.rargs[0] + p.add_option('-r', '--regex', + dest='regex', action='store_true', + help="Execute the command only on projects matching regex or wildcard expression") p.add_option('-c', '--command', help='Command (and arguments) to execute', dest='command', @@ -166,7 +173,12 @@ without iterating through the remaining projects. rc = 0 first = True - for project in self.GetProjects(args): + if not opt.regex: + projects = self.GetProjects(args) + else: + projects = self.FindProjects(args) + + for project in projects: env = os.environ.copy() def setenv(name, val): if val is None: -- cgit v1.2.3-54-g00ecf