Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[profiles] Added [system_tools] #2989

Merged
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions common/experimental_warning.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
:orphan:

.. warning::
This feature is experimental and subject to breaking changes.
117 changes: 117 additions & 0 deletions reference/config_files/profiles.rst
Original file line number Diff line number Diff line change
Expand Up @@ -180,6 +180,8 @@ List of options available from your recipe and its dependencies:
shared=True


.. _reference_config_files_profiles_tool_requires:

[tool_requires]
+++++++++++++++

Expand All @@ -196,6 +198,121 @@ List of ``tool_requires`` required by your recipe or its dependencies:
Read more about tool requires in this section: :ref:`consuming_packages_tool_requires`.


.. _reference_config_files_profiles_system_tools:

[system_tools]
+++++++++++++++

.. include:: ../../common/experimental_warning.rst

This section is similar to the previous one, **[tool_requires]**, but it's intended to list only the tool requires
that are already in your own system and you don't want Conan to search them remotely or locally.
memsharded marked this conversation as resolved.
Show resolved Hide resolved

For instance, you have already installed ``cmake==3.24.2`` in your system:

.. code-block:: bash

$ cmake --version
cmake version 3.24.2

CMake suite maintained and supported by Kitware (kitware.com/cmake).

Now, you have in your recipe (or the transitive dependencies) declared a **tool_requires**, i.e., something like this:

.. code-block:: python
:caption: **conanfile.py**

from conan import ConanFile

class PkgConan(ConanFile):
name = "pkg"
version = "2.0"
# ....

# Exact version
def build_requirements(self):
self.tool_requires("cmake/3.24.2")

# Or even version ranges
def build_requirements(self):
self.tool_requires("cmake/[>=3.20.0]")


Given this situation, it could make sense to want to use your already installed CMake version, so it's enough to declare
it as a ``system_tools`` in your profile (``default`` one or any other in use):

.. code-block:: text
:caption: *myprofile*

...

[system_tools]
cmake/3.24.2

Whenever you want to create the package, you'll see that build requirement is already satisfied because of the system tool
declaration:

.. code-block:: bash
:emphasize-lines: 9,18

$ conan create . -pr myprofile --build=missing
...
-------- Computing dependency graph --------
Graph root
virtual
Requirements
pkg/2.0#3488ec5c2829b44387152a6c4b013767 - Cache
Build requirements
cmake/3.24.2 - System tool

-------- Computing necessary packages --------

-------- Computing necessary packages --------
pkg/2.0: Forced build from source
Requirements
pkg/2.0#3488ec5c2829b44387152a6c4b013767:20496b332552131b67fb99bf425f95f64d0d0818 - Build
Build requirements
cmake/3.24.2 - System tool


Notice that if the ``system_tools`` declared does not make a strict match with the ``tool_requires`` one (version or
version range), then Conan will try to bring them remotely or locally as usual. Given the previous example, changing the
franramirez688 marked this conversation as resolved.
Show resolved Hide resolved
profile as follows:

.. code-block:: text
:caption: *myprofile*

...

[system_tools]
cmake/3.20.0

The result will be different when calling the :command:`conan create`, because Conan will download remotely and build
from source if necessary:

.. code-block:: bash
:emphasize-lines: 9,18

$ conan create . -pr myprofile --build=missing
...
-------- Computing dependency graph --------
Graph root
virtual
Requirements
pkg/2.0#3488ec5c2829b44387152a6c4b013767 - Cache
Build requirements
cmake/3.24.2#e35bc44b3fcbcd661e0af0dc5b5b1ad4 - Downloaded (conancenter)

-------- Computing necessary packages --------

-------- Computing necessary packages --------
pkg/2.0: Forced build from source
Requirements
pkg/2.0#3488ec5c2829b44387152a6c4b013767:20496b332552131b67fb99bf425f95f64d0d0818 - Build
Build requirements
cmake/3.24.2#e35bc44b3fcbcd661e0af0dc5b5b1ad4:d0599452a426a161e02a297c6e0c5070f99b4909 - Build


.. _reference_config_files_profiles_buildenv:

[buildenv]
Expand Down
6 changes: 4 additions & 2 deletions reference/config_files/settings.rst
Original file line number Diff line number Diff line change
Expand Up @@ -208,8 +208,10 @@ to the ``update`` subsetting in ``settings.yml``.
intel-cc
++++++++

This compiler is a new, **experimental** one, aimed to handle the new Intel oneAPI DPC++/C++/Classic compilers.
Instead of having *n* different compilers, you have 3 different **modes** of working:
.. include:: ../../common/experimental_warning.rst

This compiler is aimed to handle the new Intel oneAPI DPC++/C++/Classic compilers. Instead of having *n* different compilers,
you have 3 different **modes** of working:

