diff options
| author | Paul Eggleton <paul.eggleton@linux.intel.com> | 2015-10-11 19:27:44 +0100 |
|---|---|---|
| committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2015-12-01 21:32:04 +0000 |
| commit | 74505b42956e6dec31436f56db13c1dfc2d8892a (patch) | |
| tree | c2ca65d546f737251eff4cb9d32f5b047e4d28fd /scripts/lib | |
| parent | 3f46af2b1923cbfd3af0b8ce3c360eb34f316dfc (diff) | |
| download | poky-74505b42956e6dec31436f56db13c1dfc2d8892a.tar.gz | |
devtool: search: print SUMMARY value
Print the SUMMARY value for each matched item assuming it's not the
default.
(From OE-Core rev: 596dee8882ebddb45a6cce9f12aa919107106156)
Signed-off-by: Paul Eggleton <paul.eggleton@linux.intel.com>
Signed-off-by: Ross Burton <ross.burton@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'scripts/lib')
| -rw-r--r-- | scripts/lib/devtool/search.py | 77 |
1 files changed, 42 insertions, 35 deletions
diff --git a/scripts/lib/devtool/search.py b/scripts/lib/devtool/search.py index 1c8eaff49b..2ea446237e 100644 --- a/scripts/lib/devtool/search.py +++ b/scripts/lib/devtool/search.py | |||
| @@ -22,53 +22,60 @@ import bb | |||
| 22 | import logging | 22 | import logging |
| 23 | import argparse | 23 | import argparse |
| 24 | import re | 24 | import re |
| 25 | from devtool import setup_tinfoil, DevtoolError | 25 | from devtool import setup_tinfoil, parse_recipe, DevtoolError |
| 26 | 26 | ||
| 27 | logger = logging.getLogger('devtool') | 27 | logger = logging.getLogger('devtool') |
| 28 | 28 | ||
| 29 | def search(args, config, basepath, workspace): | 29 | def search(args, config, basepath, workspace): |
| 30 | """Entry point for the devtool 'search' subcommand""" | 30 | """Entry point for the devtool 'search' subcommand""" |
| 31 | 31 | ||
| 32 | tinfoil = setup_tinfoil(config_only=True, basepath=basepath) | 32 | tinfoil = setup_tinfoil(config_only=False, basepath=basepath) |
| 33 | pkgdata_dir = tinfoil.config_data.getVar('PKGDATA_DIR', True) | 33 | try: |
| 34 | tinfoil.shutdown() | 34 | pkgdata_dir = tinfoil.config_data.getVar('PKGDATA_DIR', True) |
| 35 | defsummary = tinfoil.config_data.getVar('SUMMARY', False) or '' | ||
| 35 | 36 | ||
| 36 | keyword_rc = re.compile(args.keyword) | 37 | keyword_rc = re.compile(args.keyword) |
| 37 | 38 | ||
| 38 | for fn in os.listdir(pkgdata_dir): | 39 | for fn in os.listdir(pkgdata_dir): |
| 39 | pfn = os.path.join(pkgdata_dir, fn) | 40 | pfn = os.path.join(pkgdata_dir, fn) |
| 40 | if not os.path.isfile(pfn): | 41 | if not os.path.isfile(pfn): |
| 41 | continue | 42 | continue |
| 42 | 43 | ||
| 43 | packages = [] | 44 | packages = [] |
| 44 | match = False | 45 | match = False |
| 45 | if keyword_rc.search(fn): | 46 | if keyword_rc.search(fn): |
| 46 | match = True | 47 | match = True |
| 47 | 48 | ||
| 48 | if not match: | 49 | if not match: |
| 49 | with open(pfn, 'r') as f: | 50 | with open(pfn, 'r') as f: |
| 50 | for line in f: | 51 | for line in f: |
| 51 | if line.startswith('PACKAGES:'): | 52 | if line.startswith('PACKAGES:'): |
| 52 | packages = line.split(':', 1)[1].strip().split() | 53 | packages = line.split(':', 1)[1].strip().split() |
| 53 | 54 | ||
| 54 | for pkg in packages: | 55 | for pkg in packages: |
| 55 | if keyword_rc.search(pkg): | 56 | if keyword_rc.search(pkg): |
| 56 | match = True | 57 | match = True |
| 57 | break | 58 | break |
| 58 | if os.path.exists(os.path.join(pkgdata_dir, 'runtime', pkg + '.packaged')): | 59 | if os.path.exists(os.path.join(pkgdata_dir, 'runtime', pkg + '.packaged')): |
| 59 | with open(os.path.join(pkgdata_dir, 'runtime', pkg), 'r') as f: | 60 | with open(os.path.join(pkgdata_dir, 'runtime', pkg), 'r') as f: |
| 60 | for line in f: | 61 | for line in f: |
| 61 | if ': ' in line: | 62 | if ': ' in line: |
| 62 | splitline = line.split(':', 1) | 63 | splitline = line.split(':', 1) |
| 63 | key = splitline[0] | 64 | key = splitline[0] |
| 64 | value = splitline[1].strip() | 65 | value = splitline[1].strip() |
| 65 | if key in ['PKG_%s' % pkg, 'DESCRIPTION', 'FILES_INFO'] or key.startswith('FILERPROVIDES_'): | 66 | if key in ['PKG_%s' % pkg, 'DESCRIPTION', 'FILES_INFO'] or key.startswith('FILERPROVIDES_'): |
| 66 | if keyword_rc.search(value): | 67 | if keyword_rc.search(value): |
| 67 | match = True | 68 | match = True |
| 68 | break | 69 | break |
| 69 | 70 | ||
| 70 | if match: | 71 | if match: |
| 71 | print(fn) | 72 | rd = parse_recipe(config, tinfoil, fn, True) |
| 73 | summary = rd.getVar('SUMMARY', True) | ||
| 74 | if summary == rd.expand(defsummary): | ||
| 75 | summary = '' | ||
| 76 | print("%s %s" % (fn.ljust(20), summary)) | ||
| 77 | finally: | ||
| 78 | tinfoil.shutdown() | ||
| 72 | 79 | ||
| 73 | return 0 | 80 | return 0 |
| 74 | 81 | ||
