Tích hợp với quy tắc C++

Báo cáo vấn đề Xem nguồn Nightly · 8.4 · 8.3 · 8.2 · 8.1 · 8.0 · 7.6

Trang này mô tả cách tích hợp với các quy tắc C++ ở nhiều cấp độ.

Truy cập vào chuỗi công cụ C++

Do quá trình di chuyển liên tục các quy tắc C++ sang các nền tảngchuỗi công cụ, bạn nên sử dụng hàm trợ giúp có tại @bazel_tools//tools/cpp:toolchain_utils.bzl. Hàm này hoạt động cả khi chuỗi công cụ bị tắt và bật. Để phụ thuộc vào một chuỗi công cụ C++ trong quy tắc của bạn, hãy thêm một thuộc tính Label có tên là _cc_toolchain và trỏ thuộc tính đó đến @bazel_tools//tools/cpp:current_cc_toolchain (một phiên bản của quy tắc cc_toolchain_alias, trỏ đến chuỗi công cụ C++ hiện được chọn). Sau đó, trong quá trình triển khai quy tắc, hãy sử dụng find_cpp_toolchain(ctx) để nhận CcToolchainInfo. Bạn có thể tìm thấy một ví dụ hoàn chỉnh về cách thức hoạt động trong các ví dụ về rules_cc.

Tạo dòng lệnh và biến môi trường bằng chuỗi công cụ C++

Thông thường, bạn sẽ tích hợp với chuỗi công cụ C++ để có các cờ dòng lệnh giống như các quy tắc C++, nhưng không sử dụng trực tiếp các thao tác C++. Điều này là do khi viết các thao tác của riêng mình, chúng phải hoạt động nhất quán với chuỗi công cụ C++ – ví dụ: truyền cờ dòng lệnh C++ đến một công cụ gọi trình biên dịch C++ ở chế độ nền.

Các quy tắc C++ sử dụng một cách đặc biệt để tạo dòng lệnh dựa trên cấu hình tính năng. Để tạo một dòng lệnh, bạn cần có những thông tin sau:

Vẫn có các phương thức truy xuất dành riêng cho công cụ, chẳng hạn như compiler_executable. Ưu tiên get_tool_for_action hơn những loại này, vì các phương thức truy xuất dành riêng cho công cụ cuối cùng sẽ bị xoá.

Bạn có thể tìm thấy một ví dụ hoàn chỉnh về cách thức hoạt động trong các ví dụ về rules_cc.

Triển khai các quy tắc Starlark phụ thuộc vào các quy tắc C++ và/hoặc các quy tắc C++ có thể phụ thuộc vào

Hầu hết các quy tắc C++ đều cung cấp CcInfo, một trình cung cấp chứa CompilationContextLinkingContext. Thông qua các tệp này, bạn có thể truy cập vào thông tin như tất cả các tiêu đề hoặc thư viện bắc cầu để liên kết. Từ CcInfo và từ các quy tắc CcToolchainInfo tuỳ chỉnh, Starlark sẽ có thể lấy được tất cả thông tin cần thiết.

Nếu một quy tắc Starlark tuỳ chỉnh cung cấp CcInfo, thì đó là tín hiệu cho các quy tắc C++ rằng chúng cũng có thể phụ thuộc vào quy tắc đó. Tuy nhiên, hãy cẩn thận – nếu bạn chỉ cần truyền CcInfo qua biểu đồ đến quy tắc nhị phân rồi sử dụng quy tắc đó, hãy gói CcInfo trong một trình cung cấp khác. Ví dụ: nếu quy tắc java_library muốn truyền các phần phụ thuộc gốc lên đến java_binary, thì quy tắc đó không được cung cấp trực tiếp CcInfo (cc_binary tuỳ thuộc vào java_library không có ý nghĩa), mà phải gói quy tắc đó trong, ví dụ: JavaCcInfo.

Bạn có thể tìm thấy một ví dụ hoàn chỉnh về cách thức hoạt động trong các ví dụ về rules_cc.

Sử dụng lại logic và các thao tác của quy tắc C++

Chưa ổn định; Phần này sẽ được cập nhật sau khi API ổn định. Theo dõi #4570 để biết thông tin mới nhất.