* ``icx`` for Intel oneAPI C++.
* ``dpcpp`` for Intel oneAPI DPC++.
Expand Down
2 changes: 1 addition & 1 deletion reference/extensions/python_api/ConanAPI.rst
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
Conan API Reference
===================

.. include:: api_warning.rst
.. include:: ../../../common/experimental_warning.rst
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@memsharded I think it's better to have all of them in one place. Wdyt?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, they can be even in the repo root, not a big issue for me.


.. currentmodule:: conan.api.conan_api

Expand Down
2 changes: 1 addition & 1 deletion reference/extensions/python_api/ConfigAPI.rst
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
Config API
==========

.. include:: api_warning.rst
.. include:: ../../../common/experimental_warning.rst

.. currentmodule:: conan.api.subapi.config

Expand Down
2 changes: 1 addition & 1 deletion reference/extensions/python_api/DownloadAPI.rst
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
Download API
============

.. include:: api_warning.rst
.. include:: ../../../common/experimental_warning.rst

.. currentmodule:: conan.api.subapi.download

Expand Down
2 changes: 1 addition & 1 deletion reference/extensions/python_api/ExportAPI.rst
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
Export API
==========

.. include:: api_warning.rst
.. include:: ../../../common/experimental_warning.rst

.. currentmodule:: conan.api.subapi.export

Expand Down
2 changes: 1 addition & 1 deletion reference/extensions/python_api/GraphAPI.rst
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
Graph API
=========

.. include:: api_warning.rst
.. include:: ../../../common/experimental_warning.rst

.. currentmodule:: conan.api.subapi.graph

Expand Down
2 changes: 1 addition & 1 deletion reference/extensions/python_api/InstallAPI.rst
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
Install API
===========

.. include:: api_warning.rst
.. include:: ../../../common/experimental_warning.rst

.. currentmodule:: conan.api.subapi.install

Expand Down
2 changes: 1 addition & 1 deletion reference/extensions/python_api/ListAPI.rst
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
List API
========

.. include:: api_warning.rst
.. include:: ../../../common/experimental_warning.rst

.. currentmodule:: conan.api.subapi.list

Expand Down
2 changes: 1 addition & 1 deletion reference/extensions/python_api/NewAPI.rst
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
New API
=======

.. include:: api_warning.rst
.. include:: ../../../common/experimental_warning.rst

.. currentmodule:: conan.api.subapi.new

Expand Down
2 changes: 1 addition & 1 deletion reference/extensions/python_api/ProfilesAPI.rst
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
Profiles API
============

.. include:: api_warning.rst
.. include:: ../../../common/experimental_warning.rst

.. currentmodule:: conan.api.subapi.profiles

Expand Down
2 changes: 1 addition & 1 deletion reference/extensions/python_api/RemotesAPI.rst
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
Remotes API
===========

.. include:: api_warning.rst
.. include:: ../../../common/experimental_warning.rst

.. currentmodule:: conan.api.subapi.remotes

Expand Down
2 changes: 1 addition & 1 deletion reference/extensions/python_api/RemoveAPI.rst
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
Remove API
==========

.. include:: api_warning.rst
.. include:: ../../../common/experimental_warning.rst

.. currentmodule:: conan.api.subapi.remove

Expand Down
2 changes: 1 addition & 1 deletion reference/extensions/python_api/SearchAPI.rst
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
Search API
==========

.. include:: api_warning.rst
.. include:: ../../../common/experimental_warning.rst

.. currentmodule:: conan.api.subapi.search

Expand Down
2 changes: 1 addition & 1 deletion reference/extensions/python_api/UploadAPI.rst
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
Upload API
==========

.. include:: api_warning.rst
.. include:: ../../../common/experimental_warning.rst

.. currentmodule:: conan.api.subapi.upload

Expand Down
4 changes: 0 additions & 4 deletions reference/extensions/python_api/api_warning.rst

This file was deleted.

3 changes: 2 additions & 1 deletion tutorial/consuming_packages/use_tools_as_conan_packages.rst
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ The structure of the project is the same as the one of the previous example:
└── main.c


The main difference is the addition of the **[tool_requires]** section in the
The main difference is the addition of the :ref:`reference_config_files_profiles_tool_requires` section in the
**conanfile.txt** file. In this section, we declare that we want to build our application
using CMake **v3.19.8**.

Expand Down Expand Up @@ -207,6 +207,7 @@ the environment activation:
Read more
---------

- :ref:`Using [system_tools] in your profiles <reference_config_files_profiles_system_tools>`.
- Using MinGW as tool_requires
- Using tool_requires in profiles
- Using conf to set a toolchain from a tool requires
Expand Down