# We want native packages to be relocatable 
 | 
inherit relocatable 
 | 
  
 | 
# Native packages are built indirectly via dependency, 
 | 
# no need for them to be a direct target of 'world' 
 | 
EXCLUDE_FROM_WORLD = "1" 
 | 
  
 | 
PACKAGE_ARCH = "${BUILD_ARCH}" 
 | 
  
 | 
# used by cmake class 
 | 
OECMAKE_RPATH = "${libdir}" 
 | 
OECMAKE_RPATH:class-native = "${libdir}" 
 | 
  
 | 
TARGET_ARCH = "${BUILD_ARCH}" 
 | 
TARGET_OS = "${BUILD_OS}" 
 | 
TARGET_VENDOR = "${BUILD_VENDOR}" 
 | 
TARGET_PREFIX = "${BUILD_PREFIX}" 
 | 
TARGET_CC_ARCH = "${BUILD_CC_ARCH}" 
 | 
TARGET_LD_ARCH = "${BUILD_LD_ARCH}" 
 | 
TARGET_AS_ARCH = "${BUILD_AS_ARCH}" 
 | 
TARGET_CPPFLAGS = "${BUILD_CPPFLAGS}" 
 | 
TARGET_CFLAGS = "${BUILD_CFLAGS}" 
 | 
TARGET_CXXFLAGS = "${BUILD_CXXFLAGS}" 
 | 
TARGET_LDFLAGS = "${BUILD_LDFLAGS}" 
 | 
TARGET_FPU = "" 
 | 
  
 | 
HOST_ARCH = "${BUILD_ARCH}" 
 | 
HOST_OS = "${BUILD_OS}" 
 | 
HOST_VENDOR = "${BUILD_VENDOR}" 
 | 
HOST_PREFIX = "${BUILD_PREFIX}" 
 | 
HOST_CC_ARCH = "${BUILD_CC_ARCH}" 
 | 
HOST_LD_ARCH = "${BUILD_LD_ARCH}" 
 | 
HOST_AS_ARCH = "${BUILD_AS_ARCH}" 
 | 
  
 | 
CPPFLAGS = "${BUILD_CPPFLAGS}" 
 | 
CFLAGS = "${BUILD_CFLAGS}" 
 | 
CXXFLAGS = "${BUILD_CXXFLAGS}" 
 | 
LDFLAGS = "${BUILD_LDFLAGS}" 
 | 
  
 | 
STAGING_BINDIR = "${STAGING_BINDIR_NATIVE}" 
 | 
STAGING_BINDIR_CROSS = "${STAGING_BINDIR_NATIVE}" 
 | 
  
 | 
# native pkg doesn't need the TOOLCHAIN_OPTIONS. 
 | 
TOOLCHAIN_OPTIONS = "" 
 | 
  
 | 
# Don't build ptest natively 
 | 
PTEST_ENABLED = "0" 
 | 
  
 | 
# Don't use site files for native builds 
 | 
export CONFIG_SITE = "${COREBASE}/meta/site/native" 
 | 
  
 | 
# set the compiler as well. It could have been set to something else 
 | 
export CC = "${BUILD_CC}" 
 | 
export CXX = "${BUILD_CXX}" 
 | 
export FC = "${BUILD_FC}" 
 | 
export CPP = "${BUILD_CPP}" 
 | 
export LD = "${BUILD_LD}" 
 | 
export CCLD = "${BUILD_CCLD}" 
 | 
export AR = "${BUILD_AR}" 
 | 
export AS = "${BUILD_AS}" 
 | 
export RANLIB = "${BUILD_RANLIB}" 
 | 
export STRIP = "${BUILD_STRIP}" 
 | 
export NM = "${BUILD_NM}" 
 | 
  
 | 
# Path prefixes 
 | 
base_prefix = "${STAGING_DIR_NATIVE}" 
 | 
prefix = "${STAGING_DIR_NATIVE}${prefix_native}" 
 | 
exec_prefix = "${STAGING_DIR_NATIVE}${prefix_native}" 
 | 
  
 | 
bindir = "${STAGING_BINDIR_NATIVE}" 
 | 
sbindir = "${STAGING_SBINDIR_NATIVE}" 
 | 
base_libdir = "${STAGING_LIBDIR_NATIVE}" 
 | 
libdir = "${STAGING_LIBDIR_NATIVE}" 
 | 
includedir = "${STAGING_INCDIR_NATIVE}" 
 | 
sysconfdir = "${STAGING_ETCDIR_NATIVE}" 
 | 
datadir = "${STAGING_DATADIR_NATIVE}" 
 | 
  
 | 
baselib = "lib" 
 | 
  
 | 
export lt_cv_sys_lib_dlsearch_path_spec = "${libdir} ${base_libdir} /lib /lib64 /usr/lib /usr/lib64" 
 | 
  
 | 
NATIVE_PACKAGE_PATH_SUFFIX ?= "" 
 | 
bindir .= "${NATIVE_PACKAGE_PATH_SUFFIX}" 
 | 
sbindir .= "${NATIVE_PACKAGE_PATH_SUFFIX}" 
 | 
base_libdir .= "${NATIVE_PACKAGE_PATH_SUFFIX}" 
 | 
libdir .= "${NATIVE_PACKAGE_PATH_SUFFIX}" 
 | 
libexecdir .= "${NATIVE_PACKAGE_PATH_SUFFIX}" 
 | 
  
 | 
do_populate_sysroot[sstate-inputdirs] = "${SYSROOT_DESTDIR}/${STAGING_DIR_NATIVE}/" 
 | 
do_populate_sysroot[sstate-outputdirs] = "${COMPONENTS_DIR}/${PACKAGE_ARCH}/${PN}" 
 | 
  
 | 
