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 | ||
