blob: 41597341cd1c41ec6ec92f79e1f45842b990f2c4 [file] [log] [blame]
Brad Bishop1a4b7ee2018-12-16 17:11:34 -08001#
2# Recipe needs to set MULTILIB_SCRIPTS in the form <pkgname>:<scriptname>, e.g.
3# MULTILIB_SCRIPTS = "${PN}-dev:${bindir}/file1 ${PN}:${base_bindir}/file2"
4# to indicate which script files to process from which packages.
5#
6
7inherit update-alternatives
8
9MULTILIB_SUFFIX = "${@d.getVar('base_libdir',1).split('/')[-1]}"
10
11PACKAGE_PREPROCESS_FUNCS += "multilibscript_rename"
12
13multilibscript_rename() {
14 :
15}
16
17python () {
18 # Do nothing if multilib isn't being used
19 if not d.getVar("MULTILIB_VARIANTS"):
Brad Bishop96ff1982019-08-19 13:50:42 -040020 return
Brad Bishop1a4b7ee2018-12-16 17:11:34 -080021 # Do nothing for native/cross
22 if bb.data.inherits_class('native', d) or bb.data.inherits_class('cross', d):
Brad Bishop96ff1982019-08-19 13:50:42 -040023 return
Brad Bishop1a4b7ee2018-12-16 17:11:34 -080024
25 for entry in (d.getVar("MULTILIB_SCRIPTS", False) or "").split():
Brad Bishop96ff1982019-08-19 13:50:42 -040026 pkg, script = entry.split(":")
27 epkg = d.expand(pkg)
28 scriptname = os.path.basename(script)
Patrick Williams213cb262021-08-07 19:21:33 -050029 d.appendVar("ALTERNATIVE:" + epkg, " " + scriptname + " ")
Brad Bishop96ff1982019-08-19 13:50:42 -040030 d.setVarFlag("ALTERNATIVE_LINK_NAME", scriptname, script)
31 d.setVarFlag("ALTERNATIVE_TARGET", scriptname, script + "-${MULTILIB_SUFFIX}")
32 d.appendVar("multilibscript_rename", "\n mv ${PKGD}" + script + " ${PKGD}" + script + "-${MULTILIB_SUFFIX}")
Patrick Williams213cb262021-08-07 19:21:33 -050033 d.appendVar("FILES:" + epkg, " " + script + "-${MULTILIB_SUFFIX}")
Brad Bishop1a4b7ee2018-12-16 17:11:34 -080034}