# Since we actually install these into situ there is no staging prefix 
 | 
STAGING_DIR_HOST = "" 
 | 
STAGING_DIR_TARGET = "" 
 | 
PKG_CONFIG_DIR = "${libdir}/pkgconfig" 
 | 
  
 | 
EXTRA_NATIVE_PKGCONFIG_PATH ?= "" 
 | 
PKG_CONFIG_PATH .= "${EXTRA_NATIVE_PKGCONFIG_PATH}" 
 | 
PKG_CONFIG_SYSROOT_DIR = "" 
 | 
PKG_CONFIG_SYSTEM_LIBRARY_PATH[unexport] = "1" 
 | 
PKG_CONFIG_SYSTEM_INCLUDE_PATH[unexport] = "1" 
 | 
  
 | 
# we dont want libc-*libc to kick in for native recipes 
 | 
LIBCOVERRIDE = "" 
 | 
CLASSOVERRIDE = "class-native" 
 | 
MACHINEOVERRIDES = "" 
 | 
MACHINE_FEATURES = "" 
 | 
  
 | 
PATH:prepend = "${COREBASE}/scripts/native-intercept:" 
 | 
  
 | 
# This class encodes staging paths into its scripts data so can only be 
 | 
# reused if we manipulate the paths. 
 | 
SSTATE_SCAN_CMD ?= "${SSTATE_SCAN_CMD_NATIVE}" 
 | 
  
 | 
# No strip sysroot when DEBUG_BUILD is enabled 
 | 
INHIBIT_SYSROOT_STRIP ?= "${@oe.utils.vartrue('DEBUG_BUILD', '1', '', d)}" 
 | 
  
 | 
python native_virtclass_handler () { 
 | 
    pn = e.data.getVar("PN") 
 | 
    if not pn.endswith("-native"): 
 | 
        return 
 | 
    bpn = e.data.getVar("BPN") 
 | 
  
 | 
    # Set features here to prevent appends and distro features backfill 
 | 
    # from modifying native distro features 
 | 
    features = set(d.getVar("DISTRO_FEATURES_NATIVE").split()) 
 | 
    filtered = set(bb.utils.filter("DISTRO_FEATURES", d.getVar("DISTRO_FEATURES_FILTER_NATIVE"), d).split()) 
 | 
    d.setVar("DISTRO_FEATURES", " ".join(sorted(features | filtered))) 
 | 
  
 | 
    classextend = e.data.getVar('BBCLASSEXTEND') or "" 
 | 
    if "native" not in classextend: 
 | 
        return 
 | 
  
 | 
    def map_dependencies(varname, d, suffix = "", selfref=True): 
 | 
        if suffix: 
 | 
            varname = varname + ":" + suffix 
 | 
        deps = d.getVar(varname) 
 | 
        if not deps: 
 | 
            return 
 | 
        deps = bb.utils.explode_deps(deps) 
 | 
        newdeps = [] 
 | 
        for dep in deps: 
 | 
            if dep == pn: 
 | 
                if not selfref: 
 | 
                    continue 
 | 
                newdeps.append(dep) 
 | 
            elif "-cross-" in dep: 
 | 
                newdeps.append(dep.replace("-cross", "-native")) 
 | 
            elif not dep.endswith("-native"): 
 | 
                # Replace ${PN} with ${BPN} in the dependency to make sure 
 | 
                # dependencies on, e.g., ${PN}-foo become ${BPN}-foo-native 
 | 
                # rather than ${BPN}-native-foo-native. 
 | 
                newdeps.append(dep.replace(pn, bpn) + "-native") 
 | 
            else: 
 | 
                newdeps.append(dep) 
 | 
        d.setVar(varname, " ".join(newdeps), parsing=True) 
 | 
  
 | 
    map_dependencies("DEPENDS", e.data, selfref=False) 
 | 
    for pkg in e.data.getVar("PACKAGES", False).split(): 
 | 
        map_dependencies("RDEPENDS", e.data, pkg) 
 | 
        map_dependencies("RRECOMMENDS", e.data, pkg) 
 | 
        map_dependencies("RSUGGESTS", e.data, pkg) 
 | 
        map_dependencies("RPROVIDES", e.data, pkg) 
 | 
        map_dependencies("RREPLACES", e.data, pkg) 
 | 
    map_dependencies("PACKAGES", e.data) 
 | 
  
 | 
    provides = e.data.getVar("PROVIDES") 
 | 
    nprovides = [] 
 | 
    for prov in provides.split(): 
 | 
        if prov.find(pn) != -1: 
 | 
            nprovides.append(prov) 
 | 
        elif not prov.endswith("-native"): 
 | 
            nprovides.append(prov + "-native") 
 | 
        else: 
 | 
            nprovides.append(prov) 
 | 
    e.data.setVar("PROVIDES", ' '.join(nprovides)) 
 | 
  
 | 
  
 | 
} 
 | 
  
 | 
addhandler native_virtclass_handler 
 | 
native_virtclass_handler[eventmask] = "bb.event.RecipePreFinalise" 
 | 
  
 | 
python do_addto_recipe_sysroot () { 
 | 
    bb.build.exec_func("extend_recipe_sysroot", d) 
 | 
} 
 | 
addtask addto_recipe_sysroot after do_populate_sysroot 
 | 
do_addto_recipe_sysroot[deptask] = "do_populate_sysroot" 
 | 
  
 | 
inherit nopackages 
 | 
  
 | 
do_packagedata[stamp-extra-info] = "" 
 | 
  
 | 
USE_NLS = "no" 
 | 
  
 | 
RECIPERDEPTASK = "do_populate_sysroot" 
 | 
do_populate_sysroot[rdeptask] = "${RECIPERDEPTASK}" 
 |