From: Andrei Dinu Date: Thu, 28 Mar 2013 08:23:19 +0000 (+0200) Subject: packageinfo.bbclass : extended functionality X-Git-Tag: 2015-4~7002 X-Git-Url: https://code.ossystems.io/gitweb?a=commitdiff_plain;h=108bae276fe7e462378073207a3bdca7326f8e57;p=openembedded-core.git packageinfo.bbclass : extended functionality Extended the functionality of packageinfo.bbclass so that the sistem retrieves information about the files brought in by each package. This is done (without activating buildhistory) by parsing the packages-split directory for each package. Signed-off-by: Andrei Dinu Signed-off-by: Richard Purdie --- diff --git a/meta/classes/packageinfo.bbclass b/meta/classes/packageinfo.bbclass index bd7b249bb4..5e6f5901e0 100644 --- a/meta/classes/packageinfo.bbclass +++ b/meta/classes/packageinfo.bbclass @@ -8,6 +8,25 @@ python packageinfo_handler () { 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 + dirs = os.listdir(tmpdir + '/work/') + pkgsplit_dir = tmpdir + '/work/' + items = {} + passing = '' + for directories in dirs: + temp_dirs = os.listdir(pkgsplit_dir + directories) + for temps1 in temp_dirs: + if os.path.exists(pkgsplit_dir + directories + '/' + temps1 + '/' + os.listdir(pkgsplit_dir + directories + '/' + temps1)[0] + '/packages-split'): + subs = pkgsplit_dir + directories + '/' + temps1 + '/' + os.listdir(pkgsplit_dir + directories + '/' + temps1)[0] + '/packages-split' + for temps in os.listdir(subs): + items[temps] = {} + for path, dirs, files in os.walk(pkgsplit_dir + directories + '/' + temps1 + '/' + os.listdir(pkgsplit_dir + directories + '/' + temps1)[0] + '/packages-split' + '/' + temps): + file_list = [] + if os.listdir(path) != []: + items[temps][path] = [] + for f in files: + file_list.append(f) + items[temps][path].append(file_list) + for arch in package_archs.split(): pkgdata_dir = tmpdir + '/pkgdata/' + arch + target_vendor + '-' + target_os + '/runtime/' if os.path.exists(pkgdata_dir): @@ -19,6 +38,8 @@ python packageinfo_handler () { try: sdata = oe.packagedata.read_pkgdatafile(pkgdatafile) sdata['PKG'] = pkgname + if pkgname in items: + sdata['FILES_INFO'] = items[pkgname] pkginfolist.append(sdata) except Exception as e: bb.warn("Failed to read pkgdata file %s: %s: %s" % (pkgdatafile, e.__class__, str(e)))