diff options
author | Dongxiao Xu <dongxiao.xu@intel.com> | 2012-02-23 21:48:07 +0800 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2012-02-24 00:39:09 +0000 |
commit | 99c805a168953e9d9a1968fee15c590dd46bfd60 (patch) | |
tree | 14a33800c6cd360c84ba805b205f5a0b2d3525eb /meta/classes/packageinfo.bbclass | |
parent | 9531161d40cd50c69e1ae390f073fba61aaa26f9 (diff) | |
download | poky-99c805a168953e9d9a1968fee15c590dd46bfd60.tar.gz |
packageinfo.bbclass: add a new bbclass to pass package information
packageinfo.bbclass is to pass the accurate package information to
clients (e.g. Hob), including PN, PV, RDEPENDS, PKGSIZE, etc.
(From OE-Core rev: 1a0be9ec4d53cfcaea907edebe5d8bb525496b4e)
Signed-off-by: Dongxiao Xu <dongxiao.xu@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/classes/packageinfo.bbclass')
-rw-r--r-- | meta/classes/packageinfo.bbclass | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/meta/classes/packageinfo.bbclass b/meta/classes/packageinfo.bbclass new file mode 100644 index 0000000000..46b9097a54 --- /dev/null +++ b/meta/classes/packageinfo.bbclass | |||
@@ -0,0 +1,35 @@ | |||
1 | python packageinfo_handler () { | ||
2 | if isinstance(e, bb.event.RequestPackageInfo): | ||
3 | import oe.packagedata | ||
4 | pkginfolist = [] | ||
5 | tmpdir = e.data.getVar('TMPDIR', True) | ||
6 | target_vendor = e.data.getVar('TARGET_VENDOR', True) | ||
7 | target_os = e.data.getVar('TARGET_OS', True) | ||
8 | package_archs = e.data.getVar('PACKAGE_ARCHS', True) | ||
9 | packaging = e.data.getVar('PACKAGE_CLASSES', True).split()[0].split('_')[1] | ||
10 | deploy_dir = e.data.getVar('DEPLOY_DIR', True) + '/' + packaging | ||
11 | for arch in package_archs.split(): | ||
12 | pkgdata_dir = tmpdir + '/pkgdata/' + arch + target_vendor + '-' + target_os + '/runtime/' | ||
13 | if os.path.exists(pkgdata_dir): | ||
14 | for root, dirs, files in os.walk(pkgdata_dir): | ||
15 | for pkgname in files: | ||
16 | if pkgname.endswith('.packaged'): | ||
17 | continue | ||
18 | sdata = oe.packagedata.read_pkgdatafile(root + pkgname) | ||
19 | sdata['PKG'] = pkgname | ||
20 | pkgrename = sdata['PKG_%s' % pkgname] | ||
21 | pkgv = sdata['PKGV'].replace('-', '+') | ||
22 | pkgr = sdata['PKGR'] | ||
23 | if os.path.exists(deploy_dir + '/' + arch + '/' + \ | ||
24 | pkgname + '-' + pkgv + '-' + pkgr + '.' + arch + '.' + packaging) or \ | ||
25 | os.path.exists(deploy_dir + '/' + arch + '/' + \ | ||
26 | pkgrename + '-' + pkgv + '-' + pkgr + '.' + arch + '.' + packaging) or \ | ||
27 | os.path.exists(deploy_dir + '/' + arch + '/' + \ | ||
28 | pkgname + '_' + pkgv + '-' + pkgr + '_' + arch + '.' + packaging) or \ | ||
29 | os.path.exists(deploy_dir + '/' + arch + '/' + \ | ||
30 | pkgrename + '_' + pkgv + '-' + pkgr + '_' + arch + '.' + packaging): | ||
31 | pkginfolist.append(sdata) | ||
32 | bb.event.fire(bb.event.PackageInfo(pkginfolist), e.data) | ||
33 | } | ||
34 | |||
35 | addhandler packageinfo_handler | ||