Detalles de la implementación de la resolución de la cadena de herramientas

Informar un problema Ver fuente Nightly · 8.0 . 7.4 . 7.3 · 7.2 · 7.1 · 7.0 · 6.5

Nota: Esta sección está destinada a los desarrolladores de Bazel y no es necesaria para los autores de reglas.

Varias clases de SkyFunction implementan el proceso de resolución de cadena de herramientas:

  1. RegisteredToolchainsFunction y RegisteredExecutionPlatformsFunction encuentran las cadenas de herramientas y plataformas de ejecución disponibles, según la configuración y el archivo WORKSPACE actuales.

  2. SingleToolchainResolutionFunction resuelve un solo tipo de cadena de herramientas para cada plataforma de ejecución. Es decir, para cada plataforma de ejecución, encuentra la mejor cadena de herramientas registrada que se puede usar según los siguientes criterios:

    1. Para asegurarte de que la cadena de herramientas y la plataforma de destino sean compatibles, verifica el atributo target_compatible_with.
    2. Para asegurarte de que la cadena de herramientas y la plataforma de ejecución sean compatibles, verifica el atributo exec_compatible_with.
    3. Si quedan varias cadenas de herramientas, elige la que tenga la prioridad más alta (la que se registró primero).
  3. ToolchainResolutionFunction llama a SingleToolchainResolutionFunction para cada tipo de cadena de herramientas solicitada y, luego, determina la mejor plataforma de ejecución que se debe usar.

    1. Primero, quita cualquier plataforma de ejecución que no tenga una cadena de herramientas válida para cada tipo de cadena de herramientas solicitada.
    2. Si quedan varias plataformas de ejecución, elige la que tenga la prioridad más alta (la que se registró primero).
      1. Si la plataforma de ejecución ya está establecida por la transición de la cadena de herramientas, se seleccionará primero como se describe a continuación.

Como se explica en Cadenas de herramientas y configuraciones, la dependencia de un destino a una cadena de herramientas usa una configuración especial que obliga a que la plataforma de ejecución sea la misma para ambos. A pesar del nombre "transición de cadena de herramientas", no se implementa como una transición de configuración, sino como una subclase especial de ConfiguredTargetKey, llamada ToolchainDependencyConfiguredTargetKey. Además de los otros datos en ConfiguredTargetKey, esta subclase también contiene la etiqueta de la plataforma de ejecución. Cuando ToolchainResolutionFunction considera qué plataforma de ejecución usar, si la plataforma de ejecución forzada de ToolchainDependencyConfiguredTargetKey es válida, se usará incluso si no es la de mayor prioridad.

Nota: Si la plataforma de ejecución forzada no es válida (porque no hay cadenas de herramientas válidas o debido a restricciones de ejecución de la regla o el destino), se usará la plataforma de ejecución válida de mayor prioridad.