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:38:35 +0000 |
commit | 1a0be9ec4d53cfcaea907edebe5d8bb525496b4e (patch) | |
tree | c447bdaaa876e672dae78b8a2c006859ac097f66 /meta/classes/packageinfo.bbclass | |
parent | 9c446d007957dab36ee2c012f0a5b22494a7a84f (diff) | |
download | openembedded-core-1a0be9ec4d53cfcaea907edebe5d8bb525496b4e.tar.gz openembedded-core-1a0be9ec4d53cfcaea907edebe5d8bb525496b4e.tar.bz2 openembedded-core-1a0be9ec4d53cfcaea907edebe5d8bb525496b4e.tar.xz openembedded-core-1a0be9ec4d53cfcaea907edebe5d8bb525496b4e.zip |
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.
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 000000000..46b9097a5 --- /dev/null +++ b/meta/classes/packageinfo.bbclass @@ -0,0 +1,35 @@ +python packageinfo_handler () { + if isinstance(e, bb.event.RequestPackageInfo): + import oe.packagedata + pkginfolist = [] + tmpdir = e.data.getVar('TMPDIR', True) + target_vendor = e.data.getVar('TARGET_VENDOR', True) + target_os = e.data.getVar('TARGET_OS', True) + package_archs = e.data.getVar('PACKAGE_ARCHS', True) + packaging = e.data.getVar('PACKAGE_CLASSES', True).split()[0].split('_')[1] + deploy_dir = e.data.getVar('DEPLOY_DIR', True) + '/' + packaging + for arch in package_archs.split(): + pkgdata_dir = tmpdir + '/pkgdata/' + arch + target_vendor + '-' + target_os + '/runtime/' + if os.path.exists(pkgdata_dir): + for root, dirs, files in os.walk(pkgdata_dir): + for pkgname in files: + if pkgname.endswith('.packaged'): + continue + sdata = oe.packagedata.read_pkgdatafile(root + pkgname) + sdata['PKG'] = pkgname + pkgrename = sdata['PKG_%s' % pkgname] + pkgv = sdata['PKGV'].replace('-', '+') + pkgr = sdata['PKGR'] + if os.path.exists(deploy_dir + '/' + arch + '/' + \ + pkgname + '-' + pkgv + '-' + pkgr + '.' + arch + '.' + packaging) or \ + os.path.exists(deploy_dir + '/' + arch + '/' + \ + pkgrename + '-' + pkgv + '-' + pkgr + '.' + arch + '.' + packaging) or \ + os.path.exists(deploy_dir + '/' + arch + '/' + \ + pkgname + '_' + pkgv + '-' + pkgr + '_' + arch + '.' + packaging) or \ + os.path.exists(deploy_dir + '/' + arch + '/' + \ + pkgrename + '_' + pkgv + '-' + pkgr + '_' + arch + '.' + packaging): + pkginfolist.append(sdata) + bb.event.fire(bb.event.PackageInfo(pkginfolist), e.data) +} + +addhandler packageinfo_handler |