You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@brpc.apache.org by ww...@apache.org on 2022/12/06 05:58:25 UTC
[incubator-brpc] branch master updated: add bazel third_party support (#1996)
This is an automated email from the ASF dual-hosted git repository.
wwbmmm pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/incubator-brpc.git
The following commit(s) were added to refs/heads/master by this push:
new 0aa1cf18 add bazel third_party support (#1996)
0aa1cf18 is described below
commit 0aa1cf183125215cffe726d53749f326f6cdd120
Author: fan <75...@users.noreply.github.com>
AuthorDate: Tue Dec 6 13:58:19 2022 +0800
add bazel third_party support (#1996)
* add bazel support
* remove bind
* update
* update
* update
* update doc
* fix rdma bazel build
* update
---
.bazelignore | 1 +
docs/cn/bazel_support.md | 20 ++
docs/en/bazel_support.md | 20 ++
example/build_with_bazel/BUILD.bazel | 29 ++
example/build_with_bazel/WORKSPACE | 21 ++
example/build_with_bazel/brpc_workspace.bzl | 94 ++++++
example/build_with_bazel/leveldb.BUILD | 97 ++++++
example/build_with_bazel/openssl.BUILD | 56 ++++
example/build_with_bazel/protobuf.BUILD | 498 ++++++++++++++++++++++++++++
example/build_with_bazel/test.cc | 30 ++
example/build_with_bazel/zlib.BUILD | 110 ++++++
example/rdma_performance/client.cpp | 11 +
example/rdma_performance/server.cpp | 13 +
13 files changed, 1000 insertions(+)
diff --git a/.bazelignore b/.bazelignore
new file mode 100644
index 00000000..c19cecab
--- /dev/null
+++ b/.bazelignore
@@ -0,0 +1 @@
+./example/build_with_bazel
\ No newline at end of file
diff --git a/docs/cn/bazel_support.md b/docs/cn/bazel_support.md
new file mode 100644
index 00000000..0ff86119
--- /dev/null
+++ b/docs/cn/bazel_support.md
@@ -0,0 +1,20 @@
+## bRPC 作为Bazel第三方依赖
+1. bRPC 依赖于一些开源库, 但这些库并没有提供bazel支持, 所以需要你手动将一部分依赖加入到你的构建项目中.
+2. 将 /example/build_with_bazel/*.BUILD 和 brpc_workspace.bzl 该文件移动到你的项目根目录下, 将
+```c++
+ load("@//:brpc_workspace.bzl", "brpc_workspace")
+ brpc_workspace();
+```
+内容添加到你的WORKSPACE中.
+
+3. 链接请使用
+ ```c++
+ ...
+ deps = [
+ "@apache_brpc//:bthread",
+ "@apache_brpc//:brpc",
+ "@apache_brpc//:butil",
+ "@apache_brpc//:bvar",
+ ]
+ ...
+ ```
diff --git a/docs/en/bazel_support.md b/docs/en/bazel_support.md
new file mode 100644
index 00000000..607cf9c4
--- /dev/null
+++ b/docs/en/bazel_support.md
@@ -0,0 +1,20 @@
+## bRPC as a Bazel third-party dependency
+1. bRPC relies on a number of open source libraries that do not provide bazel support, so you will need to manually add some of these dependencies to your build project.
+2. Move the BUILD file /example/build_with_bazel/*.BUILD and brpc_workspace.bzl to the root of your project, and add the contents of
+```c++
+ load("@//:brpc_workspace.bzl", "brpc_workspace")
+ brpc_workspace();
+```
+to your WORKSPACE
+
+3. link apache_brpc like:
+ ```c++
+ ...
+ deps = [
+ "@apache_brpc//:bthread",
+ "@apache_brpc//:brpc",
+ "@apache_brpc//:butil",
+ "@apache_brpc//:bvar",
+ ]
+ ...
+ ```
diff --git a/example/build_with_bazel/BUILD.bazel b/example/build_with_bazel/BUILD.bazel
new file mode 100644
index 00000000..9ac3da0c
--- /dev/null
+++ b/example/build_with_bazel/BUILD.bazel
@@ -0,0 +1,29 @@
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+# Thie empty BUILD.bazel file is required to make Bazel treat
+# this directory as a package.
+
+
+cc_binary(
+ name = "test",
+ srcs = ["test.cc"],
+ deps = [
+ "@apache_brpc//:brpc",
+ "@apache_brpc//:bthread",
+ "@apache_brpc//:bvar",
+ "@apache_brpc//:butil",
+ ],
+)
diff --git a/example/build_with_bazel/WORKSPACE b/example/build_with_bazel/WORKSPACE
new file mode 100644
index 00000000..9754258e
--- /dev/null
+++ b/example/build_with_bazel/WORKSPACE
@@ -0,0 +1,21 @@
+# Licensed to the Apache Software Foundation (ASF) under one
+# or more contributor license agreements. See the NOTICE file
+# distributed with this work for additional information
+# regarding copyright ownership. The ASF licenses this file
+# to you under the Apache License, Version 2.0 (the
+# "License"); you may not use this file except in compliance
+# with the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing,
+# software distributed under the License is distributed on an
+# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+# KIND, either express or implied. See the License for the
+# specific language governing permissions and limitations
+# under the License.
+
+workspace(name = "brpc_test")
+
+load("@//:brpc_workspace.bzl", "brpc_workspace")
+brpc_workspace();
\ No newline at end of file
diff --git a/example/build_with_bazel/brpc_workspace.bzl b/example/build_with_bazel/brpc_workspace.bzl
new file mode 100644
index 00000000..137de876
--- /dev/null
+++ b/example/build_with_bazel/brpc_workspace.bzl
@@ -0,0 +1,94 @@
+# Licensed to the Apache Software Foundation (ASF) under one
+# or more contributor license agreements. See the NOTICE file
+# distributed with this work for additional information
+# regarding copyright ownership. The ASF licenses this file
+# to you under the Apache License, Version 2.0 (the
+# "License"); you may not use this file except in compliance
+# with the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing,
+# software distributed under the License is distributed on an
+# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+# KIND, either express or implied. See the License for the
+# specific language governing permissions and limitations
+# under the License.
+
+
+load("@bazel_tools//tools/build_defs/repo:git.bzl", "git_repository", "new_git_repository")
+load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive")
+
+
+BAZEL_SKYLIB_VERSION = "1.1.1" # 2021-09-27T17:33:49Z
+
+BAZEL_SKYLIB_SHA256 = "c6966ec828da198c5d9adbaa94c05e3a1c7f21bd012a0b29ba8ddbccb2c93b0d"
+
+def brpc_workspace():
+ http_archive(
+ name = "bazel_skylib",
+ sha256 = BAZEL_SKYLIB_SHA256,
+ urls = [
+ "https://github.com/bazelbuild/bazel-skylib/releases/download/{version}/bazel-skylib-{version}.tar.gz".format(version = BAZEL_SKYLIB_VERSION),
+ "https://mirror.bazel.build/github.com/bazelbuild/bazel-skylib/releases/download/{version}/bazel-skylib-{version}.tar.gz".format(version = BAZEL_SKYLIB_VERSION),
+ ],
+ )
+
+ http_archive(
+ name = "com_google_protobuf", # 2021-10-29T00:04:02Z
+ build_file = "//:protobuf.BUILD",
+ patch_cmds = [
+ "sed -i protobuf.bzl -re '4,4d;417,508d'",
+ ],
+ patch_cmds_win = [
+ """$content = Get-Content 'protobuf.bzl' | Where-Object {
+ -not ($_.ReadCount -ne 4) -and
+ -not ($_.ReadCount -ge 418 -and $_.ReadCount -le 509)
+ }
+ Set-Content protobuf.bzl -Value $content -Encoding UTF8
+ """,
+ ],
+ sha256 = "87407cd28e7a9c95d9f61a098a53cf031109d451a7763e7dd1253abf8b4df422",
+ strip_prefix = "protobuf-3.19.1",
+ urls = ["https://github.com/protocolbuffers/protobuf/archive/refs/tags/v3.19.1.tar.gz"],
+ )
+
+
+ http_archive(
+ name = "com_github_google_leveldb",
+ build_file = "//:leveldb.BUILD",
+ strip_prefix = "leveldb-a53934a3ae1244679f812d998a4f16f2c7f309a6",
+ url = "https://github.com/google/leveldb/archive/a53934a3ae1244679f812d998a4f16f2c7f309a6.tar.gz"
+ )
+
+
+
+ http_archive(
+ name = "com_github_madler_zlib", # 2017-01-15T17:57:23Z
+ build_file = "//:zlib.BUILD",
+ sha256 = "c3e5e9fdd5004dcb542feda5ee4f0ff0744628baf8ed2dd5d66f8ca1197cb1a1",
+ strip_prefix = "zlib-1.2.11",
+ urls = [
+ "https://downloads.sourceforge.net/project/libpng/zlib/1.2.11/zlib-1.2.11.tar.gz",
+ "https://zlib.net/fossils/zlib-1.2.11.tar.gz",
+ ],
+ )
+
+ native.new_local_repository(
+ name = "openssl",
+ path = "/usr",
+ build_file = "//:openssl.BUILD",
+ )
+
+ http_archive(
+ name = "com_github_gflags_gflags",
+ strip_prefix = "gflags-46f73f88b18aee341538c0dfc22b1710a6abedef",
+ url = "https://github.com/gflags/gflags/archive/46f73f88b18aee341538c0dfc22b1710a6abedef.tar.gz",
+ )
+
+ http_archive(
+ name = "apache_brpc",
+ strip_prefix = "incubator-brpc-1.3.0",
+ url = "https://github.com/apache/incubator-brpc/archive/refs/tags/1.3.0.tar.gz"
+ )
+
diff --git a/example/build_with_bazel/leveldb.BUILD b/example/build_with_bazel/leveldb.BUILD
new file mode 100644
index 00000000..369841e1
--- /dev/null
+++ b/example/build_with_bazel/leveldb.BUILD
@@ -0,0 +1,97 @@
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+package(default_visibility = ["//visibility:public"])
+
+
+config_setting(
+ name = "darwin",
+ values = {"cpu": "darwin"},
+ visibility = ["//visibility:public"],
+)
+
+SOURCES = ["db/builder.cc",
+ "db/c.cc",
+ "db/dbformat.cc",
+ "db/db_impl.cc",
+ "db/db_iter.cc",
+ "db/dumpfile.cc",
+ "db/filename.cc",
+ "db/log_reader.cc",
+ "db/log_writer.cc",
+ "db/memtable.cc",
+ "db/repair.cc",
+ "db/table_cache.cc",
+ "db/version_edit.cc",
+ "db/version_set.cc",
+ "db/write_batch.cc",
+ "table/block_builder.cc",
+ "table/block.cc",
+ "table/filter_block.cc",
+ "table/format.cc",
+ "table/iterator.cc",
+ "table/merger.cc",
+ "table/table_builder.cc",
+ "table/table.cc",
+ "table/two_level_iterator.cc",
+ "util/arena.cc",
+ "util/bloom.cc",
+ "util/cache.cc",
+ "util/coding.cc",
+ "util/comparator.cc",
+ "util/crc32c.cc",
+ "util/env.cc",
+ "util/env_posix.cc",
+ "util/filter_policy.cc",
+ "util/hash.cc",
+ "util/histogram.cc",
+ "util/logging.cc",
+ "util/options.cc",
+ "util/status.cc",
+ "port/port_posix.cc",
+ "port/port_posix_sse.cc",
+ "helpers/memenv/memenv.cc",
+ ]
+
+cc_library(
+ name = "leveldb",
+ srcs = SOURCES,
+ hdrs = glob([
+ "helpers/memenv/*.h",
+ "util/*.h",
+ "port/*.h",
+ "port/win/*.h",
+ "table/*.h",
+ "db/*.h",
+ "include/leveldb/*.h"
+ ],
+ exclude = [
+ "**/*test.*",
+ ]),
+ includes = [
+ "include/",
+ ],
+ copts = [
+ "-fno-builtin-memcmp",
+ "-DLEVELDB_PLATFORM_POSIX=1",
+ "-DLEVELDB_ATOMIC_PRESENT",
+ ],
+ defines = [
+ "LEVELDB_PLATFORM_POSIX",
+ ] + select({
+ ":darwin": ["OS_MACOSX"],
+ "//conditions:default": [],
+ }),
+)
\ No newline at end of file
diff --git a/example/build_with_bazel/openssl.BUILD b/example/build_with_bazel/openssl.BUILD
new file mode 100644
index 00000000..117144ca
--- /dev/null
+++ b/example/build_with_bazel/openssl.BUILD
@@ -0,0 +1,56 @@
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+package(
+ default_visibility=["//visibility:public"]
+)
+
+config_setting(
+ name = "macos",
+ values = {
+ "cpu": "darwin",
+ },
+ visibility = ["//visibility:private"],
+)
+
+cc_library(
+ name = "crypto",
+ srcs = select({
+ ":macos": ["lib/libcrypto.dylib"],
+ "//conditions:default": []
+ }),
+ linkopts = select({
+ ":macos" : [],
+ "//conditions:default": ["-lcrypto"],
+ }),
+)
+
+cc_library(
+ name = "ssl",
+ hdrs = select({
+ ":macos": glob(["include/openssl/*.h"]),
+ "//conditions:default": []
+ }),
+ srcs = select ({
+ ":macos": ["lib/libssl.dylib"],
+ "//conditions:default": []
+ }),
+ includes = ["include"],
+ linkopts = select({
+ ":macos" : [],
+ "//conditions:default": ["-lssl"],
+ }),
+ deps = [":crypto"]
+)
\ No newline at end of file
diff --git a/example/build_with_bazel/protobuf.BUILD b/example/build_with_bazel/protobuf.BUILD
new file mode 100644
index 00000000..0d5188ea
--- /dev/null
+++ b/example/build_with_bazel/protobuf.BUILD
@@ -0,0 +1,498 @@
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+# Copyright 2008 Google Inc. All rights reserved.
+#
+# Redistribution and use in source and binary forms, with or without
+# modification, are permitted provided that the following conditions are
+# met:
+#
+# * Redistributions of source code must retain the above copyright
+# notice, this list of conditions and the following disclaimer.
+# * Redistributions in binary form must reproduce the above
+# copyright notice, this list of conditions and the following disclaimer
+# in the documentation and/or other materials provided with the
+# distribution.
+# * Neither the name of Google Inc. nor the names of its
+# contributors may be used to endorse or promote products derived from
+# this software without specific prior written permission.
+#
+# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+# Copied from https://github.com/protocolbuffers/protobuf/blob/v3.19.1/BUILD
+#
+# Modifications:
+# 1. Remove all non-cxx rules.
+# 2. Remove android support.
+# 3. zlib use @com_github_madler_zlib//:zlib
+
+# Bazel (https://bazel.build/) BUILD file for Protobuf.
+
+load("@rules_cc//cc:defs.bzl", "cc_binary", "cc_library", native_cc_proto_library = "cc_proto_library")
+load("@rules_proto//proto:defs.bzl", "proto_lang_toolchain", "proto_library")
+load(":compiler_config_setting.bzl", "create_compiler_config_setting")
+load(
+ ":protobuf.bzl",
+ "adapt_proto_library",
+)
+
+licenses(["notice"])
+
+exports_files(["LICENSE"])
+
+################################################################################
+# build configuration
+################################################################################
+
+################################################################################
+# ZLIB configuration
+################################################################################
+
+ZLIB_DEPS = ["@com_github_madler_zlib//:zlib"]
+
+################################################################################
+# Protobuf Runtime Library
+################################################################################
+
+MSVC_COPTS = [
+ "/wd4018", # -Wno-sign-compare
+ "/wd4065", # switch statement contains 'default' but no 'case' labels
+ "/wd4146", # unary minus operator applied to unsigned type, result still unsigned
+ "/wd4244", # 'conversion' conversion from 'type1' to 'type2', possible loss of data
+ "/wd4251", # 'identifier' : class 'type' needs to have dll-interface to be used by clients of class 'type2'
+ "/wd4267", # 'var' : conversion from 'size_t' to 'type', possible loss of data
+ "/wd4305", # 'identifier' : truncation from 'type1' to 'type2'
+ "/wd4307", # 'operator' : integral constant overflow
+ "/wd4309", # 'conversion' : truncation of constant value
+ "/wd4334", # 'operator' : result of 32-bit shift implicitly converted to 64 bits (was 64-bit shift intended?)
+ "/wd4355", # 'this' : used in base member initializer list
+ "/wd4506", # no definition for inline function 'function'
+ "/wd4800", # 'type' : forcing value to bool 'true' or 'false' (performance warning)
+ "/wd4996", # The compiler encountered a deprecated declaration.
+]
+
+COPTS = select({
+ ":msvc": MSVC_COPTS,
+ "//conditions:default": [
+ "-DHAVE_ZLIB",
+ "-Wmissing-field-initializers",
+ "-Woverloaded-virtual",
+ "-Wno-sign-compare",
+ ],
+})
+
+create_compiler_config_setting(
+ name = "msvc",
+ value = "msvc-cl",
+ visibility = [
+ # Public, but Protobuf only visibility.
+ "//:__subpackages__",
+ ],
+)
+
+# Android and MSVC builds do not need to link in a separate pthread library.
+LINK_OPTS = select({
+ ":msvc": [
+ # Suppress linker warnings about files with no symbols defined.
+ "-ignore:4221",
+ ],
+ "//conditions:default": [
+ "-lpthread",
+ "-lm",
+ ],
+})
+
+cc_library(
+ name = "protobuf_lite",
+ srcs = [
+ # AUTOGEN(protobuf_lite_srcs)
+ "src/google/protobuf/any_lite.cc",
+ "src/google/protobuf/arena.cc",
+ "src/google/protobuf/arenastring.cc",
+ "src/google/protobuf/extension_set.cc",
+ "src/google/protobuf/generated_enum_util.cc",
+ "src/google/protobuf/generated_message_table_driven_lite.cc",
+ "src/google/protobuf/generated_message_tctable_lite.cc",
+ "src/google/protobuf/generated_message_util.cc",
+ "src/google/protobuf/implicit_weak_message.cc",
+ "src/google/protobuf/inlined_string_field.cc",
+ "src/google/protobuf/io/coded_stream.cc",
+ "src/google/protobuf/io/io_win32.cc",
+ "src/google/protobuf/io/strtod.cc",
+ "src/google/protobuf/io/zero_copy_stream.cc",
+ "src/google/protobuf/io/zero_copy_stream_impl.cc",
+ "src/google/protobuf/io/zero_copy_stream_impl_lite.cc",
+ "src/google/protobuf/map.cc",
+ "src/google/protobuf/message_lite.cc",
+ "src/google/protobuf/parse_context.cc",
+ "src/google/protobuf/repeated_field.cc",
+ "src/google/protobuf/repeated_ptr_field.cc",
+ "src/google/protobuf/stubs/bytestream.cc",
+ "src/google/protobuf/stubs/common.cc",
+ "src/google/protobuf/stubs/int128.cc",
+ "src/google/protobuf/stubs/status.cc",
+ "src/google/protobuf/stubs/statusor.cc",
+ "src/google/protobuf/stubs/stringpiece.cc",
+ "src/google/protobuf/stubs/stringprintf.cc",
+ "src/google/protobuf/stubs/structurally_valid.cc",
+ "src/google/protobuf/stubs/strutil.cc",
+ "src/google/protobuf/stubs/time.cc",
+ "src/google/protobuf/wire_format_lite.cc",
+ ],
+ hdrs = glob([
+ "src/google/protobuf/**/*.h",
+ "src/google/protobuf/**/*.inc",
+ ]),
+ copts = COPTS,
+ includes = ["src/"],
+ linkopts = LINK_OPTS,
+ visibility = ["//visibility:public"],
+)
+
+PROTOBUF_DEPS = select({
+ ":msvc": [],
+ "//conditions:default": ZLIB_DEPS,
+})
+
+cc_library(
+ name = "protobuf",
+ srcs = [
+ # AUTOGEN(protobuf_srcs)
+ "src/google/protobuf/any.cc",
+ "src/google/protobuf/any.pb.cc",
+ "src/google/protobuf/api.pb.cc",
+ "src/google/protobuf/compiler/importer.cc",
+ "src/google/protobuf/compiler/parser.cc",
+ "src/google/protobuf/descriptor.cc",
+ "src/google/protobuf/descriptor.pb.cc",
+ "src/google/protobuf/descriptor_database.cc",
+ "src/google/protobuf/duration.pb.cc",
+ "src/google/protobuf/dynamic_message.cc",
+ "src/google/protobuf/empty.pb.cc",
+ "src/google/protobuf/extension_set_heavy.cc",
+ "src/google/protobuf/field_mask.pb.cc",
+ "src/google/protobuf/generated_message_bases.cc",
+ "src/google/protobuf/generated_message_reflection.cc",
+ "src/google/protobuf/generated_message_table_driven.cc",
+ "src/google/protobuf/generated_message_tctable_full.cc",
+ "src/google/protobuf/io/gzip_stream.cc",
+ "src/google/protobuf/io/printer.cc",
+ "src/google/protobuf/io/tokenizer.cc",
+ "src/google/protobuf/map_field.cc",
+ "src/google/protobuf/message.cc",
+ "src/google/protobuf/reflection_ops.cc",
+ "src/google/protobuf/service.cc",
+ "src/google/protobuf/source_context.pb.cc",
+ "src/google/protobuf/struct.pb.cc",
+ "src/google/protobuf/stubs/substitute.cc",
+ "src/google/protobuf/text_format.cc",
+ "src/google/protobuf/timestamp.pb.cc",
+ "src/google/protobuf/type.pb.cc",
+ "src/google/protobuf/unknown_field_set.cc",
+ "src/google/protobuf/util/delimited_message_util.cc",
+ "src/google/protobuf/util/field_comparator.cc",
+ "src/google/protobuf/util/field_mask_util.cc",
+ "src/google/protobuf/util/internal/datapiece.cc",
+ "src/google/protobuf/util/internal/default_value_objectwriter.cc",
+ "src/google/protobuf/util/internal/error_listener.cc",
+ "src/google/protobuf/util/internal/field_mask_utility.cc",
+ "src/google/protobuf/util/internal/json_escaping.cc",
+ "src/google/protobuf/util/internal/json_objectwriter.cc",
+ "src/google/protobuf/util/internal/json_stream_parser.cc",
+ "src/google/protobuf/util/internal/object_writer.cc",
+ "src/google/protobuf/util/internal/proto_writer.cc",
+ "src/google/protobuf/util/internal/protostream_objectsource.cc",
+ "src/google/protobuf/util/internal/protostream_objectwriter.cc",
+ "src/google/protobuf/util/internal/type_info.cc",
+ "src/google/protobuf/util/internal/utility.cc",
+ "src/google/protobuf/util/json_util.cc",
+ "src/google/protobuf/util/message_differencer.cc",
+ "src/google/protobuf/util/time_util.cc",
+ "src/google/protobuf/util/type_resolver_util.cc",
+ "src/google/protobuf/wire_format.cc",
+ "src/google/protobuf/wrappers.pb.cc",
+ ],
+ hdrs = glob([
+ "src/**/*.h",
+ "src/**/*.inc",
+ ]),
+ copts = COPTS,
+ includes = ["src/"],
+ linkopts = LINK_OPTS,
+ visibility = ["//visibility:public"],
+ deps = [":protobuf_lite"] + PROTOBUF_DEPS,
+)
+
+# This provides just the header files for use in projects that need to build
+# shared libraries for dynamic loading. This target is available until Bazel
+# adds native support for such use cases.
+# TODO(keveman): Remove this target once the support gets added to Bazel.
+cc_library(
+ name = "protobuf_headers",
+ hdrs = glob([
+ "src/**/*.h",
+ "src/**/*.inc",
+ ]),
+ includes = ["src/"],
+ visibility = ["//visibility:public"],
+)
+
+# Map of all well known protos.
+# name => (include path, imports)
+WELL_KNOWN_PROTO_MAP = {
+ "any": ("src/google/protobuf/any.proto", []),
+ "api": (
+ "src/google/protobuf/api.proto",
+ [
+ "source_context",
+ "type",
+ ],
+ ),
+ "compiler_plugin": (
+ "src/google/protobuf/compiler/plugin.proto",
+ ["descriptor"],
+ ),
+ "descriptor": ("src/google/protobuf/descriptor.proto", []),
+ "duration": ("src/google/protobuf/duration.proto", []),
+ "empty": ("src/google/protobuf/empty.proto", []),
+ "field_mask": ("src/google/protobuf/field_mask.proto", []),
+ "source_context": ("src/google/protobuf/source_context.proto", []),
+ "struct": ("src/google/protobuf/struct.proto", []),
+ "timestamp": ("src/google/protobuf/timestamp.proto", []),
+ "type": (
+ "src/google/protobuf/type.proto",
+ [
+ "any",
+ "source_context",
+ ],
+ ),
+ "wrappers": ("src/google/protobuf/wrappers.proto", []),
+}
+
+WELL_KNOWN_PROTOS = [value[0] for value in WELL_KNOWN_PROTO_MAP.values()]
+
+LITE_WELL_KNOWN_PROTO_MAP = {
+ "any": ("src/google/protobuf/any.proto", []),
+ "api": (
+ "src/google/protobuf/api.proto",
+ [
+ "source_context",
+ "type",
+ ],
+ ),
+ "duration": ("src/google/protobuf/duration.proto", []),
+ "empty": ("src/google/protobuf/empty.proto", []),
+ "field_mask": ("src/google/protobuf/field_mask.proto", []),
+ "source_context": ("src/google/protobuf/source_context.proto", []),
+ "struct": ("src/google/protobuf/struct.proto", []),
+ "timestamp": ("src/google/protobuf/timestamp.proto", []),
+ "type": (
+ "src/google/protobuf/type.proto",
+ [
+ "any",
+ "source_context",
+ ],
+ ),
+ "wrappers": ("src/google/protobuf/wrappers.proto", []),
+}
+
+LITE_WELL_KNOWN_PROTOS = [value[0] for value in LITE_WELL_KNOWN_PROTO_MAP.values()]
+
+filegroup(
+ name = "well_known_protos",
+ srcs = WELL_KNOWN_PROTOS,
+ visibility = ["//visibility:public"],
+)
+
+filegroup(
+ name = "lite_well_known_protos",
+ srcs = LITE_WELL_KNOWN_PROTOS,
+ visibility = ["//visibility:public"],
+)
+
+adapt_proto_library(
+ name = "cc_wkt_protos_genproto",
+ visibility = ["//visibility:public"],
+ deps = [proto + "_proto" for proto in WELL_KNOWN_PROTO_MAP.keys()],
+)
+
+cc_library(
+ name = "cc_wkt_protos",
+ deprecation = "Only for backward compatibility. Do not use.",
+ visibility = ["//visibility:public"],
+)
+
+################################################################################
+# Well Known Types Proto Library Rules
+#
+# These proto_library rules can be used with one of the language specific proto
+# library rules i.e. java_proto_library:
+#
+# java_proto_library(
+# name = "any_java_proto",
+# deps = ["@com_google_protobuf//:any_proto],
+# )
+################################################################################
+
+[proto_library(
+ name = proto[0] + "_proto",
+ srcs = [proto[1][0]],
+ strip_import_prefix = "src",
+ visibility = ["//visibility:public"],
+ deps = [dep + "_proto" for dep in proto[1][1]],
+) for proto in WELL_KNOWN_PROTO_MAP.items()]
+
+[native_cc_proto_library(
+ name = proto + "_cc_proto",
+ visibility = ["//visibility:private"],
+ deps = [proto + "_proto"],
+) for proto in WELL_KNOWN_PROTO_MAP.keys()]
+
+################################################################################
+# Protocol Buffers Compiler
+################################################################################
+
+cc_library(
+ name = "protoc_lib",
+ srcs = [
+ # AUTOGEN(protoc_lib_srcs)
+ "src/google/protobuf/compiler/code_generator.cc",
+ "src/google/protobuf/compiler/command_line_interface.cc",
+ "src/google/protobuf/compiler/cpp/cpp_enum.cc",
+ "src/google/protobuf/compiler/cpp/cpp_enum_field.cc",
+ "src/google/protobuf/compiler/cpp/cpp_extension.cc",
+ "src/google/protobuf/compiler/cpp/cpp_field.cc",
+ "src/google/protobuf/compiler/cpp/cpp_file.cc",
+ "src/google/protobuf/compiler/cpp/cpp_generator.cc",
+ "src/google/protobuf/compiler/cpp/cpp_helpers.cc",
+ "src/google/protobuf/compiler/cpp/cpp_map_field.cc",
+ "src/google/protobuf/compiler/cpp/cpp_message.cc",
+ "src/google/protobuf/compiler/cpp/cpp_message_field.cc",
+ "src/google/protobuf/compiler/cpp/cpp_padding_optimizer.cc",
+ "src/google/protobuf/compiler/cpp/cpp_parse_function_generator.cc",
+ "src/google/protobuf/compiler/cpp/cpp_primitive_field.cc",
+ "src/google/protobuf/compiler/cpp/cpp_service.cc",
+ "src/google/protobuf/compiler/cpp/cpp_string_field.cc",
+ "src/google/protobuf/compiler/csharp/csharp_doc_comment.cc",
+ "src/google/protobuf/compiler/csharp/csharp_enum.cc",
+ "src/google/protobuf/compiler/csharp/csharp_enum_field.cc",
+ "src/google/protobuf/compiler/csharp/csharp_field_base.cc",
+ "src/google/protobuf/compiler/csharp/csharp_generator.cc",
+ "src/google/protobuf/compiler/csharp/csharp_helpers.cc",
+ "src/google/protobuf/compiler/csharp/csharp_map_field.cc",
+ "src/google/protobuf/compiler/csharp/csharp_message.cc",
+ "src/google/protobuf/compiler/csharp/csharp_message_field.cc",
+ "src/google/protobuf/compiler/csharp/csharp_primitive_field.cc",
+ "src/google/protobuf/compiler/csharp/csharp_reflection_class.cc",
+ "src/google/protobuf/compiler/csharp/csharp_repeated_enum_field.cc",
+ "src/google/protobuf/compiler/csharp/csharp_repeated_message_field.cc",
+ "src/google/protobuf/compiler/csharp/csharp_repeated_primitive_field.cc",
+ "src/google/protobuf/compiler/csharp/csharp_source_generator_base.cc",
+ "src/google/protobuf/compiler/csharp/csharp_wrapper_field.cc",
+ "src/google/protobuf/compiler/java/java_context.cc",
+ "src/google/protobuf/compiler/java/java_doc_comment.cc",
+ "src/google/protobuf/compiler/java/java_enum.cc",
+ "src/google/protobuf/compiler/java/java_enum_field.cc",
+ "src/google/protobuf/compiler/java/java_enum_field_lite.cc",
+ "src/google/protobuf/compiler/java/java_enum_lite.cc",
+ "src/google/protobuf/compiler/java/java_extension.cc",
+ "src/google/protobuf/compiler/java/java_extension_lite.cc",
+ "src/google/protobuf/compiler/java/java_field.cc",
+ "src/google/protobuf/compiler/java/java_file.cc",
+ "src/google/protobuf/compiler/java/java_generator.cc",
+ "src/google/protobuf/compiler/java/java_generator_factory.cc",
+ "src/google/protobuf/compiler/java/java_helpers.cc",
+ "src/google/protobuf/compiler/java/java_kotlin_generator.cc",
+ "src/google/protobuf/compiler/java/java_map_field.cc",
+ "src/google/protobuf/compiler/java/java_map_field_lite.cc",
+ "src/google/protobuf/compiler/java/java_message.cc",
+ "src/google/protobuf/compiler/java/java_message_builder.cc",
+ "src/google/protobuf/compiler/java/java_message_builder_lite.cc",
+ "src/google/protobuf/compiler/java/java_message_field.cc",
+ "src/google/protobuf/compiler/java/java_message_field_lite.cc",
+ "src/google/protobuf/compiler/java/java_message_lite.cc",
+ "src/google/protobuf/compiler/java/java_name_resolver.cc",
+ "src/google/protobuf/compiler/java/java_primitive_field.cc",
+ "src/google/protobuf/compiler/java/java_primitive_field_lite.cc",
+ "src/google/protobuf/compiler/java/java_service.cc",
+ "src/google/protobuf/compiler/java/java_shared_code_generator.cc",
+ "src/google/protobuf/compiler/java/java_string_field.cc",
+ "src/google/protobuf/compiler/java/java_string_field_lite.cc",
+ "src/google/protobuf/compiler/js/js_generator.cc",
+ "src/google/protobuf/compiler/js/well_known_types_embed.cc",
+ "src/google/protobuf/compiler/objectivec/objectivec_enum.cc",
+ "src/google/protobuf/compiler/objectivec/objectivec_enum_field.cc",
+ "src/google/protobuf/compiler/objectivec/objectivec_extension.cc",
+ "src/google/protobuf/compiler/objectivec/objectivec_field.cc",
+ "src/google/protobuf/compiler/objectivec/objectivec_file.cc",
+ "src/google/protobuf/compiler/objectivec/objectivec_generator.cc",
+ "src/google/protobuf/compiler/objectivec/objectivec_helpers.cc",
+ "src/google/protobuf/compiler/objectivec/objectivec_map_field.cc",
+ "src/google/protobuf/compiler/objectivec/objectivec_message.cc",
+ "src/google/protobuf/compiler/objectivec/objectivec_message_field.cc",
+ "src/google/protobuf/compiler/objectivec/objectivec_oneof.cc",
+ "src/google/protobuf/compiler/objectivec/objectivec_primitive_field.cc",
+ "src/google/protobuf/compiler/php/php_generator.cc",
+ "src/google/protobuf/compiler/plugin.cc",
+ "src/google/protobuf/compiler/plugin.pb.cc",
+ "src/google/protobuf/compiler/python/python_generator.cc",
+ "src/google/protobuf/compiler/ruby/ruby_generator.cc",
+ "src/google/protobuf/compiler/subprocess.cc",
+ "src/google/protobuf/compiler/zip_writer.cc",
+ ],
+ copts = COPTS,
+ includes = ["src/"],
+ linkopts = LINK_OPTS,
+ visibility = ["//visibility:public"],
+ deps = [":protobuf"],
+)
+
+cc_binary(
+ name = "protoc",
+ srcs = ["src/google/protobuf/compiler/main.cc"],
+ linkopts = LINK_OPTS,
+ visibility = ["//visibility:public"],
+ deps = [":protoc_lib"],
+)
+
+proto_lang_toolchain(
+ name = "cc_toolchain",
+ blacklisted_protos = [proto + "_proto" for proto in WELL_KNOWN_PROTO_MAP.keys()],
+ command_line = "--cpp_out=$(OUT)",
+ runtime = ":protobuf",
+ visibility = ["//visibility:public"],
+)
+
+alias(
+ name = "objectivec",
+ actual = "//objectivec",
+ visibility = ["//visibility:public"],
+)
+
+alias(
+ name = "protobuf_objc",
+ actual = "//objectivec",
+ visibility = ["//visibility:public"],
+)
diff --git a/example/build_with_bazel/test.cc b/example/build_with_bazel/test.cc
new file mode 100644
index 00000000..b4eb7780
--- /dev/null
+++ b/example/build_with_bazel/test.cc
@@ -0,0 +1,30 @@
+// Licensed to the Apache Software Foundation (ASF) under one
+// or more contributor license agreements. See the NOTICE file
+// distributed with this work for additional information
+// regarding copyright ownership. The ASF licenses this file
+// to you under the Apache License, Version 2.0 (the
+// "License"); you may not use this file except in compliance
+// with the License. You may obtain a copy of the License at
+//
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing,
+// software distributed under the License is distributed on an
+// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+// KIND, either express or implied. See the License for the
+// specific language governing permissions and limitations
+// under the License.
+
+#include <bthread/bthread.h>
+
+void *PrintHellobRPC(void *arg) {
+ printf("I Love bRPC");
+ return nullptr;
+}
+
+int main(int argc, char **argv) {
+ bthread_t th_1;
+ bthread_start_background(&th_1, nullptr, PrintHellobRPC, nullptr);
+ bthread_join(th_1, nullptr);
+ return 0;
+}
diff --git a/example/build_with_bazel/zlib.BUILD b/example/build_with_bazel/zlib.BUILD
new file mode 100644
index 00000000..28cc0815
--- /dev/null
+++ b/example/build_with_bazel/zlib.BUILD
@@ -0,0 +1,110 @@
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+# Copyright 2008 Google Inc. All rights reserved.
+#
+# Redistribution and use in source and binary forms, with or without
+# modification, are permitted provided that the following conditions are
+# met:
+#
+# * Redistributions of source code must retain the above copyright
+# notice, this list of conditions and the following disclaimer.
+# * Redistributions in binary form must reproduce the above
+# copyright notice, this list of conditions and the following disclaimer
+# in the documentation and/or other materials provided with the
+# distribution.
+# * Neither the name of Google Inc. nor the names of its
+# contributors may be used to endorse or promote products derived from
+# this software without specific prior written permission.
+#
+# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+# Copied from https://github.com/protocolbuffers/protobuf/blob/v3.9.1/third_party/zlib.BUILD
+load("@rules_cc//cc:defs.bzl", "cc_library")
+
+_ZLIB_HEADERS = [
+ "crc32.h",
+ "deflate.h",
+ "gzguts.h",
+ "inffast.h",
+ "inffixed.h",
+ "inflate.h",
+ "inftrees.h",
+ "trees.h",
+ "zconf.h",
+ "zlib.h",
+ "zutil.h",
+]
+
+_ZLIB_PREFIXED_HEADERS = ["zlib/include/" + hdr for hdr in _ZLIB_HEADERS]
+
+# In order to limit the damage from the `includes` propagation
+# via `:zlib`, copy the public headers to a subdirectory and
+# expose those.
+genrule(
+ name = "copy_public_headers",
+ srcs = _ZLIB_HEADERS,
+ outs = _ZLIB_PREFIXED_HEADERS,
+ cmd = "cp $(SRCS) $(@D)/zlib/include/",
+ visibility = ["//visibility:private"],
+)
+
+cc_library(
+ name = "zlib",
+ srcs = [
+ "adler32.c",
+ "compress.c",
+ "crc32.c",
+ "deflate.c",
+ "gzclose.c",
+ "gzlib.c",
+ "gzread.c",
+ "gzwrite.c",
+ "infback.c",
+ "inffast.c",
+ "inflate.c",
+ "inftrees.c",
+ "trees.c",
+ "uncompr.c",
+ "zutil.c",
+ ],
+ hdrs = _ZLIB_PREFIXED_HEADERS,
+ copts = select({
+ ":windows": [],
+ "//conditions:default": [
+ "-Wno-unused-variable",
+ "-Wno-implicit-function-declaration",
+ ],
+ }),
+ includes = ["zlib/include/"],
+ visibility = ["//visibility:public"],
+)
+
+config_setting(
+ name = "windows",
+ constraint_values = [
+ "@platforms//os:windows",
+ ],
+)
diff --git a/example/rdma_performance/client.cpp b/example/rdma_performance/client.cpp
index 5d0178af..1ab77b8e 100644
--- a/example/rdma_performance/client.cpp
+++ b/example/rdma_performance/client.cpp
@@ -30,6 +30,8 @@
#include "bvar/variable.h"
#include "test.pb.h"
+#ifdef BRPC_WITH_RDMA
+
DEFINE_int32(thread_num, 0, "How many threads are used");
DEFINE_int32(queue_depth, 1, "How many requests can be pending in the queue");
DEFINE_int32(expected_qps, 0, "The expected QPS");
@@ -308,3 +310,12 @@ int main(int argc, char* argv[]) {
return 0;
}
+
+#else
+
+int main(int argc, char* argv[]) {
+ LOG(ERROR) << " brpc is not compiled with rdma. To enable it, please refer to https://github.com/apache/incubator-brpc/blob/master/docs/en/rdma.md";
+ return 0;
+}
+
+#endif
diff --git a/example/rdma_performance/server.cpp b/example/rdma_performance/server.cpp
index 82e17583..96335114 100644
--- a/example/rdma_performance/server.cpp
+++ b/example/rdma_performance/server.cpp
@@ -15,6 +15,7 @@
// specific language governing permissions and limitations
// under the License.
+
#include <gflags/gflags.h>
#include "butil/atomicops.h"
#include "butil/logging.h"
@@ -23,6 +24,8 @@
#include "bvar/variable.h"
#include "test.pb.h"
+#ifdef BRPC_WITH_RDMA
+
DEFINE_int32(port, 8002, "TCP Port of this server");
DEFINE_bool(use_rdma, true, "Use RDMA or not");
@@ -82,3 +85,13 @@ int main(int argc, char* argv[]) {
server.RunUntilAskedToQuit();
return 0;
}
+
+#else
+
+
+int main(int argc, char* argv[]) {
+ LOG(ERROR) << " brpc is not compiled with rdma. To enable it, please refer to https://github.com/apache/incubator-brpc/blob/master/docs/en/rdma.md";
+ return 0;
+}
+
+#endif
---------------------------------------------------------------------
To unsubscribe, e-mail: dev-unsubscribe@brpc.apache.org
For additional commands, e-mail: dev-help@brpc.apache.org