C++ y Bazel

Informar un problema Ver fuente

En esta página, encontrarás recursos que te ayudarán a usar Bazel con proyectos de C++. Vincula a un instructivo, reglas de compilación y otra información específica para compilar proyectos de C++ con Bazel.

Cómo trabajar 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 muestran 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 objetivo de regla cc_library por unidad de compilación en el directorio.

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

  • Si hay un solo archivo de origen en srcs, asigna a la biblioteca el mismo nombre que el de ese archivo C++. Esta biblioteca debe contener archivos C++, cualquier archivo de encabezado que coincida 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 objetivo de regla cc_test por cada objetivo cc_library en el archivo. Asigna el nombre [library-name]_test de destino y el archivo de origen [library-name]_test.cc. Por ejemplo, un destino de prueba para el destino de la biblioteca mylib que se mostró antes 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 de acceso:

  • Haz que todas las rutas de inclusión estén relacionadas con el directorio del lugar de trabajo.

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

  • Evita el uso de combinaciones de teclas del directorio de UNIX, como . (directorio actual) o .. (directorio superior).

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