C++ y Bazel

En esta página, se incluyen recursos que te ayudan a usar Bazel con proyectos de C++. Se vincula a un instructivo, reglas de compilación y otra información específica para compilar proyectos de C++ con Bazel.

Trabaja con Bazel

Los siguientes recursos te ayudarán a trabajar con Bazel en proyectos de C++:

Prácticas recomendadas

Además de las prácticas recomendadas generales de Bazel, a continuación, se incluyen las prácticas recomendadas específicas para proyectos de C++.

Archivos BUILD

Sigue los lineamientos que se indican a continuación cuando crees tus archivos BUILD:

  • Cada archivo BUILD debe contener un cc_library destino de regla por unidad de compilación en el directorio.

  • Debes granularizar tus bibliotecas de C++ tanto como sea posible para maximizar la incrementalidad y paralelizar la compilación.

  • Si hay un solo archivo fuente en srcs, asigna a la biblioteca el mismo nombre que el de ese archivo de C++. Esta biblioteca debe contener archivos de C++, cualquier archivo de encabezado coincidente y las dependencias directas de la biblioteca. Por ejemplo:

    cc_library(
        name = "mylib",
        srcs = ["mylib.cc"],
        hdrs = ["mylib.h"],
        deps = [":lower-level-lib"]
    )
    
  • Usa un destino de regla cc_test por destino cc_library en el archivo. Asigna el nombre al destino [library-name]_test y el nombre al archivo fuente [library-name]_test.cc. Por ejemplo, un destino de prueba para el destino de biblioteca mylib que se muestra arriba se vería de la siguiente manera:

    cc_test(
        name = "mylib_test",
        srcs = ["mylib_test.cc"],
        deps = [":mylib"]
    )
    

Incluir rutas

Sigue estos lineamientos para incluir rutas:

  • Haz que todas las rutas de inclusión sean relativas al directorio del espacio de trabajo.

  • Usa inclusiones entre comillas (#include "foo/bar/baz.h") para encabezados que no sean del sistema, no corchetes angulares (#include <foo/bar/baz.h>).

  • Evita usar accesos directos de directorios de UNIX, como . (directorio actual) o .. (directorio superior).

  • Para el código heredado o third_party que requiere inclusiones que apunten fuera del repositorio del proyecto, como las inclusiones de repositorios externos que requieren un prefijo, usa los argumentos include_prefix y strip_include_prefix en el destino de la regla cc_library.

Funciones de la cadena de herramientas

Las siguientes funciones opcionales pueden mejorar la higiene de un proyecto de C++. Se pueden habilitar con la --features marca de línea de comandos o el atributo features de las reglas repo, package o cc_*:

  • La función parse_headers hace que se use el compilador de C++ para analizar (pero no compilar) todos los archivos de encabezado en los destinos compilados y sus dependencias cuando se usa la --process_headers_in_dependencies marca. Esto puede ayudar a detectar problemas en las bibliotecas de solo encabezado y garantizar que los encabezados sean autónomos y no dependan del orden en que se incluyen.
  • La función layering_check exige que los destinos solo incluyan encabezados proporcionados por sus dependencias directas. La cadena de herramientas predeterminada admite esta función en Linux con clang como compilador.