#!/usr/bin/env bash # # Copyright (c) 2021 Project CHIP Authors # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # set -e _normpath() { python -c "import os.path; print(os.path.normpath('$@'))" } echo_green() { echo -e "\033[0;32m$*\033[0m" } echo_blue() { echo -e "\033[1;34m$*\033[0m" } echo_bold_white() { echo -e "\033[1;37m$*\033[0m" } CHIP_ROOT=$(_normpath "$(dirname "$0")/..") OUTPUT_ROOT="$CHIP_ROOT/out/python_lib" declare chip_detail_logging=false declare enable_pybindings=false declare chip_mdns declare case_retry_delta declare install_virtual_env declare clean_virtual_env=yes declare install_pytest_requirements=yes help() { echo "Usage: $file_name [ options ... ] [ -chip_detail_logging ChipDetailLoggingValue ] [ -chip_mdns ChipMDNSValue ] [-enable_pybindings EnableValue]" echo "General Options: -h, --help Display this information. Input Options: -d, --chip_detail_logging Specify ChipDetailLoggingValue as true or false. By default it is false. -m, --chip_mdns ChipMDNSValue Specify ChipMDNSValue as platform or minimal. By default it is minimal. -p, --enable_pybindings Specify whether to enable pybindings as python controller. -t --time_between_case_retries MRPActiveRetryInterval Specify MRPActiveRetryInterval value Default is 300 ms -i, --install_virtual_env Create a virtual environment with the wheels installed represents where the virtual environment is to be created. -c, --clean_virtual_env When installing a virtual environment, create/clean it first. Defaults to yes. --include_pytest_deps Install requirements.txt for running scripts/tests and src/python_testing scripts. Defaults to yes. --extra_packages PACKAGES Install extra Python packages from PyPI --include_yamltests Whether to install the matter_yamltests wheel. -z --pregen_dir DIRECTORY Directory where generated zap files have been pre-generated. " } file_name=${0##*/} while (($#)); do case $1 in --help | -h) help exit 1 ;; --chip_detail_logging | -d) chip_detail_logging=$2 if [[ "$chip_detail_logging" != "true" && "$chip_detail_logging" != "false" ]]; then echo "chip_detail_logging should have a true/false value, not '$chip_detail_logging'" exit fi shift ;; --chip_mdns | -m) chip_mdns=$2 shift ;; --enable_pybindings | -p) enable_pybindings=$2 if [[ "$enable_pybindings" != "true" && "$enable_pybindings" != "false" ]]; then echo "enable_pybindings should have a true/false value, not '$enable_pybindings'" exit fi shift ;; --time_between_case_retries | -t) chip_case_retry_delta=$2 shift ;; --install_virtual_env | -i) install_virtual_env=$2 shift ;; --clean_virtual_env | -c) clean_virtual_env=$2 if [[ "$clean_virtual_env" != "yes" && "$clean_virtual_env" != "no" ]]; then echo "clean_virtual_env should have a yes/no value, not '$clean_virtual_env'" exit fi shift ;; --include_pytest_deps) install_pytest_requirements=$2 if [[ "$install_pytest_requirements" != "yes" && "$install_pytest_requirements" != "no" ]]; then echo "install_pytest_requirements should have a yes/no value, not '$install_pytest_requirements'" exit fi shift ;; --extra_packages) extra_packages=$2 shift ;; --include_yamltests) include_yamltests="yes" ;; --pregen_dir | -z) pregen_dir=$2 shift ;; -*) help echo "Unknown Option \"$1\"" exit 1 ;; esac shift done # Print input values echo "Input values: chip_detail_logging = $chip_detail_logging , chip_mdns = \"$chip_mdns\", enable_pybindings = $enable_pybindings, chip_case_retry_delta=\"$chip_case_retry_delta\", pregen_dir=\"$pregen_dir\"" # Ensure we have a compilation environment source "$CHIP_ROOT/scripts/activate.sh" # Generates ninja files [[ -n "$chip_mdns" ]] && chip_mdns_arg="chip_mdns=\"$chip_mdns\"" || chip_mdns_arg="" [[ -n "$chip_case_retry_delta" ]] && chip_case_retry_arg="chip_case_retry_delta=$chip_case_retry_delta" || chip_case_retry_arg="" [[ -n "$pregen_dir" ]] && pregen_dir_arg="chip_code_pre_generated_directory=\"$pregen_dir\"" || pregen_dir_arg="" # Make all possible human redable tracing available. tracing_options="matter_log_json_payload_hex=true matter_log_json_payload_decode_full=true matter_enable_tracing_support=true" gn --root="$CHIP_ROOT" gen "$OUTPUT_ROOT" --args="$tracing_options chip_detail_logging=$chip_detail_logging enable_pylib=$enable_pybindings enable_rtti=$enable_pybindings chip_project_config_include_dirs=[\"//config/python\"] $chip_mdns_arg $chip_case_retry_arg $pregen_dir_arg" function ninja_target() { # Print the ninja target required to build a gn label. local GN_LABEL="$1" local NINJA_TARGET="$(gn ls "$OUTPUT_ROOT" --as=output "$GN_LABEL")" echo "$NINJA_TARGET" } function wheel_output_dir() { # Print the wheel output directory for a pw_python_package or # pw_python_distribution. The label must end in "._build_wheel". local GN_LABEL="$1" local NINJA_TARGET="$(ninja_target "$GN_LABEL")" local WHEEL_DIR="$OUTPUT_ROOT"/"$(dirname "$NINJA_TARGET")/$(basename -s .stamp "$NINJA_TARGET")" echo "$WHEEL_DIR" } # Compile Python wheels ninja -C "$OUTPUT_ROOT" python_wheels # Add wheels from chip_python_wheel_action templates. if [ "$enable_pybindings" == true ]; then WHEEL=("$OUTPUT_ROOT"/pybindings/pycontroller/pychip-*.whl) else WHEEL=("$OUTPUT_ROOT"/controller/python/chip*.whl) fi if [ -n "$include_yamltests" ]; then YAMLTESTS_GN_LABEL="//scripts:matter_yamltests_distribution._build_wheel" # Add wheels from pw_python_package or pw_python_distribution templates. WHEEL+=( "$(ls -tr "$(wheel_output_dir "$YAMLTESTS_GN_LABEL")"/*.whl | head -n 1)" ) fi if [ -n "$extra_packages" ]; then WHEEL+=("$extra_packages") fi if [ -n "$install_virtual_env" ]; then ENVIRONMENT_ROOT="$install_virtual_env" if [ "$clean_virtual_env" = "yes" ]; then # Create a virtual environment that has access to the built python tools echo_blue "Creating a clear VirtualEnv in '$ENVIRONMENT_ROOT' ..." virtualenv --clear "$ENVIRONMENT_ROOT" elif [ ! -f "$ENVIRONMENT_ROOT"/bin/activate ]; then echo_blue "Creating a new VirtualEnv in '$ENVIRONMENT_ROOT' ..." virtualenv "$ENVIRONMENT_ROOT" fi source "$ENVIRONMENT_ROOT"/bin/activate "$ENVIRONMENT_ROOT"/bin/python -m pip install --upgrade pip "$ENVIRONMENT_ROOT"/bin/pip install --upgrade "${WHEEL[@]}" if [ "$install_pytest_requirements" = "yes" ]; then echo_blue "Installing python test dependencies ..." "$ENVIRONMENT_ROOT"/bin/pip install -r "$CHIP_ROOT/scripts/tests/requirements.txt" "$ENVIRONMENT_ROOT"/bin/pip install -r "$CHIP_ROOT/src/python_testing/requirements.txt" fi echo "" echo_green "Compilation completed and WHL package installed in: " echo_blue " $ENVIRONMENT_ROOT" echo "" echo_green "To use please run:" echo_bold_white " source $ENVIRONMENT_ROOT/bin/activate" fi