From 47b1c5d3eae42900c1b7a0b69140a4a637c66abf Mon Sep 17 00:00:00 2001 From: Steffen Smolka Date: Tue, 17 Dec 2024 18:14:33 -0800 Subject: [PATCH] Add support for Bzlmod (fixes #515). Signed-off-by: Steffen Smolka --- .github/workflows/ci-build-proto.yml | 13 ++++--- .gitignore | 7 ++-- bazel/example/using-bzlmod/.bazelrc | 6 ++++ bazel/example/{ => using-bzlmod}/BUILD.bazel | 0 bazel/example/using-bzlmod/MODULE.bazel | 24 +++++++++++++ .../{ => using-bzlmod}/hello_p4runtime.cc | 0 bazel/example/{ => using-workspace}/.bazelrc | 2 +- .../{ => using-workspace}/.bazelversion | 0 bazel/example/using-workspace/BUILD.bazel | 8 +++++ .../{ => using-workspace}/WORKSPACE.bazel | 2 +- .../using-workspace/hello_p4runtime.cc | 21 +++++++++++ proto/.bazelrc | 6 ++-- proto/.bazelversion | 1 - proto/MODULE.bazel | 35 +++++++++++++++++++ proto/WORKSPACE.bzlmod | 5 +++ 15 files changed, 117 insertions(+), 13 deletions(-) create mode 100644 bazel/example/using-bzlmod/.bazelrc rename bazel/example/{ => using-bzlmod}/BUILD.bazel (100%) create mode 100644 bazel/example/using-bzlmod/MODULE.bazel rename bazel/example/{ => using-bzlmod}/hello_p4runtime.cc (100%) rename bazel/example/{ => using-workspace}/.bazelrc (67%) rename bazel/example/{ => using-workspace}/.bazelversion (100%) create mode 100644 bazel/example/using-workspace/BUILD.bazel rename bazel/example/{ => using-workspace}/WORKSPACE.bazel (98%) create mode 100644 bazel/example/using-workspace/hello_p4runtime.cc delete mode 100644 proto/.bazelversion create mode 100644 proto/MODULE.bazel create mode 100644 proto/WORKSPACE.bzlmod diff --git a/.github/workflows/ci-build-proto.yml b/.github/workflows/ci-build-proto.yml index 4ab094c7..a1b48d84 100644 --- a/.github/workflows/ci-build-proto.yml +++ b/.github/workflows/ci-build-proto.yml @@ -2,11 +2,11 @@ name: "build protobufs" on: push: - branches: + branches: - main - '*-dev' pull_request: - branches: + branches: - main - '*-dev' schedule: @@ -21,7 +21,7 @@ jobs: - uses: actions/checkout@v2 with: submodules: recursive - + - name: Mount bazel cache uses: actions/cache@v2 with: @@ -42,5 +42,8 @@ jobs: - name: Build proto/ run: cd proto && bazel build //... && bazel test //... - - name: Build bazel/example/ - run: cd bazel/example/ && bazel build //... + - name: Build bazel/example/using-workspace/ + run: cd bazel/example/using-workspace && bazel build //... + + - name: Build bazel/example/using-bzlmod/ + run: cd bazel/example/using-bzlmod && bazel build //... diff --git a/.gitignore b/.gitignore index 8af80faf..c2889b78 100644 --- a/.gitignore +++ b/.gitignore @@ -1,12 +1,15 @@ # Emacs *~ docs/v1/build/ -bazel-* .DS_Store build dist *.egg-info .eggs -# rust +# Rust target/ + +# Bazel +bazel-* +*.lock diff --git a/bazel/example/using-bzlmod/.bazelrc b/bazel/example/using-bzlmod/.bazelrc new file mode 100644 index 00000000..27c8bb06 --- /dev/null +++ b/bazel/example/using-bzlmod/.bazelrc @@ -0,0 +1,6 @@ +# Use Bzlmod (`MODULE.bazel`) instead of `WORKSPACE.bazel`. +common --enable_bzlmod +common --noenable_workspace + +# C++14 required for recent gRPC versions +build --cxxopt='-std=c++14' diff --git a/bazel/example/BUILD.bazel b/bazel/example/using-bzlmod/BUILD.bazel similarity index 100% rename from bazel/example/BUILD.bazel rename to bazel/example/using-bzlmod/BUILD.bazel diff --git a/bazel/example/using-bzlmod/MODULE.bazel b/bazel/example/using-bzlmod/MODULE.bazel new file mode 100644 index 00000000..d6099a81 --- /dev/null +++ b/bazel/example/using-bzlmod/MODULE.bazel @@ -0,0 +1,24 @@ +bazel_dep( + name = "p4runtime", + repo_name = "com_github_p4lang_p4runtime", +) + +# In your own project, you will likely want to use `http_archive` instead +# of `local_repository` to load p4runtime. +local_path_override( + module_name = "p4runtime", + path = "../../../proto", +) + +# git_override( +# module_name = "p4runtime", +# strip_prefix = "p4runtime-1.4.1/proto", +# urls = ["https://github.com/p4lang/p4runtime/archive/v1.4.1.tar.gz"], +# # sha256 = "", +# ) + +bazel_dep( + name = "protobuf", + version = "29.1", + repo_name = "com_google_protobuf", +) diff --git a/bazel/example/hello_p4runtime.cc b/bazel/example/using-bzlmod/hello_p4runtime.cc similarity index 100% rename from bazel/example/hello_p4runtime.cc rename to bazel/example/using-bzlmod/hello_p4runtime.cc diff --git a/bazel/example/.bazelrc b/bazel/example/using-workspace/.bazelrc similarity index 67% rename from bazel/example/.bazelrc rename to bazel/example/using-workspace/.bazelrc index 4fea8e53..e408f4d8 100644 --- a/bazel/example/.bazelrc +++ b/bazel/example/using-workspace/.bazelrc @@ -1,4 +1,4 @@ -# Flip when we add Bzlmod support (#518). +# Use `WORKSPACE.bazel` instead of bzlmod (`MODULE.bazel`). common --enable_workspace common --noenable_bzlmod diff --git a/bazel/example/.bazelversion b/bazel/example/using-workspace/.bazelversion similarity index 100% rename from bazel/example/.bazelversion rename to bazel/example/using-workspace/.bazelversion diff --git a/bazel/example/using-workspace/BUILD.bazel b/bazel/example/using-workspace/BUILD.bazel new file mode 100644 index 00000000..5c8067b6 --- /dev/null +++ b/bazel/example/using-workspace/BUILD.bazel @@ -0,0 +1,8 @@ +cc_binary( + name = "hello_p4runtime", + srcs = ["hello_p4runtime.cc"], + deps = [ + "@com_github_p4lang_p4runtime//:p4info_cc_proto", + "@com_google_protobuf//:protobuf", + ] +) diff --git a/bazel/example/WORKSPACE.bazel b/bazel/example/using-workspace/WORKSPACE.bazel similarity index 98% rename from bazel/example/WORKSPACE.bazel rename to bazel/example/using-workspace/WORKSPACE.bazel index 074d6ed2..35a8ae1b 100644 --- a/bazel/example/WORKSPACE.bazel +++ b/bazel/example/using-workspace/WORKSPACE.bazel @@ -5,7 +5,7 @@ load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive") # of `local_repository` to load p4runtime. local_repository( name = "com_github_p4lang_p4runtime", - path = "../../proto", + path = "../../../proto", ) # http_archive( # name = "com_github_p4lang_p4runtime", diff --git a/bazel/example/using-workspace/hello_p4runtime.cc b/bazel/example/using-workspace/hello_p4runtime.cc new file mode 100644 index 00000000..779c2f3d --- /dev/null +++ b/bazel/example/using-workspace/hello_p4runtime.cc @@ -0,0 +1,21 @@ +#include + +#include "google/protobuf/text_format.h" +#include "p4/config/v1/p4info.pb.h" + +using ::google::protobuf::TextFormat; +using ::p4::config::v1::P4Info; + +int main() { + P4Info p4info; + TextFormat::ParseFromString(R"PROTO( + tables { + preamble { + id: 10 + name: "Hello, P4Runtime!" + } + } + )PROTO", &p4info); + p4info.mutable_tables()->at(0).mutable_preamble()->set_id(42); + std::cout << p4info.DebugString(); +} diff --git a/proto/.bazelrc b/proto/.bazelrc index 4fea8e53..10d71bba 100644 --- a/proto/.bazelrc +++ b/proto/.bazelrc @@ -1,6 +1,6 @@ -# Flip when we add Bzlmod support (#518). -common --enable_workspace -common --noenable_bzlmod +# Use Bzlmod. +common --enable_bzlmod +common --noenable_workspace # C++14 required for recent gRPC versions build --cxxopt='-std=c++14' diff --git a/proto/.bazelversion b/proto/.bazelversion deleted file mode 100644 index 815da58b..00000000 --- a/proto/.bazelversion +++ /dev/null @@ -1 +0,0 @@ -7.4.1 diff --git a/proto/MODULE.bazel b/proto/MODULE.bazel new file mode 100644 index 00000000..67dba860 --- /dev/null +++ b/proto/MODULE.bazel @@ -0,0 +1,35 @@ +module( + name = "p4runtime", + bazel_compatibility = [">=7.4.1"], + repo_name = "com_github_p4lang_p4runtime", +) + +bazel_dep(name = "bazel_skylib", version = "1.7.1") +bazel_dep( + name = "googleapis", + version = "0.0.0-20240819-fe8ba054a", + repo_name = "com_google_googleapis", +) + +switched_rules = use_extension("@com_google_googleapis//:extensions.bzl", "switched_rules") +switched_rules.use_languages( + cc = True, + go = True, + grpc = True, + python = True, +) +use_repo(switched_rules, "com_google_googleapis_imports") + +bazel_dep(name = "grpc", version = "1.68.0", repo_name = "com_github_grpc_grpc") +bazel_dep( + name = "protobuf", + version = "29.1", + repo_name = "com_google_protobuf", +) +bazel_dep(name = "rules_license", version = "1.0.0") +bazel_dep(name = "rules_proto", version = "7.0.2") +bazel_dep( + name = "rules_go", + version = "0.50.1", + repo_name = "io_bazel_rules_go", +) diff --git a/proto/WORKSPACE.bzlmod b/proto/WORKSPACE.bzlmod new file mode 100644 index 00000000..203f54c6 --- /dev/null +++ b/proto/WORKSPACE.bzlmod @@ -0,0 +1,5 @@ +# https://bazel.build/external/migration#workspace.bzlmod +# +# This file is intentionally empty. When bzlmod is enabled and this +# file exists, the contents of WORKSPACE.bazel is ignored. This prevents +# bzlmod builds from unintentionally depending on the WORKSPACE.bazel file.