Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(133)

Unified Diff: pydir/ifatts.py

Issue 659513005: Allow conditional lit tests in Subzero, based on build flags. (Closed) Base URL: https://chromium.googlesource.com/native_client/pnacl-subzero.git@master
Patch Set: Fix issues in patch set 3. Created 6 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: pydir/ifatts.py
diff --git a/pydir/ifatts.py b/pydir/ifatts.py
new file mode 100755
index 0000000000000000000000000000000000000000..1cb0c2b76ae5d5522075af00f4d6bc3e740e2dcb
--- /dev/null
+++ b/pydir/ifatts.py
@@ -0,0 +1,58 @@
+#!/usr/bin/env python2
+
+import argparse
+import os
+import sys
+
+from utils import shellcmd
+
+def GetFileAttributes(Filename):
Jim Stichnoth 2014/10/20 16:44:28 http://google-styleguide.googlecode.com/svn/trunk/
Karl 2014/10/20 21:00:42 Done.
+ """Returns the set of names contained in file named Filename.
+ """
+ if not os.path.isfile(Filename):
+ raise RuntimeError("Can't open: %s" % Filename)
+ with open(Filename, 'r') as f:
+ return f.read().split()
+
+def HasFileAttributes(Filename, Attributes):
+ """Returns true if the set of names in Attributes also appear
Jim Stichnoth 2014/10/20 16:44:28 I thought Jan already mentioned this, but multi-li
Karl 2014/10/20 21:00:42 Done.
Jim Stichnoth 2014/10/21 21:58:41 Not done, please do...
Karl 2014/10/22 17:03:35 Done.
+ in the set of names contained in file named Filename.
+ """
+ return set(Attributes) <= set(GetFileAttributes(Filename))
+
+def main():
+ """Check if the set attributes (i.e. names), contained in FILE,
+ contains the attributes defined by --att=ATTRIBUTE arguments. If
+ so, runs in a shell the command defined by the remaining
+ arguments. Otherwise, quits (generating no output) and returns
+ success.
+ """
jvoung (off chromium) 2014/10/20 17:36:00 could line this """ up too
Karl 2014/10/20 21:00:42 Done.
+ argparser = argparse.ArgumentParser(
+ description=' ' + main.__doc__,
+ formatter_class=argparse.ArgumentDefaultsHelpFormatter)
+ argparser.add_argument('file', metavar='FILE',
+ help='File defining attributes to check against.')
+ argparser.add_argument('--att', required=False, default=[],
+ action='append', metavar='ATTRIBUTE',
+ help='Attribute to check. May be repeated.')
+ argparser.add_argument('--echo-cmd', required=False,
+ action='store_true',
+ help='Trace the command before running.')
+ argparser.add_argument('--command', nargs=argparse.REMAINDER,
+ help='Command to run if attributes found.')
+
+ args = argparser.parse_args()
+
+ # Quit early if no command to run.
+ if not args.command:
+ raise RuntimeError("No command argument(s) specified for ifatts")
+
+ if HasFileAttributes(args.file, args.att):
+ stdout_result = shellcmd(args.command, echo=args.echo_cmd)
+ if not args.echo_cmd:
+ sys.stdout.write(stdout_result)
+
+ return 0
+
+if __name__ == '__main__':
+ main()
jvoung (off chromium) 2014/10/20 17:36:00 This should be "sys.exit(main())", to use main's r
Karl 2014/10/20 21:00:42 Ok. Chose the latter.
jvoung (off chromium) 2014/10/21 19:12:00 Can you upload the new copy?
Karl 2014/10/21 21:14:18 Sorry about that. Apparently, I modified it after

Powered by Google App Engine
This is Rietveld 408576698