C++ y Bazel

Informar un problema Ver fuente

Esta página contiene recursos que te ayudarán 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.

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 incluyen prácticas recomendadas específicas para proyectos de C++.

Archivos de BUILD

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

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

  • Debes detallar tus 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 nombre de ese archivo C++. Esta biblioteca debe contener archivos 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 objetivo cc_library en el archivo. Asigna el nombre [library-name]_test de destino y [library-name]_test.cc al archivo de origen. Por ejemplo, un destino de prueba para el destino de la biblioteca mylib que se mostró anteriormente se vería de la siguiente manera:

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

Incluir rutas

Sigue estos lineamientos para las rutas de inclusión:

  • 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 usar combinaciones de teclas de directorio de UNIX, como . (directorio actual) o .. (directorio principal).

  • En el caso del código heredado o third_party que requiere apuntar fuera del repositorio del proyecto, como cuando se requiere un prefijo en un repositorio externo, usa los argumentos include_prefix y strip_include_prefix en el destino de la regla cc_library.