mirror of
https://github.com/openembedded/meta-openembedded.git
synced 2025-07-19 15:29:08 +02:00

PyO3 provides Rust bindings for Python, including tools for creating native Python extension modules. Running and interacting with Python code from a Rust binary is also supported. This class sets up the cross-compilation environment. Export PYO3_CROSS, PYO3_CROSS_LIB_DIR, PYO3_CROSS_INCLUDE_DIR and CARGO_BUILD_TARGET to inform tools like setuptools-rust we are cross-compiling. Export RUSTFLAGS so cargo can find 'std' and 'core' for target Dynamically generate PyO3 config file and export PYO3_CONFIG_FILE absolute path. This is the trick that finally made pyo3 work. Signed-off-by: Tim Orling <tim.orling@konsulko.com> Signed-off-by: Khem Raj <raj.khem@gmail.com> Signed-off-by: Trevor Gamblin <trevor.gamblin@windriver.com>
31 lines
767 B
Plaintext
31 lines
767 B
Plaintext
#
|
|
# This class helps make sure that Python extensions built with PyO3
|
|
# and setuptools_rust properly set up the environment for cross compilation
|
|
#
|
|
|
|
inherit cargo python3-dir siteinfo
|
|
|
|
export PYO3_CROSS="1"
|
|
export PYO3_CROSS_PYTHON_VERSION="${PYTHON_BASEVERSION}"
|
|
export PYO3_CROSS_LIB_DIR="${STAGING_LIBDIR}"
|
|
export CARGO_BUILD_TARGET="${HOST_SYS}"
|
|
export RUSTFLAGS
|
|
export PYO3_PYTHON="${PYTHON}"
|
|
export PYO3_CONFIG_FILE="${WORKDIR}/pyo3.config"
|
|
|
|
pyo3_do_configure () {
|
|
cat > ${WORKDIR}/pyo3.config << EOF
|
|
implementation=CPython
|
|
version=${PYTHON_BASEVERSION}
|
|
shared=true
|
|
abi3=false
|
|
lib_name=${PYTHON_DIR}
|
|
lib_dir=${STAGING_LIBDIR}
|
|
pointer_width=${SITEINFO_BITS}
|
|
build_flags=WITH_THREAD
|
|
suppress_build_script_link_lines=false
|
|
EOF
|
|
}
|
|
|
|
EXPORT_FUNCTIONS do_configure
|