BUILD 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535
  1. # Licensed to the Apache Software Foundation (ASF) under one or more
  2. # contributor license agreements. See the NOTICE file distributed with
  3. # this work for additional information regarding copyright ownership.
  4. # The ASF licenses this file to You under the Apache License, Version 2.0
  5. # (the "License"); you may not use this file except in compliance with
  6. # the License. You may obtain a copy of the License at
  7. #
  8. # http://www.apache.org/licenses/LICENSE-2.0
  9. #
  10. # Unless required by applicable law or agreed to in writing, software
  11. # distributed under the License is distributed on an "AS IS" BASIS,
  12. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. # See the License for the specific language governing permissions and
  14. # limitations under the License.
  15. licenses(["notice"]) # Apache v2
  16. exports_files(["LICENSE"])
  17. load(":bazel/brpc.bzl", "brpc_proto_library")
  18. config_setting(
  19. name = "with_glog",
  20. define_values = {"with_glog": "true"},
  21. visibility = ["//visibility:public"],
  22. )
  23. config_setting(
  24. name = "with_mesalink",
  25. define_values = {"with_mesalink": "true"},
  26. visibility = ["//visibility:public"],
  27. )
  28. config_setting(
  29. name = "with_thrift",
  30. define_values = {"with_thrift": "true"},
  31. visibility = ["//visibility:public"],
  32. )
  33. config_setting(
  34. name = "unittest",
  35. define_values = {"unittest": "true"},
  36. )
  37. config_setting(
  38. name = "darwin",
  39. values = {"cpu": "darwin"},
  40. visibility = ["//visibility:public"],
  41. )
  42. config_setting(
  43. name = "linux",
  44. values = {"cpu": "linux"},
  45. visibility = ["//visibility:public"],
  46. )
  47. COPTS = [
  48. "-DBTHREAD_USE_FAST_PTHREAD_MUTEX",
  49. "-D__const__=",
  50. "-D_GNU_SOURCE",
  51. "-DUSE_SYMBOLIZE",
  52. "-DNO_TCMALLOC",
  53. "-D__STDC_FORMAT_MACROS",
  54. "-D__STDC_LIMIT_MACROS",
  55. "-D__STDC_CONSTANT_MACROS",
  56. "-DGFLAGS_NS=google",
  57. ] + select({
  58. ":with_glog": ["-DBRPC_WITH_GLOG=1"],
  59. "//conditions:default": ["-DBRPC_WITH_GLOG=0"],
  60. }) + select({
  61. ":with_mesalink": ["-DUSE_MESALINK"],
  62. "//conditions:default": [""],
  63. }) + select({
  64. ":with_thrift": ["-DENABLE_THRIFT_FRAMED_PROTOCOL=1"],
  65. "//conditions:default": [""],
  66. })
  67. LINKOPTS = [
  68. "-lpthread",
  69. "-ldl",
  70. "-lz",
  71. "-lssl",
  72. "-lcrypto",
  73. ] + select({
  74. ":darwin": [
  75. "-framework CoreFoundation",
  76. "-framework CoreGraphics",
  77. "-framework CoreData",
  78. "-framework CoreText",
  79. "-framework Security",
  80. "-framework Foundation",
  81. "-Wl,-U,_MallocExtension_ReleaseFreeMemory",
  82. "-Wl,-U,_ProfilerStart",
  83. "-Wl,-U,_ProfilerStop",
  84. "-Wl,-U,_RegisterThriftProtocol",
  85. ],
  86. "//conditions:default": [
  87. "-lrt",
  88. ],
  89. }) + select({
  90. ":with_mesalink": [
  91. "-lmesalink",
  92. ],
  93. "//conditions:default": [],
  94. }) + select({
  95. ":with_thrift": [
  96. "-lthriftnb",
  97. "-levent",
  98. "-lthrift"],
  99. "//conditions:default": [],
  100. })
  101. genrule(
  102. name = "config_h",
  103. outs = [
  104. "src/butil/config.h",
  105. ],
  106. cmd = """cat << EOF >$@""" + """
  107. // This file is auto-generated.
  108. #ifndef BUTIL_CONFIG_H
  109. #define BUTIL_CONFIG_H
  110. #ifdef BRPC_WITH_GLOG
  111. #undef BRPC_WITH_GLOG
  112. #endif
  113. #define BRPC_WITH_GLOG """ + select({
  114. ":with_glog": "1",
  115. "//conditions:default": "0",
  116. }) +
  117. """
  118. #endif // BUTIL_CONFIG_H
  119. EOF
  120. """
  121. )
  122. BUTIL_SRCS = [
  123. "src/butil/third_party/dmg_fp/g_fmt.cc",
  124. "src/butil/third_party/dmg_fp/dtoa_wrapper.cc",
  125. "src/butil/third_party/dynamic_annotations/dynamic_annotations.c",
  126. "src/butil/third_party/icu/icu_utf.cc",
  127. "src/butil/third_party/superfasthash/superfasthash.c",
  128. "src/butil/third_party/modp_b64/modp_b64.cc",
  129. "src/butil/third_party/symbolize/demangle.cc",
  130. "src/butil/third_party/symbolize/symbolize.cc",
  131. "src/butil/third_party/snappy/snappy-sinksource.cc",
  132. "src/butil/third_party/snappy/snappy-stubs-internal.cc",
  133. "src/butil/third_party/snappy/snappy.cc",
  134. "src/butil/third_party/murmurhash3/murmurhash3.cpp",
  135. "src/butil/arena.cpp",
  136. "src/butil/at_exit.cc",
  137. "src/butil/atomicops_internals_x86_gcc.cc",
  138. "src/butil/base64.cc",
  139. "src/butil/big_endian.cc",
  140. "src/butil/cpu.cc",
  141. "src/butil/debug/alias.cc",
  142. "src/butil/debug/asan_invalid_access.cc",
  143. "src/butil/debug/crash_logging.cc",
  144. "src/butil/debug/debugger.cc",
  145. "src/butil/debug/debugger_posix.cc",
  146. "src/butil/debug/dump_without_crashing.cc",
  147. "src/butil/debug/proc_maps_linux.cc",
  148. "src/butil/debug/stack_trace.cc",
  149. "src/butil/debug/stack_trace_posix.cc",
  150. "src/butil/environment.cc",
  151. "src/butil/files/file.cc",
  152. "src/butil/files/file_posix.cc",
  153. "src/butil/files/file_enumerator.cc",
  154. "src/butil/files/file_enumerator_posix.cc",
  155. "src/butil/files/file_path.cc",
  156. "src/butil/files/file_path_constants.cc",
  157. "src/butil/files/memory_mapped_file.cc",
  158. "src/butil/files/memory_mapped_file_posix.cc",
  159. "src/butil/files/scoped_file.cc",
  160. "src/butil/files/scoped_temp_dir.cc",
  161. "src/butil/file_util.cc",
  162. "src/butil/file_util_posix.cc",
  163. "src/butil/guid.cc",
  164. "src/butil/guid_posix.cc",
  165. "src/butil/hash.cc",
  166. "src/butil/lazy_instance.cc",
  167. "src/butil/location.cc",
  168. "src/butil/memory/aligned_memory.cc",
  169. "src/butil/memory/ref_counted.cc",
  170. "src/butil/memory/ref_counted_memory.cc",
  171. "src/butil/memory/singleton.cc",
  172. "src/butil/memory/weak_ptr.cc",
  173. "src/butil/posix/file_descriptor_shuffle.cc",
  174. "src/butil/posix/global_descriptors.cc",
  175. "src/butil/process_util.cc",
  176. "src/butil/rand_util.cc",
  177. "src/butil/rand_util_posix.cc",
  178. "src/butil/fast_rand.cpp",
  179. "src/butil/safe_strerror_posix.cc",
  180. "src/butil/sha1_portable.cc",
  181. "src/butil/strings/latin1_string_conversions.cc",
  182. "src/butil/strings/nullable_string16.cc",
  183. "src/butil/strings/safe_sprintf.cc",
  184. "src/butil/strings/string16.cc",
  185. "src/butil/strings/string_number_conversions.cc",
  186. "src/butil/strings/string_split.cc",
  187. "src/butil/strings/string_piece.cc",
  188. "src/butil/strings/string_util.cc",
  189. "src/butil/strings/string_util_constants.cc",
  190. "src/butil/strings/stringprintf.cc",
  191. "src/butil/strings/utf_offset_string_conversions.cc",
  192. "src/butil/strings/utf_string_conversion_utils.cc",
  193. "src/butil/strings/utf_string_conversions.cc",
  194. "src/butil/synchronization/cancellation_flag.cc",
  195. "src/butil/synchronization/condition_variable_posix.cc",
  196. "src/butil/synchronization/waitable_event_posix.cc",
  197. "src/butil/threading/non_thread_safe_impl.cc",
  198. "src/butil/threading/platform_thread_posix.cc",
  199. "src/butil/threading/simple_thread.cc",
  200. "src/butil/threading/thread_checker_impl.cc",
  201. "src/butil/threading/thread_collision_warner.cc",
  202. "src/butil/threading/thread_id_name_manager.cc",
  203. "src/butil/threading/thread_local_posix.cc",
  204. "src/butil/threading/thread_local_storage.cc",
  205. "src/butil/threading/thread_local_storage_posix.cc",
  206. "src/butil/threading/thread_restrictions.cc",
  207. "src/butil/threading/watchdog.cc",
  208. "src/butil/time/clock.cc",
  209. "src/butil/time/default_clock.cc",
  210. "src/butil/time/default_tick_clock.cc",
  211. "src/butil/time/tick_clock.cc",
  212. "src/butil/time/time.cc",
  213. "src/butil/time/time_posix.cc",
  214. "src/butil/version.cc",
  215. "src/butil/logging.cc",
  216. "src/butil/class_name.cpp",
  217. "src/butil/errno.cpp",
  218. "src/butil/find_cstr.cpp",
  219. "src/butil/status.cpp",
  220. "src/butil/string_printf.cpp",
  221. "src/butil/thread_local.cpp",
  222. "src/butil/unix_socket.cpp",
  223. "src/butil/endpoint.cpp",
  224. "src/butil/fd_utility.cpp",
  225. "src/butil/files/temp_file.cpp",
  226. "src/butil/files/file_watcher.cpp",
  227. "src/butil/time.cpp",
  228. "src/butil/zero_copy_stream_as_streambuf.cpp",
  229. "src/butil/crc32c.cc",
  230. "src/butil/containers/case_ignored_flat_map.cpp",
  231. "src/butil/iobuf.cpp",
  232. "src/butil/binary_printer.cpp",
  233. "src/butil/recordio.cc",
  234. "src/butil/popen.cpp",
  235. ] + select({
  236. ":darwin": [
  237. "src/butil/time/time_mac.cc",
  238. "src/butil/mac/scoped_mach_port.cc",
  239. ],
  240. "//conditions:default": [
  241. "src/butil/file_util_linux.cc",
  242. "src/butil/threading/platform_thread_linux.cc",
  243. "src/butil/strings/sys_string_conversions_posix.cc",
  244. ],
  245. })
  246. objc_library(
  247. name = "macos_lib",
  248. hdrs = [":config_h",
  249. "src/butil/atomicops.h",
  250. "src/butil/atomicops_internals_atomicword_compat.h",
  251. "src/butil/atomicops_internals_mac.h",
  252. "src/butil/base_export.h",
  253. "src/butil/basictypes.h",
  254. "src/butil/build_config.h",
  255. "src/butil/compat.h",
  256. "src/butil/compiler_specific.h",
  257. "src/butil/containers/hash_tables.h",
  258. "src/butil/debug/debugger.h",
  259. "src/butil/debug/leak_annotations.h",
  260. "src/butil/file_util.h",
  261. "src/butil/file_descriptor_posix.h",
  262. "src/butil/files/file_path.h",
  263. "src/butil/files/file.h",
  264. "src/butil/files/scoped_file.h",
  265. "src/butil/lazy_instance.h",
  266. "src/butil/logging.h",
  267. "src/butil/mac/bundle_locations.h",
  268. "src/butil/mac/foundation_util.h",
  269. "src/butil/mac/scoped_cftyperef.h",
  270. "src/butil/mac/scoped_typeref.h",
  271. "src/butil/macros.h",
  272. "src/butil/memory/aligned_memory.h",
  273. "src/butil/memory/scoped_policy.h",
  274. "src/butil/memory/scoped_ptr.h",
  275. "src/butil/move.h",
  276. "src/butil/port.h",
  277. "src/butil/posix/eintr_wrapper.h",
  278. "src/butil/scoped_generic.h",
  279. "src/butil/strings/string16.h",
  280. "src/butil/strings/string_piece.h",
  281. "src/butil/strings/string_util.h",
  282. "src/butil/strings/string_util_posix.h",
  283. "src/butil/strings/sys_string_conversions.h",
  284. "src/butil/synchronization/lock.h",
  285. "src/butil/time/time.h",
  286. "src/butil/time.h",
  287. "src/butil/third_party/dynamic_annotations/dynamic_annotations.h",
  288. "src/butil/threading/platform_thread.h",
  289. "src/butil/threading/thread_restrictions.h",
  290. "src/butil/threading/thread_id_name_manager.h",
  291. "src/butil/type_traits.h",
  292. ],
  293. non_arc_srcs = [
  294. "src/butil/mac/bundle_locations.mm",
  295. "src/butil/mac/foundation_util.mm",
  296. "src/butil/file_util_mac.mm",
  297. "src/butil/threading/platform_thread_mac.mm",
  298. "src/butil/strings/sys_string_conversions_mac.mm",
  299. ],
  300. deps = [
  301. "@com_github_gflags_gflags//:gflags",
  302. ] + select({
  303. ":with_glog": ["@com_github_google_glog//:glog"],
  304. "//conditions:default": [],
  305. }),
  306. includes = ["src/"],
  307. enable_modules = True,
  308. tags = ["manual"],
  309. )
  310. cc_library(
  311. name = "butil",
  312. srcs = BUTIL_SRCS,
  313. hdrs = glob([
  314. "src/butil/*.h",
  315. "src/butil/*.hpp",
  316. "src/butil/**/*.h",
  317. "src/butil/**/*.hpp",
  318. "src/butil/**/**/*.h",
  319. "src/butil/**/**/*.hpp",
  320. "src/butil/**/**/**/*.h",
  321. "src/butil/**/**/**/*.hpp",
  322. "src/butil/third_party/dmg_fp/dtoa.cc",
  323. ]) + [":config_h"],
  324. deps = [
  325. "@com_google_protobuf//:protobuf",
  326. "@com_github_gflags_gflags//:gflags",
  327. ] + select({
  328. ":with_glog": ["@com_github_google_glog//:glog"],
  329. ":darwin": [":macos_lib"],
  330. "//conditions:default": [],
  331. }),
  332. includes = [
  333. "src/",
  334. ],
  335. copts = COPTS + select({
  336. ":unittest": [
  337. "-DBVAR_NOT_LINK_DEFAULT_VARIABLES",
  338. "-DUNIT_TEST",
  339. ],
  340. "//conditions:default": [],
  341. }),
  342. linkopts = LINKOPTS,
  343. visibility = ["//visibility:public"],
  344. )
  345. cc_library(
  346. name = "bvar",
  347. srcs = glob([
  348. "src/bvar/*.cpp",
  349. "src/bvar/detail/*.cpp",
  350. ],
  351. exclude = [
  352. "src/bvar/default_variables.cpp",
  353. ]) + select({
  354. ":unittest": [],
  355. "//conditions:default": ["src/bvar/default_variables.cpp"],
  356. }),
  357. hdrs = glob([
  358. "src/bvar/*.h",
  359. "src/bvar/utils/*.h",
  360. "src/bvar/detail/*.h",
  361. ]),
  362. includes = [
  363. "src/",
  364. ],
  365. deps = [
  366. ":butil",
  367. ],
  368. copts = COPTS + select({
  369. ":unittest": [
  370. "-DBVAR_NOT_LINK_DEFAULT_VARIABLES",
  371. "-DUNIT_TEST",
  372. ],
  373. "//conditions:default": [],
  374. }),
  375. linkopts = LINKOPTS,
  376. visibility = ["//visibility:public"],
  377. )
  378. cc_library(
  379. name = "bthread",
  380. srcs = glob([
  381. "src/bthread/*.cpp",
  382. ]),
  383. hdrs = glob([
  384. "src/bthread/*.h",
  385. "src/bthread/*.list",
  386. ]),
  387. includes = [
  388. "src/"
  389. ],
  390. deps = [
  391. ":butil",
  392. ":bvar",
  393. ],
  394. copts = COPTS,
  395. linkopts = LINKOPTS,
  396. visibility = ["//visibility:public"],
  397. )
  398. cc_library(
  399. name = "json2pb",
  400. srcs = glob([
  401. "src/json2pb/*.cpp",
  402. ]),
  403. hdrs = glob([
  404. "src/json2pb/*.h",
  405. ]),
  406. includes = [
  407. "src/",
  408. ],
  409. deps = [
  410. ":butil",
  411. ],
  412. copts = COPTS,
  413. linkopts = LINKOPTS,
  414. visibility = ["//visibility:public"],
  415. )
  416. cc_library(
  417. name = "mcpack2pb",
  418. srcs = [
  419. "src/mcpack2pb/field_type.cpp",
  420. "src/mcpack2pb/mcpack2pb.cpp",
  421. "src/mcpack2pb/parser.cpp",
  422. "src/mcpack2pb/serializer.cpp",
  423. ],
  424. hdrs = glob([
  425. "src/mcpack2pb/*.h",
  426. ]),
  427. includes = [
  428. "src/",
  429. ],
  430. deps = [
  431. ":butil",
  432. ":cc_brpc_idl_options_proto",
  433. "@com_google_protobuf//:protoc_lib",
  434. ],
  435. copts = COPTS,
  436. linkopts = LINKOPTS,
  437. visibility = ["//visibility:public"],
  438. )
  439. brpc_proto_library(
  440. name = "cc_brpc_idl_options_proto",
  441. srcs = [
  442. "src/idl_options.proto",
  443. ],
  444. deps = [
  445. "@com_google_protobuf//:cc_wkt_protos"
  446. ],
  447. visibility = ["//visibility:public"],
  448. )
  449. brpc_proto_library(
  450. name = "cc_brpc_internal_proto",
  451. srcs = glob([
  452. "src/brpc/*.proto",
  453. "src/brpc/policy/*.proto",
  454. ]),
  455. include = "src/",
  456. deps = [
  457. ":cc_brpc_idl_options_proto",
  458. "@com_google_protobuf//:cc_wkt_protos"
  459. ],
  460. visibility = ["//visibility:public"],
  461. )
  462. cc_library(
  463. name = "brpc",
  464. srcs = glob([
  465. "src/brpc/*.cpp",
  466. "src/brpc/**/*.cpp",
  467. ],
  468. exclude = [
  469. "src/brpc/thrift_service.cpp",
  470. "src/brpc/thrift_message.cpp",
  471. "src/brpc/policy/thrift_protocol.cpp",
  472. ]) + select({
  473. ":with_thrift" : glob([
  474. "src/brpc/thrift*.cpp",
  475. "src/brpc/**/thrift*.cpp"]),
  476. "//conditions:default" : [],
  477. }),
  478. hdrs = glob([
  479. "src/brpc/*.h",
  480. "src/brpc/**/*.h"
  481. ]),
  482. includes = [
  483. "src/",
  484. ],
  485. deps = [
  486. ":butil",
  487. ":bthread",
  488. ":bvar",
  489. ":json2pb",
  490. ":mcpack2pb",
  491. ":cc_brpc_internal_proto",
  492. "@com_github_google_leveldb//:leveldb",
  493. ],
  494. copts = COPTS,
  495. linkopts = LINKOPTS,
  496. visibility = ["//visibility:public"],
  497. )
  498. cc_binary(
  499. name = "protoc-gen-mcpack",
  500. srcs = [
  501. "src/mcpack2pb/generator.cpp",
  502. ],
  503. deps = [
  504. ":cc_brpc_idl_options_proto",
  505. ":brpc",
  506. ],
  507. copts = COPTS,
  508. linkopts = LINKOPTS,
  509. visibility = ["//visibility:public"],
  510. )