blob: 1756f342ce3b0a173e59fed25ecbdd3fcc5d4c90 [file] [log] [blame]
Brad Bishop19323692019-04-05 15:28:33 -04001include meson.inc
2
3inherit nativesdk
4inherit siteinfo
5
6SRC_URI += "file://meson-setup.py \
7 file://meson-wrapper"
8
9def meson_endian(prefix, d):
10 arch, os = d.getVar(prefix + "_ARCH"), d.getVar(prefix + "_OS")
11 sitedata = siteinfo_data_for_machine(arch, os, d)
12 if "endian-little" in sitedata:
13 return "little"
14 elif "endian-big" in sitedata:
15 return "big"
16 else:
17 bb.fatal("Cannot determine endianism for %s-%s" % (arch, os))
18
Brad Bishop19323692019-04-05 15:28:33 -040019# The cross file logic is similar but not identical to that in meson.bbclass,
20# since it's generating for an SDK rather than a cross-compile. Important
21# differences are:
22# - We can't set vars like CC, CXX, etc. yet because they will be filled in with
23# real paths by meson-setup.sh when the SDK is extracted.
24# - Some overrides aren't needed, since the SDK injects paths that take care of
25# them.
26do_install_append() {
27 install -d ${D}${datadir}/meson
28 cat >${D}${datadir}/meson/meson.cross.template <<EOF
29[binaries]
30c = @CC
31cpp = @CXX
32ar = @AR
33nm = @NM
34ld = @LD
35strip = @STRIP
36pkgconfig = 'pkg-config'
37
38[properties]
39needs_exe_wrapper = true
40c_args = @CFLAGS
41c_link_args = @LDFLAGS
42cpp_args = @CPPFLAGS
43cpp_link_args = @LDFLAGS
44
45[host_machine]
46system = '${SDK_OS}'
47cpu_family = '${SDK_ARCH}'
48cpu = '${SDK_ARCH}'
49endian = '${@meson_endian("SDK", d)}'
50EOF
51
52 install -d ${D}${SDKPATHNATIVE}/post-relocate-setup.d
53 install -m 0755 ${WORKDIR}/meson-setup.py ${D}${SDKPATHNATIVE}/post-relocate-setup.d/
54
55 # We need to wrap the real meson with a thin env setup wrapper.
56 mv ${D}${bindir}/meson ${D}${bindir}/meson.real
57 install -m 0755 ${WORKDIR}/meson-wrapper ${D}${bindir}/meson
58}
59
60RDEPENDS_${PN} += "\
61 nativesdk-ninja \
62 nativesdk-python3 \
63 nativesdk-python3-setuptools \
64 "
65
66FILES_${PN} += "${datadir}/meson ${SDKPATHNATIVE}"