.. 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. .. _core_buildelement_builtins: BuildElement - Built-in functionality ===================================== The :doc:`manual ` core plugin and various common element plugins available in other repositories are based on the :mod:`BuildElement ` base class, which provides built in functionality that could be overridden by the individual plugins. This page will give a brief summary of how some of the common features work, some of them or the variables they use will be further detailed in the :doc:`API reference `. The `strip-binaries` variable ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ The `strip-binaries` variable is by default **empty**. You need to use the appropiate commands depending of the system you are building. If you are targeting Linux, ones known to work are the ones used by the `freedesktop-sdk `_, you can take a look to them in their `project.conf `_ Location for staging dependencies ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ The BuildElement supports the "location" :term:`dependency configuration `, which means you can use this configuration for any BuildElement class. The "location" configuration defines where the dependency will be staged in the build sandbox. **Example:** Here is an example of how one might stage some dependencies into an alternative location while staging some elements in the sandbox root. .. code:: yaml # Stage these build dependencies in /opt # build-depends: - baseproject.bst:opt-dependencies.bst config: location: /opt # Stage these tools in "/" and require them as # runtime dependencies. depends: - baseproject.bst:base-tools.bst .. note:: The order of dependencies specified is not significant. The staging locations will be sorted so that elements are staged in parent directories before subdirectories. `digest-environment` for dependencies ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ The BuildElement supports the ``digest-environment`` :term:`dependency configuration `, which sets the specified environment variable in the build sandbox to the CAS digest corresponding to a directory that contains all dependencies that are configured with the same ``digest-environment``. This is useful for REAPI clients in the sandbox such as `recc `_, see ``remote-apis-socket`` in the :ref:`sandbox configuration `. **Example:** Here is an example of how to set the environment variable `GCC_DIGEST` to the CAS digest of a directory that contains ``gcc.bst`` and its runtime dependencies. The ``libpony.bst`` dependency will not be included in that CAS directory. .. code:: yaml build-depends: - baseproject.bst:gcc.bst config: digest-environment: GCC_DIGEST - libpony.bst Location for running commands ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ The ``command-subdir`` variable sets where commands will be executed, and the directory will be created automatically if it does not exist. The ``command-subdir`` is a relative path from ``%{build-root}``, and cannot be a parent or adjacent directory, it must expand to a subdirectory of ``${build-root}``. Location for configuring the project ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ The ``conf-root`` is the location that specific build elements can use to look for build configuration files. This is used by elements such as `autotools `_, `cmake `_, `meson `_, `setuptools `_ and `pip `_. The default value of ``conf-root`` is defined by default as ``.``. This means that if the ``conf-root`` is not explicitly set to another directory, the configuration files are expected to be found in ``command-subdir``. Separating source and build directories ''''''''''''''''''''''''''''''''''''''' A typical example of using ``conf-root`` is when performing `autotools `_ builds where your source directory is separate from your build directory. This can be achieved in build elements which use ``conf-root`` as follows: .. code:: yaml variables: # Specify that build configuration scripts are found in %{build-root} conf-root: "%{build-root}" # The build will run in the `_build` subdirectory command-subdir: _build Install Location ~~~~~~~~~~~~~~~~ Build elements must install the build output to the directory defined by ``install-root``. You need not set or change the ``install-root`` variable as it will be defined automatically on your behalf, and it is used to collect build output when creating the resulting artifacts. It is important to know about ``install-root`` in order to write your own custom install instructions, for example the `cmake `_ element will use it to specify the ``DESTDIR``.