mirror of
https://git.yoctoproject.org/poky
synced 2026-01-29 21:08:42 +01:00
image-buildinfo.bbclass: new class, writes build information to image
Writes build information to target filesystem on /etc/build such as enabled layers, their current status and commit. squashspaces was moved to oe/utils.py to make it available to different classes and avoid code duplication. [YOCTO #6770] (From OE-Core rev: c9cc652e88ddedddf8a2f23fb9b8c024616526d7) Signed-off-by: Alejandro Hernandez <alejandro.hernandez@linux.intel.com> Signed-off-by: Ross Burton <ross.burton@intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
committed by
Richard Purdie
parent
c58237560d
commit
ed3e25379c
@@ -155,7 +155,7 @@ python buildhistory_emit_pkghistory() {
|
||||
with open(os.path.join(pkgdata_dir, pn)) as f:
|
||||
for line in f.readlines():
|
||||
if line.startswith('PACKAGES: '):
|
||||
packages = squashspaces(line.split(': ', 1)[1])
|
||||
packages = oe.utils.squashspaces(line.split(': ', 1)[1])
|
||||
break
|
||||
except IOError as e:
|
||||
if e.errno == errno.ENOENT:
|
||||
@@ -181,7 +181,7 @@ python buildhistory_emit_pkghistory() {
|
||||
rcpinfo.pe = pe
|
||||
rcpinfo.pv = pv
|
||||
rcpinfo.pr = pr
|
||||
rcpinfo.depends = sortlist(squashspaces(d.getVar('DEPENDS', True) or ""))
|
||||
rcpinfo.depends = sortlist(oe.utils.squashspaces(d.getVar('DEPENDS', True) or ""))
|
||||
rcpinfo.packages = packages
|
||||
write_recipehistory(rcpinfo, d)
|
||||
|
||||
@@ -222,13 +222,13 @@ python buildhistory_emit_pkghistory() {
|
||||
pkginfo.pkge = pkge
|
||||
pkginfo.pkgv = pkgv
|
||||
pkginfo.pkgr = pkgr
|
||||
pkginfo.rprovides = sortpkglist(squashspaces(pkgdata.get('RPROVIDES', "")))
|
||||
pkginfo.rdepends = sortpkglist(squashspaces(pkgdata.get('RDEPENDS', "")))
|
||||
pkginfo.rrecommends = sortpkglist(squashspaces(pkgdata.get('RRECOMMENDS', "")))
|
||||
pkginfo.rsuggests = sortpkglist(squashspaces(pkgdata.get('RSUGGESTS', "")))
|
||||
pkginfo.rreplaces = sortpkglist(squashspaces(pkgdata.get('RREPLACES', "")))
|
||||
pkginfo.rconflicts = sortpkglist(squashspaces(pkgdata.get('RCONFLICTS', "")))
|
||||
pkginfo.files = squashspaces(pkgdata.get('FILES', ""))
|
||||
pkginfo.rprovides = sortpkglist(oe.utils.squashspaces(pkgdata.get('RPROVIDES', "")))
|
||||
pkginfo.rdepends = sortpkglist(oe.utils.squashspaces(pkgdata.get('RDEPENDS', "")))
|
||||
pkginfo.rrecommends = sortpkglist(oe.utils.squashspaces(pkgdata.get('RRECOMMENDS', "")))
|
||||
pkginfo.rsuggests = sortpkglist(oe.utils.squashspaces(pkgdata.get('RSUGGESTS', "")))
|
||||
pkginfo.rreplaces = sortpkglist(oe.utils.squashspaces(pkgdata.get('RREPLACES', "")))
|
||||
pkginfo.rconflicts = sortpkglist(oe.utils.squashspaces(pkgdata.get('RCONFLICTS', "")))
|
||||
pkginfo.files = oe.utils.squashspaces(pkgdata.get('FILES', ""))
|
||||
for filevar in pkginfo.filevars:
|
||||
pkginfo.filevars[filevar] = pkgdata.get(filevar, "")
|
||||
|
||||
@@ -525,11 +525,6 @@ def buildhistory_get_metadata_revs(d):
|
||||
for i in layers]
|
||||
return '\n'.join(medadata_revs)
|
||||
|
||||
|
||||
def squashspaces(string):
|
||||
import re
|
||||
return re.sub("\s+", " ", string).strip()
|
||||
|
||||
def outputvars(vars, listvars, d):
|
||||
vars = vars.split()
|
||||
listvars = listvars.split()
|
||||
@@ -538,7 +533,7 @@ def outputvars(vars, listvars, d):
|
||||
value = d.getVar(var, True) or ""
|
||||
if var in listvars:
|
||||
# Squash out spaces
|
||||
value = squashspaces(value)
|
||||
value = oe.utils.squashspaces(value)
|
||||
ret += "%s = %s\n" % (var, value)
|
||||
return ret.rstrip('\n')
|
||||
|
||||
|
||||
69
meta/classes/image-buildinfo.bbclass
Normal file
69
meta/classes/image-buildinfo.bbclass
Normal file
@@ -0,0 +1,69 @@
|
||||
#
|
||||
# Writes build information to target filesystem on /etc/build
|
||||
#
|
||||
# Copyright (C) 2014 Intel Corporation
|
||||
# Author: Alejandro Enedino Hernandez Samaniego <alejandro.hernandez@intel.com>
|
||||
#
|
||||
# Licensed under the MIT license, see COPYING.MIT for details
|
||||
#
|
||||
# Usage: add INHERIT += "image-buildinfo" to your conf file
|
||||
#
|
||||
|
||||
# Desired variables to display
|
||||
IMAGE_BUILDINFO_VARS ?= "DISTRO DISTRO_VERSION"
|
||||
|
||||
# From buildhistory.bbclass
|
||||
def image_buildinfo_outputvars(vars, listvars, d):
|
||||
vars = vars.split()
|
||||
listvars = listvars.split()
|
||||
ret = ""
|
||||
for var in vars:
|
||||
value = d.getVar(var, True) or ""
|
||||
if (d.getVarFlag(var, 'type') == "list"):
|
||||
value = oe.utils.squashspaces(value)
|
||||
ret += "%s = %s\n" % (var, value)
|
||||
return ret.rstrip('\n')
|
||||
|
||||
# Gets git branch's status (clean or dirty)
|
||||
def get_layer_git_status(path):
|
||||
f = os.popen("cd %s; git diff --stat 2>&1 | tail -n 1" % path)
|
||||
data = f.read()
|
||||
if f.close() is None:
|
||||
if len(data) != 0:
|
||||
return "-- modified"
|
||||
return ""
|
||||
|
||||
# Returns layer revisions along with their respective status
|
||||
def get_layer_revs(d):
|
||||
layers = (d.getVar("BBLAYERS", True) or "").split()
|
||||
medadata_revs = ["%-17s = %s:%s %s" % (os.path.basename(i), \
|
||||
base_get_metadata_git_branch(i, None).strip(), \
|
||||
base_get_metadata_git_revision(i, None), \
|
||||
get_layer_git_status(i)) \
|
||||
for i in layers]
|
||||
return '\n'.join(medadata_revs)
|
||||
|
||||
def buildinfo_target(d):
|
||||
# Get context
|
||||
if d.getVar('BB_WORKERCONTEXT', True) != '1':
|
||||
return ""
|
||||
# Single and list variables to be read
|
||||
vars = (d.getVar("IMAGE_BUILDINFO_VARS", True) or "")
|
||||
listvars = (d.getVar("IMAGE_BUILDINFO_LVARS", True) or "")
|
||||
return image_buildinfo_outputvars(vars, listvars, d)
|
||||
|
||||
# Write build information to target filesystem
|
||||
buildinfo () {
|
||||
cat > ${IMAGE_ROOTFS}${sysconfdir}/build << END
|
||||
-----------------------
|
||||
Build Configuration: |
|
||||
-----------------------
|
||||
${@buildinfo_target(d)}
|
||||
-----------------------
|
||||
Layer Revisions: |
|
||||
-----------------------
|
||||
${@get_layer_revs(d)}
|
||||
END
|
||||
}
|
||||
|
||||
IMAGE_PREPROCESS_COMMAND += "buildinfo;"
|
||||
@@ -180,3 +180,7 @@ def multiprocess_exec(commands, function):
|
||||
pool.terminate()
|
||||
pool.join()
|
||||
raise
|
||||
|
||||
def squashspaces(string):
|
||||
import re
|
||||
return re.sub("\s+", " ", string).strip()
|
||||
|
||||
Reference in New Issue
Block a user