From 6ce287937e86a43d696e3615aa18d439928b7691 Mon Sep 17 00:00:00 2001 From: Paul Eggleton Date: Fri, 18 Oct 2013 14:52:10 +0100 Subject: scripts/oe-pkgdata-util: add ability to find a recipe from a target package Add a "lookup-recipe" command to show which recipe produced a particular package. (From OE-Core rev: 4ab561ac3df105b4b6487271b6ccc29445518d52) Signed-off-by: Paul Eggleton Signed-off-by: Richard Purdie --- scripts/oe-pkgdata-util | 37 +++++++++++++++++++++++++++++++++++++ 1 file changed, 37 insertions(+) (limited to 'scripts/oe-pkgdata-util') diff --git a/scripts/oe-pkgdata-util b/scripts/oe-pkgdata-util index 08773e9b05..80cacc5b66 100755 --- a/scripts/oe-pkgdata-util +++ b/scripts/oe-pkgdata-util @@ -219,6 +219,38 @@ def lookup_pkg(args, usage): items.extend(mappings.get(pkg, [])) print '\n'.join(items) +def lookup_recipe(args, usage): + if len(args) < 2: + usage() + sys.exit(1) + + pkgdata_dir = args[0] + pkgs = args[1].split() + + if not os.path.exists(pkgdata_dir): + print('ERROR: Unable to find pkgdata directory %s' % pkgdata_dir) + sys.exit(1) + + mappings = defaultdict(list) + for pkg in pkgs: + pkgfile = os.path.join(pkgdata_dir, 'runtime-reverse', pkg) + if os.path.exists(pkgfile): + with open(pkgfile, 'r') as f: + for line in f: + fields = line.rstrip().split(': ') + if fields[0] == 'PN': + mappings[pkg].append(fields[1]) + break + if len(mappings) < len(pkgs): + missing = list(set(pkgs) - set(mappings.keys())) + sys.stderr.write("ERROR: the following packages could not be found: %s\n" % ', '.join(missing)) + sys.exit(1) + + items = [] + for pkg in pkgs: + items.extend(mappings.get(pkg, [])) + print '\n'.join(items) + def find_path(args, usage): if len(args) < 2: usage() @@ -263,6 +295,9 @@ Available commands: lookup-pkg "" look up the specified recipe-space package name(s) to see what the final runtime package name is (e.g. eglibc becomes libc6) + lookup-recipe "" + look up the specified package(s) to see which recipe they were + produced by find-path find the package providing the specified path (wildcards * ? allowed) read-value "" @@ -284,6 +319,8 @@ Available commands: glob(args[1:], parser.print_help) elif args[0] == "lookup-pkg": lookup_pkg(args[1:], parser.print_help) + elif args[0] == "lookup-recipe": + lookup_recipe(args[1:], parser.print_help) elif args[0] == "find-path": find_path(args[1:], parser.print_help) elif args[0] == "read-value": -- cgit v1.2.3-54-g00ecf