| # Copyright 2022 The Pigweed 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 |
| # |
| # https://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. |
| |
| import("//build_overrides/pigweed.gni") |
| import("$dir_pw_build/python.gni") |
| import("$dir_pw_build/python_dist.gni") |
| import("$dir_pw_build/python_venv.gni") |
| |
| # NOTE: All the `deps` listed in `//BUILD.gn` must either be instantiated with a |
| # toolchain, e.g. `":my_host_target(//path/to/host:toolchain)"`, or listed |
| # within an `if (current_toolchain != default_toolchain)` statement. |
| # It also prevents the default toolchain from parsing any unnecessary BUILD.gn |
| # files. |
| |
| # This group is built during bootstrap to setup the interactive Python |
| # environment. |
| pw_python_group("python") { |
| python_deps = [ |
| # Generate and pip install _all_python_packages |
| ":pip_install_zephyr_integration_tools", |
| ] |
| } |
| |
| # In-tree Python packages |
| _zephyr_integration_python_packages = [] |
| |
| # Pigweed Python packages to include |
| _pigweed_python_packages = [ "$dir_pw_env_setup:core_pigweed_python_packages" ] |
| |
| _all_python_packages = |
| _zephyr_integration_python_packages + _pigweed_python_packages |
| |
| # The default venv for Python actions in GN |
| # Set this gn arg in a declare_args block in this file 'BUILD.gn' or in '.gn' to |
| # use this venv. |
| # |
| # pw_build_PYTHON_BUILD_VENV = "//:zephyr_integration_build_venv" |
| # |
| pw_python_venv("zephyr_integration_build_venv") { |
| path = "$root_build_dir/python-venv" |
| constraints = pw_build_PIP_CONSTRAINTS |
| requirements = pw_build_PIP_REQUIREMENTS |
| |
| # Ensure all third party Python dependencies are installed into this venv. |
| # This works by checking the setup.cfg files for all packages listed here and |
| # installing the packages listed in the [options].install_requires field. |
| source_packages = _all_python_packages |
| } |
| |
| # This template collects all python packages and their dependencies into a |
| # single super Python package for installation into the bootstrapped virtual |
| # environment. |
| pw_create_python_source_tree( |
| "generate_zephyr_integration_tools_python_distribution") { |
| packages = _all_python_packages |
| generate_setup_cfg = { |
| name = "sample-project-tools" |
| version = "0.0.1" |
| append_date_to_version = true |
| include_default_pyproject_file = true |
| } |
| } |
| |
| # Install the sample-project-tools super Python package into the bootstrapped |
| # Python venv. |
| pw_internal_pip_install("pip_install_zephyr_integration_tools") { |
| packages = [ ":generate_zephyr_integration_tools_python_distribution" ] |
| } |