| # |
| # Recipe needs to set MULTILIB_SCRIPTS in the form <pkgname>:<scriptname>, e.g. |
| # MULTILIB_SCRIPTS = "${PN}-dev:${bindir}/file1 ${PN}:${base_bindir}/file2" |
| # to indicate which script files to process from which packages. |
| # |
| |
| inherit update-alternatives |
| |
| MULTILIB_SUFFIX = "${@d.getVar('base_libdir',1).split('/')[-1]}" |
| |
| PACKAGE_PREPROCESS_FUNCS += "multilibscript_rename" |
| |
| multilibscript_rename() { |
| : |
| } |
| |
| python () { |
| # Do nothing if multilib isn't being used |
| if not d.getVar("MULTILIB_VARIANTS"): |
| return |
| # Do nothing for native/cross |
| if bb.data.inherits_class('native', d) or bb.data.inherits_class('cross', d): |
| return |
| |
| for entry in (d.getVar("MULTILIB_SCRIPTS", False) or "").split(): |
| pkg, script = entry.split(":") |
| scriptname = os.path.basename(script) |
| d.appendVar("ALTERNATIVE_" + pkg, scriptname + " ") |
| d.setVarFlag("ALTERNATIVE_LINK_NAME", scriptname, script) |
| d.setVarFlag("ALTERNATIVE_TARGET", scriptname, script + "-${MULTILIB_SUFFIX}") |
| d.appendVar("multilibscript_rename", "\n mv ${PKGD}" + script + " ${PKGD}" + script + "-${MULTILIB_SUFFIX}") |
| } |