summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--meta/classes/packageinfo.bbclass35
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 @@
1python 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
35addhandler packageinfo_handler