proto.conf 37 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881
  1. # tag:tool-specific tag:proto
  2. PROTOC=${tool:"contrib/tools/protoc"}
  3. PROTOC_OLD=${tool:"contrib/tools/protoc_old"}
  4. PY_PROTOC=${tool:"contrib/tools/protoc"}
  5. when ($PYTHON2 == "yes") {
  6. PY_PROTOC=${PROTOC_OLD}
  7. }
  8. JAVA_PROTOC=${tool:"build/platform/java/protoc"}
  9. when ($OPENSOURCE_REPLACE_PROTOBUF) {
  10. PROTOC_STYLEGUIDE_OUT=
  11. PROTOC_PLUGIN_STYLEGUIDE=
  12. PROTOBUF_INCLUDE_PATH="${protobuf_INCLUDE_DIRS}"
  13. DEFAULT_PROTOC_TOOLS=
  14. }
  15. otherwise {
  16. PROTOC_STYLEGUIDE_OUT=--cpp_styleguide_out=$ARCADIA_BUILD_ROOT/$PROTO_NAMESPACE
  17. PROTOC_PLUGIN_STYLEGUIDE=--plugin=protoc-gen-cpp_styleguide=${tool:"contrib/tools/protoc/plugins/cpp_styleguide"}
  18. PROTOBUF_INCLUDE_PATH=${ARCADIA_ROOT}/contrib/libs/protobuf/src
  19. PROTOBUF_OLD_PATH=${ARCADIA_ROOT}/contrib/libs/protobuf_old/src
  20. DEFAULT_PROTOC_TOOLS=${hide;tool:"contrib/tools/protoc/bin"} ${hide;tool:"contrib/tools/protoc/plugins/cpp_styleguide"}
  21. }
  22. USE_VANILLA_PROTOC=no
  23. PROTOC_TRANSITIVE_HEADERS=yes
  24. _PROTOC_FLAGS=
  25. # tag:proto
  26. PY_PROTOS_FOR=no
  27. BUILD_PROTO_AS_EVLOG=no
  28. # tag:proto
  29. PROTO_NAMESPACE=
  30. # tag:proto tag:python-specific
  31. GEN_PY_PROTOS=$YMAKE_PYTHON ${input:"build/scripts/gen_py_protos.py"} --py_ver ${_PYTHON_VER}
  32. # tag:proto tag:cpp-specific
  33. PROTO_HEADER_EXTS=.pb.h
  34. CPP_PROTO_CMDLINE=
  35. CPP_PROTO_OPTS=
  36. CPP_PROTO_OUTS=
  37. CPP_PROTO_OUTS_SEM=
  38. CPP_PROTO_SUFFIXES=.pb.h .pb.cc
  39. CPP_PROTO_PLUGINS=
  40. CPP_PROTO_NO_DBGINFO=no
  41. # tag:proto tag:cpp-specific
  42. CPP_EV_OPTS=--plugin=protoc-gen-event2cpp=${tool:"tools/event2cpp"} --event2cpp_out=$ARCADIA_BUILD_ROOT -I=$ARCADIA_ROOT/library/cpp/eventlog
  43. CPP_EV_OUTS=
  44. CPP_EV_OUTS_SEM=
  45. # tag:proto tag:python-specific
  46. PY_PROTO_OPTS=
  47. PY_PROTO_OUTS=
  48. PY_PROTO_OUTS_INTERNAL=
  49. PY_PROTO_DEPS=
  50. PY_PROTO_SUFFIXES=_pb2.py
  51. PY_EVLOG_SUFFIXES=_ev_pb2.py
  52. # tag:proto tag:java-specific
  53. JAVA_PROTO_ARGS=
  54. # tag:proto tag:python-specific
  55. OPTIMIZE_PY_PROTOS_FLAG=no
  56. # tag:proto
  57. ### @usage: CPP_PROTOLIBS_DEBUG_INFO()
  58. ###
  59. ### Eqvivalent to NO_DEBUG_INFO() macro if the flag CPP_PROTO_NO_DBGINFO=yes
  60. macro CPP_PROTOLIBS_DEBUG_INFO() {
  61. SET(NO_DEBUGINFO $CPP_PROTO_NO_DBGINFO)
  62. }
  63. # tag:internal
  64. ### @usage: _ORDER_ADDINCL([BUILD ...] [SOURCE ...] Args...) # internal
  65. ###
  66. ### Order and filter ADDINCLs (Args - is intentionally omitted in ADDINCL macro)
  67. macro _ORDER_ADDINCL(BUILD[], SOURCE[], ARGS...) {
  68. ADDINCL($BUILD $SOURCE)
  69. }
  70. # tag:proto
  71. ### @usage: PROTO_ADDINCL([GLOBAL] [WITH_GEN] Path)
  72. ###
  73. ### This macro introduces proper ADDINCLs for .proto-files found in sources and
  74. ### .cpp/.h generated files, supplying them to appropriate commands and allowing
  75. ### proper dependency resolution at configure-time.
  76. ###
  77. ### Note: you normally shouldn't use this macro. ADDINCLs should be sent to user
  78. ### from dependency via PROTO_NAMESPACE macro
  79. macro PROTO_ADDINCL(GLOBAL?"GLOBAL":"", Path, WITH_GEN?"BUILD":"") {
  80. _ORDER_ADDINCL($WITH_GEN $GLOBAL FOR proto ${ARCADIA_BUILD_ROOT}/$Path SOURCE $GLOBAL FOR proto ${ARCADIA_ROOT}/$Path)
  81. ADDINCL($GLOBAL ${ARCADIA_BUILD_ROOT}/$Path)
  82. }
  83. # tag:proto
  84. ### @usage: PROTO_NAMESPACE([WITH_GEN] Namespace)
  85. ###
  86. ### Defines protobuf namespace (import/export path prefix) which should be used for imports and
  87. ### which defines output path for .proto generation.
  88. ###
  89. ### For proper importing and configure-time dependency management it sets ADDINCLs
  90. ### for both .cpp headers includes and .proto imports. If .proto expected to be used outside of the
  91. ### processing module use GLOBAL to send proper ADDINCLs to all (transitive) users. PEERDIR to
  92. ### PROTO_LIBRARY with PROTO_NAMESPACE() is enough at user side to correctly use the library.
  93. ### If generated .proto files are going to be used for building a module than use of WITH_GEN
  94. ### parameter will add appropriate dir from the build root for .proto files search.
  95. macro PROTO_NAMESPACE(GLOBAL?"GLOBAL":"", WITH_GEN?"WITH_GEN":"", Namespace) {
  96. SET(PROTO_NAMESPACE $Namespace)
  97. PROTO_ADDINCL(GLOBAL $WITH_GEN $Namespace)
  98. }
  99. # tag:proto
  100. ### @usage PROTOC_FATAL_WARNINGS()
  101. ###
  102. ### Treat protoc warnings as fatal errors that break the build, for example, unused imports
  103. ### Adds `--fatal_warnings` argument to protoc
  104. macro PROTOC_FATAL_WARNINGS() {
  105. SET_APPEND(_PROTOC_FLAGS --fatal_warnings)
  106. }
  107. # tag:proto tag:internal tag:python-specific
  108. ### @usage: OPTIMIZE_PY_PROTOS() # internal
  109. ###
  110. ### Enable Python proto optimization by embedding corresponding C++ code into binary.
  111. ### Python protobuf runtime will use C++ implementation instead of Python one if former is available.
  112. ### This is default mode for most PROTO_LIBRARY's and PY2_LIBRARY's, some system ones being exceptions.
  113. macro OPTIMIZE_PY_PROTOS() {
  114. SET(OPTIMIZE_PY_PROTOS_FLAG yes)
  115. }
  116. # tag:proto tag:python-specific
  117. ### @usage: NO_OPTIMIZE_PY_PROTOS()
  118. ###
  119. ### Disable Python proto optimization using embedding corresponding C++ code into binary.
  120. ### Python protobuf runtime will use C++ implementation instead of Python one if former is available.
  121. ### This is default mode only for some system libraries.
  122. macro NO_OPTIMIZE_PY_PROTOS() {
  123. SET(OPTIMIZE_PY_PROTOS_FLAG no)
  124. }
  125. # tag:proto tag:python-specific
  126. macro _PROTO_PLUGIN_ARGS_BASE(Name, Tool, OutParm...) {
  127. .CMD=--plugin=protoc-gen-${Name}=\${tool:"$Tool"} --${Name}_out=$ARCADIA_BUILD_ROOT/\$PROTO_NAMESPACE ${pre=--${Name}_opt=:OutParm}
  128. .SEM=IGNORED
  129. }
  130. # tag:proto tag:python-specific
  131. macro _ADD_PY_PROTO_OUT(Suf) {
  132. SET_APPEND(PY_PROTO_OUTS \${output;hide;noauto;norel;nopath;noext;suf=$Suf:File})
  133. SET_APPEND(PY_PROTO_OUTS_INTERNAL \${output;hide;noauto;norel;nopath;noext;suf=__int${_PYTHON_VER}__$Suf:File} \${hide;kv:"ext_out_name_for_\${nopath;noext;suf=__int${_PYTHON_VER}__$Suf:File} \${nopath;noext;suf=$Suf:File}"})
  134. # XXX fix variable expansion in plugins
  135. SET(PY_PROTO_SUFFIXES $PY_PROTO_SUFFIXES $Suf)
  136. }
  137. # tag:proto tag:python-specific
  138. ### @usage: PY_PROTO_PLUGIN(Name Ext Tool DEPS <Dependencies>)
  139. ###
  140. ### Define protoc plugin for python with given Name that emits extra output with provided Extension
  141. ### using Tool. Extra dependencies are passed via DEPS
  142. macro PY_PROTO_PLUGIN(NAME, EXT, TOOL, DEPS[]) {
  143. SET_APPEND(PY_PROTO_OPTS $_PROTO_PLUGIN_ARGS_BASE($NAME $TOOL))
  144. _ADD_PY_PROTO_OUT($EXT)
  145. # XXX fix variable expansion in plugins
  146. SET(PY_PROTO_DEPS $PY_PROTO_DEPS $DEPS)
  147. }
  148. # tag:proto tag:python-specific
  149. ### @usage: PY_PROTO_PLUGIN2(Name Ext1 Ext2 Tool DEPS <Dependencies>)
  150. ###
  151. ### Define protoc plugin for python with given Name that emits 2 extra outputs with provided Extensions
  152. ### using Tool. Extra dependencies are passed via DEPS
  153. macro PY_PROTO_PLUGIN2(NAME, EXT1, EXT2, TOOL, DEPS[]) {
  154. PY_PROTO_PLUGIN($NAME $EXT1 $TOOL DEPS $DEPS)
  155. _ADD_PY_PROTO_OUT($EXT2)
  156. }
  157. # tag:proto tag:java-specific
  158. macro _JAVA_PROTO_PLUGIN_ARGS_BASE(Name, Tool, OutParm...) {
  159. .CMD=--plugin=protoc-gen-${Name}=\${tool:"$Tool"} --${Name}_out=$ARCADIA_BUILD_ROOT/java_out
  160. }
  161. # tag:proto tag:java-specific
  162. ### @usage: JAVA_PROTO_PLUGIN(Name Tool DEPS <Dependencies>)
  163. ###
  164. ### Define protoc plugin for Java with given Name that emits extra outputs
  165. ### using Tool. Extra dependencies are passed via DEPS
  166. macro JAVA_PROTO_PLUGIN(NAME, TOOL, DEPS[]) {
  167. SET_APPEND(JAVA_PROTO_ARGS $_JAVA_PROTO_PLUGIN_ARGS_BASE($NAME $TOOL))
  168. # XXX fix variable expansion in plugins
  169. SET(JAVA_PROTOBUF_PEERS $JAVA_PROTOBUF_PEERS $DEPS)
  170. }
  171. macro _ADD_SEM_PROP_IF_NON_EMPTY(Prop, Args...) {
  172. .SEM=${pre=&& set_target_property $Prop :Args} ${pre=&& target_properties-ITEM && target_properties-name $Prop && target_properties-value :Args}
  173. }
  174. # tag:proto tag:java-specific
  175. macro WITH_KOTLIN_GRPC() {
  176. ENABLE(KOTLIN_PROTO)
  177. PEERDIR(build/platform/java/kotlin_grpc)
  178. SET_APPEND(JAVA_PROTO_ARGS ${env:"JAVA_HOME=${JDK_RESOURCE}"} ${env:"KOTLIN_GRPC_JAR=${KOTLIN_GRPC_RESOURCE_GLOBAL}/grpc_kotlin/protoc-gen-grpc-kotlin-1.3.1.jar"} --plugin=protoc-gen-kotlin_grpc=${KOTLIN_GRPC_RESOURCE_GLOBAL}/grpc_kotlin/grpc_kotlin --kotlin_grpc_out=$ARCADIA_BUILD_ROOT/java_out)
  179. SET(JAVA_PROTOBUF_PEERS $JAVA_PROTOBUF_PEERS contrib/java/io/grpc/grpc-kotlin-stub/1.3.1)
  180. SET(JAVA_PROTOBUF_PEERS $JAVA_PROTOBUF_PEERS contrib/java/com/google/protobuf/protobuf-kotlin/${JAVA_PROTO_RUNTIME_VERSION})
  181. }
  182. # tag:proto tag:cpp-specific
  183. macro _ADD_CPP_PROTO_OUT(Suf) {
  184. .SEM=append_target_property PROTOC_EXTRA_OUTS $Suf && protoc_extra_outs $Suf ${output;hide;suf=.o:Suf} $_ADD_SEM_PROP_IF_NON_EMPTY(PROTO_NAMESPACE $PROTO_NAMESPACE)
  185. SET_APPEND(CPP_PROTO_OUTS \${output;norel;nopath;noext;suf=$Suf:File})
  186. # XXX fix variable expansion in plugins
  187. SET(CPP_PROTO_SUFFIXES $CPP_PROTO_SUFFIXES $Suf)
  188. }
  189. # tag:proto tag:cpp-specific
  190. HAS_CPP_PROTOBUF_PEERS=no
  191. CPP_PROTOBUF_PEERS=
  192. # tag:proto tag:cpp-specific
  193. ### @usage: CPP_PROTO_PLUGIN0(Name Tool [DEPS <Dependencies>] [EXTRA_OUT_FLAG <ExtraOutFlag>])
  194. ###
  195. ### Define protoc plugin for C++ with given Name that emits code into regular outputs
  196. ### using Tool. Extra dependencies are passed via DEPS.
  197. macro CPP_PROTO_PLUGIN0(NAME, TOOL, DEPS[], EXTRA_OUT_FLAG="") {
  198. .SEM=target_proto_plugin $NAME ${tool;rootrel:TOOL} ${output;hide;suf=.fake.o:NAME} && target_macroses-ITEM && target_macroses-macro target_proto_plugin && target_macroses-args $NAME ${tool;rootrel:TOOL} ${output;hide;suf=.fake.o:NAME}
  199. SET_APPEND(CPP_PROTO_OPTS $_PROTO_PLUGIN_ARGS_BASE($NAME $TOOL $EXTRA_OUT_FLAG))
  200. # XXX fix variable expansion in plugins
  201. ENABLE(HAS_CPP_PROTOBUF_PEERS)
  202. SET(CPP_PROTOBUF_PEERS $CPP_PROTOBUF_PEERS $DEPS)
  203. }
  204. # tag:proto tag:cpp-specific
  205. ### @usage: CPP_PROTO_PLUGIN(Name Tool Suf [DEPS <Dependencies>] [EXTRA_OUT_FLAG <ExtraOutFlag>])
  206. ###
  207. ### Define protoc plugin for C++ with given Name that emits code into 1 extra output
  208. ### using Tool. Extra dependencies are passed via DEPS.
  209. macro CPP_PROTO_PLUGIN(NAME, TOOL, SUF, DEPS[], EXTRA_OUT_FLAG="") {
  210. CPP_PROTO_PLUGIN0($NAME $TOOL DEPS $DEPS ${pre=EXTRA_OUT_FLAG :EXTRA_OUT_FLAG})
  211. _ADD_CPP_PROTO_OUT($SUF)
  212. }
  213. # tag:proto tag:cpp-specific
  214. ### @usage: CPP_PROTO_PLUGIN2(Name Tool Suf1 Suf2 [DEPS <Dependencies>] [EXTRA_OUT_FLAG <ExtraOutFlag>])
  215. ###
  216. ### Define protoc plugin for C++ with given Name that emits code into 2 extra outputs
  217. ### using Tool. Extra dependencies are passed via DEPS.
  218. macro CPP_PROTO_PLUGIN2(NAME, TOOL, SUF1, SUF2, DEPS[], EXTRA_OUT_FLAG="") {
  219. CPP_PROTO_PLUGIN($NAME $TOOL $SUF1 DEPS $DEPS ${pre=EXTRA_OUT_FLAG :EXTRA_OUT_FLAG})
  220. _ADD_CPP_PROTO_OUT($SUF2)
  221. SET_APPEND(CPP_PROTO_OUTS_SEM \${output;hide;norel;nopath;noext;suf=$SUF2:File})
  222. }
  223. # tag:proto
  224. ### @usage: USE_SKIFF() #wip, do not use
  225. ###
  226. ### Use mapreduce/yt/skiff_proto/plugin for C++
  227. macro USE_SKIFF() {
  228. # Move extra includes to INDUCED_DEPS macro in mapreduce/yt/skiff_proto/plugin/ya.make
  229. CPP_PROTO_PLUGIN0(skiff mapreduce/yt/skiff_proto/plugin DEPS mapreduce/yt/skiff_proto/lib)
  230. }
  231. # tag:go-specific
  232. _GO_COMMON_GOOGLE_APIS = \
  233. vendor/google.golang.org/genproto/googleapis/api/annotations \
  234. vendor/google.golang.org/genproto/googleapis/api/configchange \
  235. vendor/google.golang.org/genproto/googleapis/api/distribution \
  236. vendor/google.golang.org/genproto/googleapis/api/expr/v1alpha1 \
  237. vendor/google.golang.org/genproto/googleapis/api/expr/v1beta1 \
  238. vendor/google.golang.org/genproto/googleapis/api/httpbody \
  239. vendor/google.golang.org/genproto/googleapis/api/label \
  240. vendor/google.golang.org/genproto/googleapis/api/metric \
  241. vendor/google.golang.org/genproto/googleapis/api/monitoredres \
  242. vendor/google.golang.org/genproto/googleapis/api/serviceconfig \
  243. vendor/cloud.google.com/go/servicecontrol/apiv1/servicecontrolpb \
  244. vendor/cloud.google.com/go/servicemanagement/apiv1/servicemanagementpb \
  245. vendor/google.golang.org/genproto/googleapis/iam/admin/v1 \
  246. vendor/google.golang.org/genproto/googleapis/iam/credentials/v1 \
  247. vendor/google.golang.org/genproto/googleapis/iam/v1 \
  248. vendor/google.golang.org/genproto/googleapis/iam/v1/logging \
  249. vendor/google.golang.org/genproto/googleapis/logging/type \
  250. vendor/google.golang.org/genproto/googleapis/logging/v2 \
  251. vendor/google.golang.org/genproto/googleapis/rpc/code \
  252. vendor/google.golang.org/genproto/googleapis/rpc/errdetails \
  253. vendor/google.golang.org/genproto/googleapis/rpc/status \
  254. vendor/google.golang.org/genproto/googleapis/type/calendarperiod \
  255. vendor/google.golang.org/genproto/googleapis/type/color \
  256. vendor/google.golang.org/genproto/googleapis/type/date \
  257. vendor/google.golang.org/genproto/googleapis/type/dayofweek \
  258. vendor/google.golang.org/genproto/googleapis/type/expr \
  259. vendor/google.golang.org/genproto/googleapis/type/fraction \
  260. vendor/google.golang.org/genproto/googleapis/type/latlng \
  261. vendor/google.golang.org/genproto/googleapis/type/money \
  262. vendor/google.golang.org/genproto/googleapis/type/postaladdress \
  263. vendor/google.golang.org/genproto/googleapis/type/quaternion \
  264. vendor/google.golang.org/genproto/googleapis/type/timeofday
  265. # tag:go-specific
  266. _COMMON_GOOGLE_APIS=None
  267. # tag:go-specific
  268. ### @usage: USE_COMMON_GOOGLE_APIS([apis...])
  269. ###
  270. ### Use common-google-apis library set. Pass optional apis list to be used or use them all.
  271. ### This macro is properly handled for all languages including Go, where apis come in
  272. ## pregenerated form. In other languages apis are generated from sources in Arcadia.
  273. macro USE_COMMON_GOOGLE_APIS(APIS...) {
  274. SET(_COMMON_GOOGLE_APIS ${pre=vendor/google.golang.org/genproto/googleapis/:APIS})
  275. }
  276. # tag:go-specific tag:proto
  277. GO_PROTO_GEN_PLUGINS=
  278. GO_PROTO_OPTS=
  279. GO_PROTO_OUTS=
  280. GO_PROTO_GRPC_OPTS=
  281. GO_PROTO_GRPC_OUTS=
  282. GO_PROTO_V2=no
  283. _GO_PROTO_CHECK_OUTPUT=
  284. # tag:go-specific tag:proto
  285. GO_PROTOBUF_IMPORTS=\
  286. ${GOSTD}/sync \
  287. ${GOSTD}/reflect \
  288. ${GOSTD}/fmt \
  289. ${GOSTD}/math \
  290. vendor/github.com/golang/protobuf/proto \
  291. vendor/google.golang.org/protobuf/types/descriptorpb \
  292. vendor/google.golang.org/protobuf/runtime/protoimpl \
  293. vendor/google.golang.org/protobuf/runtime/protoiface \
  294. vendor/google.golang.org/protobuf/reflect/protoreflect
  295. # tag:go-specific tag:proto
  296. GO_PROTOBUF_WELLKNOWN_TYPES=\
  297. vendor/google.golang.org/protobuf/types/known/anypb \
  298. vendor/google.golang.org/protobuf/types/known/apipb \
  299. vendor/google.golang.org/protobuf/types/known/durationpb \
  300. vendor/google.golang.org/protobuf/types/known/emptypb \
  301. vendor/google.golang.org/protobuf/types/known/fieldmaskpb \
  302. vendor/google.golang.org/protobuf/types/known/sourcecontextpb \
  303. vendor/google.golang.org/protobuf/types/known/structpb \
  304. vendor/google.golang.org/protobuf/types/known/timestamppb \
  305. vendor/google.golang.org/protobuf/types/known/typepb \
  306. vendor/google.golang.org/protobuf/types/known/wrapperspb
  307. # tag:go-specific tag:proto
  308. ### @usage: GO_PROTO_PLUGIN(Name Ext Tool [DEPS dependencies...])
  309. ###
  310. ### Define protoc plugin for GO with given Name that emits extra output with provided extension
  311. ### Ext using Tool. Extra dependencies are passed via DEPS.
  312. macro GO_PROTO_PLUGIN(NAME, EXT, TOOL, DEPS[]) {
  313. SET_APPEND(GO_PROTO_OPTS $_PROTO_PLUGIN_ARGS_BASE($NAME $TOOL))
  314. SET_APPEND(GO_PROTO_OUTS \${output;hide;noauto;norel;nopath;noext;suf=$EXT:File})
  315. PEERDIR(${DEPS})
  316. }
  317. # tag:go-specific tag:proto
  318. GO_PROTO_CMDLINE=${cwd;rootdir;input:File} $YMAKE_PYTHON3 ${input:"build/scripts/go_proto_wrapper.py"} --arcadia-prefix $GO_ARCADIA_PROJECT_PREFIX --contrib-prefix $GO_CONTRIB_PROJECT_PREFIX --namespace ./$PROTO_NAMESPACE $_GO_PROTO_CHECK_OUTPUT --proto ${input;rootrel:File} -- $PROTOC -I=./$PROTO_NAMESPACE -I=$ARCADIA_ROOT/$PROTO_NAMESPACE ${pre=-I=:_PROTO__INCLUDE} -I=$ARCADIA_BUILD_ROOT -I=$PROTOBUF_INCLUDE_PATH $_PROTOC_FLAGS ${hide:PROTO_FAKEID}
  319. # tag:go-specific tag:proto
  320. macro _GO_PROTO_CMD_IMPL(File, OPTS...) {
  321. .CMD=$GO_PROTO_CMDLINE $OPTS ${kv;hide:"p PB"} ${kv;hide:"pc yellow"}
  322. .PEERDIR=${GO_PROTOBUF_IMPORTS} ${GO_PROTOBUF_WELLKNOWN_TYPES}
  323. .ADDINCL=FOR proto ${PROTOBUF_INCLUDE_PATH}
  324. }
  325. # tag:go-specific tag:proto
  326. macro _GO_PROTO_CMD(File) {
  327. .CMD=$_GO_PROTO_CMD_IMPL($File $GO_PROTO_OPTS $GO_PROTO_OUTS)
  328. }
  329. # tag:proto
  330. ### @usage: YT_ORM_PROTO_YSON(Files... OUT_OPTS Opts...)
  331. ###
  332. ### Generate .yson.go from .proto using yt/yt/orm/go/codegen/yson/internal/proto-yson-gen/cmd/proto-yson-gen
  333. macro YT_ORM_PROTO_YSON(OUT_OPTS[], Files...) {
  334. .CMD=${cwd:BINDIR} $PROTOC --plugin=protoc-gen-custom=${tool:"yt/yt/orm/go/codegen/yson/internal/proto-yson-gen/cmd/proto-yson-gen"} -I=${ARCADIA_ROOT}/${PROTO_NAMESPACE} ${pre=-I=:_PROTO__INCLUDE} -I=${ARCADIA_ROOT} --custom_out="$OUT_OPTS paths=base_name:." --custom_opt="goroot=${GO_TOOLS_ROOT}" $_PROTOC_FLAGS ${input:Files} ${output;hide;noauto;nopath;noext;suf=.yson.go:Files} ${hide:PROTO_FAKEID}
  335. .ADDINCL=FOR proto ${ARCADIA_ROOT}/${MODDIR} FOR proto ${ARCADIA_ROOT}/${GO_TEST_IMPORT_PATH} FOR proto yt ${ARCADIA_BUILD_ROOT}/yt FOR proto ${PROTOBUF_INCLUDE_PATH}
  336. .PEERDIR=$GOSTD/strings $GOSTD/fmt $GOSTD/errors $GOSTD/encoding/json library/go/core/xerrors yt/go/yson yt/go/yterrors yt/yt/orm/go/codegen/yson/ytypes contrib/libs/protobuf
  337. }
  338. _SEM_CPP_PROTO_CMD=target_proto_messages PRIVATE ${input:File} \
  339. && target_options-privates-ITEM && target_options-privates-option target_proto_messages && target_options-privates-args ${input:File} \
  340. $CPP_PROTO_OUTS_SEM ${output;hide;suf=${OBJ_SUF}.pb.o:File} $DEFAULT_PROTOC_TOOLS \
  341. && set_global_flags COMMON_PROTOC_FLAGS \
  342. && platform_vars-COMMON_PROTOC_FLAGS "" \
  343. && target_proto_outs --cpp_out=$ARCADIA_BUILD_ROOT/$PROTO_NAMESPACE $PROTOC_STYLEGUIDE_OUT \
  344. && target_macroses-ITEM && target_macroses-macro target_proto_outs && target_macroses-args --cpp_out=$ARCADIA_BUILD_ROOT/$PROTO_NAMESPACE $PROTOC_STYLEGUIDE_OUT \
  345. && target_proto_addincls ./$PROTO_NAMESPACE $ARCADIA_ROOT/$PROTO_NAMESPACE ${_PROTO__INCLUDE} $ARCADIA_BUILD_ROOT $PROTOBUF_INCLUDE_PATH \
  346. && target_macroses-ITEM && target_macroses-macro target_proto_addincls && target_macroses-args ./$PROTO_NAMESPACE $ARCADIA_ROOT/$PROTO_NAMESPACE ${_PROTO__INCLUDE} $ARCADIA_BUILD_ROOT $PROTOBUF_INCLUDE_PATH
  347. # tag:proto
  348. macro _CPP_PROTO_CMD(File) {
  349. .CMD=$CPP_PROTO_CMDLINE $CPP_PROTO_OPTS ${kv;hide:"p PB"} ${kv;hide:"pc yellow"}
  350. .SEM=$_SEM_CPP_PROTO_CMD
  351. .PEERDIR=contrib/libs/protobuf
  352. }
  353. # tag:proto
  354. macro _CPP_VANILLA_PROTO_CMD(File) {
  355. .CMD=$CPP_PROTO_CMDLINE $CPP_PROTO_OPTS ${kv;hide:"p PB"} ${kv;hide:"pc yellow"}
  356. .PEERDIR=contrib/libs/protobuf_std
  357. }
  358. _SEM_CPP_EV_CMD=target_ev_messages PRIVATE ${input:File} \
  359. && target_options-privates-ITEM && target_options-privates-option target_ev_messages && target_options-privates-args ${input:File} \
  360. $CPP_EV_OUTS_SEM ${output;hide;suf=${OBJ_SUF}.pb.o:File} ${hide;tool:"tools/event2cpp/bin"} $DEFAULT_PROTOC_TOOLS \
  361. && set_global_flags COMMON_PROTOC_FLAGS \
  362. && platform_vars-COMMON_PROTOC_FLAGS "" \
  363. && target_proto_outs --cpp_out=$ARCADIA_BUILD_ROOT/$PROTO_NAMESPACE $PROTOC_STYLEGUIDE_OUT --event2cpp_out=$ARCADIA_BUILD_ROOT/$PROTO_NAMESPACE \
  364. && target_macroses-ITEM && target_macroses-macro target_proto_outs && target_macroses-args --cpp_out=$ARCADIA_BUILD_ROOT/$PROTO_NAMESPACE $PROTOC_STYLEGUIDE_OUT --event2cpp_out=$ARCADIA_BUILD_ROOT/$PROTO_NAMESPACE \
  365. && target_proto_addincls ./$PROTO_NAMESPACE $ARCADIA_ROOT/$PROTO_NAMESPACE ${_PROTO__INCLUDE} $ARCADIA_BUILD_ROOT $PROTOBUF_INCLUDE_PATH $ARCADIA_ROOT/library/cpp/eventlog \
  366. && target_macroses-ITEM && target_macroses-macro target_proto_addincls && target_macroses-args ./$PROTO_NAMESPACE $ARCADIA_ROOT/$PROTO_NAMESPACE ${_PROTO__INCLUDE} $ARCADIA_BUILD_ROOT $PROTOBUF_INCLUDE_PATH $ARCADIA_ROOT/library/cpp/eventlog
  367. # tag:proto
  368. macro _CPP_EVLOG_CMD(File) {
  369. .CMD=$CPP_EV_CMDLINE $CPP_EV_OPTS ${kv;hide:"p EV"} ${kv;hide:"pc yellow"}
  370. .SEM=$_SEM_CPP_EV_CMD
  371. .PEERDIR=library/cpp/eventlog contrib/libs/protobuf
  372. }
  373. # tag:proto
  374. macro _CPP_PROTO_EVLOG_CMD(File) {
  375. # process .proto as .ev
  376. .CMD=$CPP_PROTO_CMDLINE $CPP_EV_OPTS ${kv;hide:"p PB"} ${kv;hide:"pc yellow"}
  377. .PEERDIR=library/cpp/eventlog contrib/libs/protobuf
  378. }
  379. # tag:proto
  380. macro _CPP_CFGPROTO_CMD(File) {
  381. # keep extension in output just as in EV: this is hard-coded behaviour of protoc for non-.proto extensions
  382. .CMD=$CPP_EV_CMDLINE --plugin=protoc-gen-config=${tool:"library/cpp/proto_config/plugin"} --config_out=$ARCADIA_BUILD_ROOT/$PROTO_NAMESPACE ${kv;hide:"p PB"} ${kv;hide:"pc yellow"}
  383. .PEERDIR=library/cpp/proto_config/codegen library/cpp/proto_config/protos contrib/libs/protobuf
  384. }
  385. # tag:proto
  386. PY_PROTO_MYPY_ENABLED=yes
  387. PY_PROTO_MYPY_PLUGIN_BASE=--plugin=protoc-gen-mypy=${tool:"contrib/python/mypy-protobuf/bin/protoc-gen-mypy"} --mypy_out=$ARCADIA_BUILD_ROOT/$PROTO_NAMESPACE
  388. # tag:proto tag:python-specific
  389. PY_PROTO_MYPY_SUFFIX=
  390. PY_PROTO_MYPY_PLUGIN=
  391. PY_PROTO_MYPY_PLUGIN_INTERNAL=
  392. # tag:proto tag:python-specific
  393. macro NO_MYPY() {
  394. DISABLE(PY_PROTO_MYPY_ENABLED)
  395. }
  396. # tag:proto tag:python-specific
  397. macro _PY_PROTO_CMD_BASE(File, Suf, Args...) {
  398. .CMD=$PY_PROTOC -I=./$PROTO_NAMESPACE -I=$ARCADIA_ROOT/$PROTO_NAMESPACE ${pre=-I=:_PROTO__INCLUDE} -I=$ARCADIA_BUILD_ROOT -I=$PROTOBUF_INCLUDE_PATH --python_out=$ARCADIA_BUILD_ROOT/$PROTO_NAMESPACE $_PROTOC_FLAGS ${input;rootrel:File} ${output;main;hide;noauto;norel;nopath;noext;suf=$Suf:File} ${kv;hide:"p PB"} ${kv;hide:"pc yellow"} $Args ${hide:PROTO_FAKEID}
  399. }
  400. # tag:proto tag:python-specific
  401. macro _PY_PROTO_CMD(File) {
  402. .CMD=${cwd;rootdir;input:File} $_PY_PROTO_CMD_BASE($File _pb2.py $PY_PROTO_OPTS $PY_PROTO_OUTS $PY_PROTO_MYPY_PLUGIN)
  403. }
  404. # tag:proto tag:python-specific
  405. macro _PY_PROTO_CMD_INTERNAL(File) {
  406. .CMD=${cwd;rootdir;input:File} $GEN_PY_PROTOS --suffixes $PY_PROTO_SUFFIXES $PY_PROTO_MYPY_SUFFIX --input ${input;rootrel:File} --ns /$PROTO_NAMESPACE -- $_PY_PROTO_CMD_BASE($File __int${_PYTHON_VER}___pb2.py $PY_PROTO_OPTS $PY_PROTO_OUTS_INTERNAL ${hide;kv:"ext_out_name_for_${nopath;noext;suf=__int${_PYTHON_VER}___pb2.py:File} ${nopath;noext;suf=_pb2.py:File}"} $PY_PROTO_MYPY_PLUGIN_INTERNAL)
  407. }
  408. # tag:proto tag:java-specific
  409. JAVA_PROTO_RUNTIME=
  410. # tag:proto tag:java-specific
  411. ### @usage: USE_JAVALITE()
  412. ### Use protobuf-javalite for Java
  413. macro USE_JAVALITE() {
  414. SET(JAVA_PROTO_RUNTIME javalite)
  415. }
  416. # tag:proto tag:java-specific
  417. JAVA_PROTO_COMPILER_VERSION = 3.25.3
  418. JAVA_PROTO_RUNTIME_VERSION = 3.25.3
  419. JAVA_PROTO_COMMON_VERSION = 2.9.0
  420. JAVA_GRPC_VERSION = 1.51.0
  421. JAVA_NETTY_NETTY_VERSION = 4.1.79.Final
  422. KOTLIN_PROTO=no
  423. KOTLIN_PROTO_PEERS=
  424. when ($JAVA_PROTO_RUNTIME == "javalite") {
  425. _JAVA_PROTO_LITE_ARG=lite:
  426. JAVA_PROTOBUF_PEERS=contrib/java/com/google/protobuf/protobuf-javalite/${JAVA_PROTO_RUNTIME_VERSION} ${KOTLIN_PROTO_PEERS}
  427. JAVA_GRPC_STUB=contrib/java/io/grpc/grpc-stub/${JAVA_GRPC_VERSION}
  428. JAVA_GRPC_PROTOBUF=contrib/java/io/grpc/grpc-protobuf/${JAVA_GRPC_VERSION}
  429. }
  430. otherwise {
  431. _JAVA_PROTO_LITE_ARG=
  432. JAVA_PROTOBUF_PEERS=contrib/java/com/google/protobuf/protobuf-java/${JAVA_PROTO_RUNTIME_VERSION} ${KOTLIN_PROTO_PEERS}
  433. JAVA_GRPC_STUB=contrib/java/io/grpc/grpc-stub/${JAVA_GRPC_VERSION}
  434. JAVA_GRPC_PROTOBUF=contrib/java/io/grpc/grpc-protobuf/${JAVA_GRPC_VERSION}
  435. }
  436. KOTLIN_PROTO_FLAGS=
  437. # tag:proto tag:java-specific
  438. macro _JAVA_PROTO_CMD(File) {
  439. .CMD=${cwd;rootdir;input:File} $YMAKE_PYTHON ${input:"build/scripts/tared_protoc.py"} --tar-output ${output;norel;nopath;noext;suf=.jsrc:File} --protoc-out-dir $ARCADIA_BUILD_ROOT/java_out $JAVA_PROTOC -I=./$PROTO_NAMESPACE ${pre=-I=:_PROTO__INCLUDE} -I=$ARCADIA_ROOT --java_out=${_JAVA_PROTO_LITE_ARG}$ARCADIA_BUILD_ROOT/java_out ${KOTLIN_PROTO_FLAGS} $_PROTOC_FLAGS ${input;rootrel:File} ${kv;hide:"p PB"} ${kv;hide:"pc yellow"} $JAVA_PROTO_ARGS ${hide:PROTO_FAKEID}
  440. .SEM=proto_files ${input;rootrel:File} ${hide;output:File.jsrc}
  441. }
  442. # tag:proto tag:perl-specific tag:deprecated
  443. ### @usage: XS_PROTO(InputProto Dir Outputs...) # deprecated
  444. ###
  445. ### Generate Perl code from protobuf.
  446. ### In order to use this macro one should predict all outputs protoc will emit from input_proto file and enlist those as outputs.
  447. macro XS_PROTO(File, Dir, Outputs...) {
  448. .CMD=${PROTOC_OLD} -I=${ARCADIA_ROOT}/${Dir} ${pre=-I=:_PROTO__INCLUDE} -I=${ARCADIA_ROOT} -I=${PROTOBUF_OLD_PATH} --perlxs_out=${BINDIR} $_PROTOC_FLAGS ${input:File} ${hide;output:Outputs} ${induced_deps=h+cpp;hide;nopath;noext;suf=.pb.h:File} ${hide:PROTO_FAKEID}
  449. PEERDIR(${Dir})
  450. ADDINCL(${ARCADIA_BUILD_ROOT}/${Dir})
  451. }
  452. # tag:proto tag:python-specific
  453. when ($PY_PROTOS_FOR == "yes") {
  454. PEERDIR+=contrib/libs/protobuf/python
  455. }
  456. # tag:python-specific
  457. macro _PY_EVLOG_CMD_BASE(File, Suf, Args...) {
  458. .CMD=$_PY_PROTO_CMD_BASE($File $Suf $Args)
  459. .PEERDIR=library/cpp/eventlog/proto
  460. }
  461. # tag:python-specific tag:proto
  462. macro _PY_EVLOG_CMD(File) {
  463. .CMD=${cwd;rootdir;input:File} $_PY_EVLOG_CMD_BASE($File _ev_pb2.py)
  464. }
  465. # tag:python-specific tag:proto
  466. macro _PY_EVLOG_CMD_INTERNAL(File) {
  467. .CMD=${cwd;rootdir;input:File} $GEN_PY_PROTOS --suffixes $PY_EVLOG_SUFFIXES --input ${input;rootrel:File} --ns /$PROTO_NAMESPACE -- $_PY_EVLOG_CMD_BASE($File __int${_PYTHON_VER}___ev_pb2.py ${hide;kv:"ext_out_name_for_${nopath;noext;suf=__int${_PYTHON_VER}___ev_pb2.py:File} ${nopath;noext;suf=_ev_pb2.py:File}"})
  468. }
  469. # tag:java-specific tag:proto
  470. macro _JAVA_EVLOG_CMD(File) {
  471. .CMD=$COPY_CMD ${input:File} ${output;nopath;noext;norel;suf=_ev.proto:File} ${kv;hide:"p EV"} ${kv;hide:"pc yellow"}
  472. .PEERDIR=library/cpp/eventlog/proto
  473. }
  474. # tag:proto tag:grpc
  475. _GRPC_ENABLED=no
  476. _GRPC_SUF_CC=.grpc.pb.cc
  477. _GRPC_SUF_H=.grpc.pb.h
  478. # tag:proto tag:grpc
  479. ### @usage: GRPC()
  480. ###
  481. ### Emit GRPC code for all .proto files in a PROTO_LIBRARY.
  482. ### This works for all available PROTO_LIBRARY versions (C++, Python 2.x, Python 3.x, Java and Go).
  483. macro GRPC() {
  484. ENABLE(_GRPC_ENABLED)
  485. # C++
  486. CPP_PROTO_PLUGIN2(grpc_cpp contrib/tools/protoc/plugins/grpc_cpp $_GRPC_SUF_CC $_GRPC_SUF_H DEPS contrib/libs/grpc $_GRPC_GMOCK_OUTFLAG)
  487. # Python
  488. PY_PROTO_PLUGIN(grpc_py _pb2_grpc.py contrib/tools/protoc/plugins/grpc_python DEPS contrib/python/grpcio)
  489. # Java
  490. JAVA_PROTO_PLUGIN(grpc_java build/platform/java/grpc DEPS $JAVA_GRPC_STUB $JAVA_GRPC_PROTOBUF)
  491. SET_APPEND(JAVA_PROTOBUF_PEERS contrib/java/javax/annotation/javax.annotation-api/1.3.1)
  492. }
  493. # tag:proto tag:grpc
  494. _GRPC_GMOCK_OUTFLAG=
  495. # tag:proto tag:grpc
  496. ### @usage: WITH_GMOCK()
  497. ###
  498. ### Enable generating *_mock.grpc.pb.cc/h files
  499. macro GRPC_WITH_GMOCK() {
  500. SET(_GRPC_GMOCK_OUTFLAG EXTRA_OUT_FLAG generate_mock_code=true)
  501. GRPC()
  502. _ADD_CPP_PROTO_OUT(_mock$_GRPC_SUF_H)
  503. SET_APPEND(CPP_PROTO_OUTS_SEM ${output;hide;norel;nopath;noext;suf=_mock$_GRPC_SUF_H:File})
  504. }
  505. macro GO_PROTO_USE_V2() {
  506. ENABLE(GO_PROTO_V2)
  507. }
  508. # tag:proto
  509. ### @usage: RESOLVE_PROTO()
  510. ###
  511. ### Enable include resolving within UNIONs and let system .proto being resolved
  512. ### among .proto/.gztproto imports
  513. ###
  514. ### Note: it is currently impossible to enable resolving only for .proto, so resolving is enabled for all supported files
  515. ### also we only add ADDINCL for stock protobuf. So use this macro with care: it may cause resolving problems those are
  516. ### to be addressed by either ADDINCLs or marking them as TEXT. Please contact devtools for details.
  517. macro RESOLVE_PROTO() {
  518. SET(DONT_RESOLVE_INCLUDES no)
  519. ADDINCL(FOR proto $PROTOBUF_INCLUDE_PATH)
  520. }
  521. # tag:python-specific tag:proto tag:deprecated
  522. ### @usage GENERATE_PY_PROTOS(ProtoFiles...) # deprecated
  523. ###
  524. ### Generate python bindings for protobuf files.
  525. ### Macro is obsolete and not recommended for use!
  526. macro GENERATE_PY_PROTOS(FILES...) {
  527. foreach (FILE : $FILES) {
  528. _PY_PROTO_CMD($FILE)
  529. }
  530. }
  531. # tag:python-specific tag:proto
  532. macro _GENERATE_PY_PROTOS_INTERNAL(FILES...) {
  533. foreach (FILE : $FILES) {
  534. _PY_PROTO_CMD_INTERNAL($FILE)
  535. }
  536. }
  537. # tag:python-specific
  538. macro _GENERATE_PY_EVS_INTERNAL(FILES...) {
  539. foreach (FILE : $FILES) {
  540. _PY_EVLOG_CMD_INTERNAL($FILE)
  541. }
  542. }
  543. ### @usage: LIST_PROTO([TO list.proto] Files...) # deprecated
  544. ###
  545. ### Create list of .proto files in a list-file (should be .proto, files.proto by default)
  546. ### with original .proto-files as list's dependencies.
  547. ###
  548. ### This allows to process files listed, passing list as an argument to the processor
  549. ###
  550. ### TODO: proper implementation needed
  551. macro LIST_PROTO(TO="files.proto", Files...) {
  552. .CMD=$YMAKE_PYTHON3 ${input:"build/scripts/list.py"} ${Files} ${input;hide:Files} ${stdout;output;noauto:TO} ${output_include;from_input;hide:Files}
  553. _COMPILE_LIST_PROTO(${TO})
  554. _EXPOSE(${TO})
  555. }
  556. macro _COMPILE_LIST_PROTO(SRC) {
  557. .CMD=$YMAKE_PYTHON ${input:"build/scripts/touch.py"} ${input;hide:SRC} ${output;noext;suf=.pb.h:SRC}
  558. }
  559. # tag:proto
  560. macro _PROTO_DESC_RAWPROTO_CMD(File) {
  561. .CMD=${cwd;rootdir;input:File} $YMAKE_PYTHON3 ${input:"build/scripts/desc_rawproto_wrapper.py"} --desc-output ${output;suf=.desc:File} --rawproto-output ${output;norel;suf=.${_MODDIR_HASH}.rawproto:File} --proto-file ${input;rootrel:File} -- $PROTOC -I=./$PROTO_NAMESPACE -I=$ARCADIA_ROOT/$PROTO_NAMESPACE ${pre=-I=:_PROTO__INCLUDE} -I=$ARCADIA_BUILD_ROOT -I=$PROTOBUF_INCLUDE_PATH --include_source_info $_PROTOC_FLAGS ${hide:PROTO_FAKEID}
  562. }
  563. _PROTO_DESC_MERGE_CMD=$YMAKE_PYTHON3 ${input:"build/scripts/merge_files.py"} $TARGET ${ext=.desc:AUTO_INPUT} ${kv;hide:"p PD"} ${kv;hide:"pc light-cyan"} && ${cwd:ARCADIA_BUILD_ROOT} $YMAKE_PYTHON3 ${input:"build/scripts/collect_rawproto.py"} --output ${output;suf=.protosrc:REALPRJNAME} ${rootrel;ext=.rawproto:AUTO_INPUT}
  564. _PROTO_DESC_MERGE_PEERS_CMD=$YMAKE_PYTHON3 ${input:"build/scripts/merge_files.py"} $TARGET $PEERS ${ext=.protodesc:SRCS_GLOBAL} ${kv;hide:"p PD"} ${kv;hide:"pc light-cyan"} && ${cwd:ARCADIA_BUILD_ROOT} $YMAKE_PYTHON3 ${input:"build/scripts/merge_protosrc.py"} --output ${output;suf=.tar:REALPRJNAME} ${rootrel:PEERS}
  565. NEED_GOOGLE_PROTO_PEERDIRS=yes
  566. CPP_PROTO_LIBRARY_SEM=$CPP_LIBRARY_SEM
  567. JAVA_PROTO_LIBRARY_SEM=$BUILD_PROTO_JAR_SEM $_GRADLE_EXPORT_PUBLISHING_SEM
  568. # tag:proto
  569. ### @usage: PROTO_LIBRARY()
  570. ###
  571. ### Build some varian of protocol buffers library.
  572. ###
  573. ### The particular variant is selected based on where PEERDIR to PROTO_LIBRARY comes from.
  574. ###
  575. ### Now supported 5 variants: C++, Java, Python 2.x, Python 3.x and Go.
  576. ### When PEERDIR comes from module for particular language appropriate variant is selected.
  577. ### PROTO_LIBRARY also supports emission of GRPC code if GRPC() macro is specified.
  578. ### Notes:
  579. ### - Python versions emit C++ code in addition to Python as optimization.
  580. ### - In some PROTO_LIBRARY-es Java or Python versions are excluded via EXCLUDE_TAGS macros due to incompatibilities.
  581. ### - Use from DEPENDS or BUNDLE is not allowed
  582. ###
  583. ### Documentation: https://wiki.yandex-team.ru/yatool/proto_library/
  584. ###
  585. ### See: [GRPC()](#macro_GRPC), [OPTIMIZE_PY_PROTOS()](#macro_OPTIMIZE_PY_PROTOS), [INCLUDE_TAGS()](#macro_INCLUDE_TAGS), [EXCLUDE_TAGS()](#macro_EXCLUDE_TAGS)
  586. multimodule PROTO_LIBRARY {
  587. module CPP_PROTO : LIBRARY {
  588. .ALLOWED=_EXPOSE LIST_PROTO
  589. # TODO(svidyuk): think about marker which forces semantics inheritance
  590. .SEM=CPP_PROTO_LIBRARY_SEM
  591. FORCE_COVERAGE_DISABLED=yes
  592. ENABLE(CPP_PROTO)
  593. ENABLE(GEN_PROTO)
  594. NO_CLANG_TIDY()
  595. CPP_PROTOLIBS_DEBUG_INFO()
  596. SET(PEERDIR_TAGS CPP_PROTO)
  597. when ($BUILD_PROTO_AS_EVLOG == "yes" && $USE_VANILLA_PROTOC == "yes") {
  598. _OK=no
  599. }
  600. ASSERT(_OK BUILD_PROTO_AS_EVLOG and USE_VANILLA_PROTOC are incompatible yet)
  601. MODULE_SUFFIX=$_CPP_PROTO_MODULE_SUFFIX
  602. MODULE_PREFIX=$_CPP_PROTO_MODULE_PREFIX
  603. when ($_COMMON_GOOGLE_APIS != "None") {
  604. PEERDIR += contrib/libs/googleapis-common-protos
  605. }
  606. }
  607. module JAVA_PROTO: EXTERNAL_JAVA_LIBRARY {
  608. .EXTS=.jsrc
  609. .ALLOWED=GRPC
  610. .SEM=JAVA_PROTO_LIBRARY_SEM
  611. SET(PEERDIR_TAGS JAVA JAVA_PROTO)
  612. ENABLE(JAVA_PROTO)
  613. DISABLE(_NEED_SBOM_INFO)
  614. PEERDIR+=$JAVA_PROTOBUF_PEERS
  615. when ($KOTLIN_PROTO == "yes") {
  616. KOTLIN_PROTO_PEERS=contrib/java/com/google/protobuf/protobuf-kotlin/${JAVA_PROTO_RUNTIME_VERSION}
  617. KOTLIN_PROTO_FLAGS=--kotlin_out=$ARCADIA_BUILD_ROOT/java_out
  618. }
  619. when ($GRADLE_EXPORT_PUBLISHING == "yes") {
  620. _GRADLE_EXPORT_PUBLISHING_SEM=$_DO_GRADLE_EXPORT_PUBLISHING_SEM
  621. }
  622. .IGNORED=GENERATE_ENUM_SERIALIZATION GENERATE_ENUM_SERIALIZATION_WITH_HEADER USE_SKIFF CPP_PROTO_PLUGIN2 PY_PROTO_PLUGIN YMAPS_SPROTO RESOURCE
  623. ADDINCL(FOR proto $PROTOBUF_INCLUDE_PATH)
  624. when ($_COMMON_GOOGLE_APIS != "None") {
  625. PEERDIR += contrib/java/com/google/api/grpc/proto-google-common-protos/${JAVA_PROTO_COMMON_VERSION}
  626. ADDINCL += GLOBAL FOR proto ${ARCADIA_ROOT}/contrib/libs/googleapis-common-protos
  627. }
  628. }
  629. module PY_PROTO: PY2_LIBRARY {
  630. .ALIASES=SRCS=PY_SRCS
  631. .ALLOWED=OPTIMIZE_PY_PROTOS NO_OPTIMIZE_PY_PROTOS
  632. .PEERDIRSELF=CPP_PROTO
  633. .SEM=IGNORED
  634. SET(PEERDIR_TAGS PY2 PY_PROTO)
  635. ENABLE(PY_PROTO)
  636. DISABLE(_NEED_SBOM_INFO)
  637. OPTIMIZE_PY_PROTOS()
  638. OBJ_SUF=.py2
  639. # Can not use NO_LINT(), because is not allowed outside of contrib directory
  640. SET(_NO_LINT_VALUE none_internal)
  641. when ($_COMMON_GOOGLE_APIS != "None") {
  642. PEERDIR += contrib/libs/googleapis-common-protos
  643. }
  644. _IGNORE_SELF_PEERS=
  645. _CPP_PROTO_LIBRARY=${MODDIR}/$_CPP_PROTO_MODULE_PREFIX$REALPRJNAME$_CPP_PROTO_MODULE_SUFFIX
  646. when ($OPTIMIZE_PY_PROTOS_FLAG == "no") {
  647. _IGNORE_PEERDIRSELF=CPP_PROTO
  648. }
  649. SET_APPEND(_WHOLE_ARCHIVE_LIBS_VALUE_GLOBAL $_CPP_PROTO_LIBRARY)
  650. }
  651. module PY3_PROTO: PY3_LIBRARY {
  652. .ALIASES=SRCS=PY_SRCS
  653. .ALLOWED=OPTIMIZE_PY_PROTOS NO_OPTIMIZE_PY_PROTOS
  654. .PEERDIRSELF=CPP_PROTO
  655. .SEM=IGNORED
  656. SET(PEERDIR_TAGS PY3 PY3_PROTO)
  657. ENABLE(PY3_PROTO)
  658. DISABLE(_NEED_SBOM_INFO)
  659. OPTIMIZE_PY_PROTOS()
  660. OBJ_SUF=.py3
  661. # Can not use NO_LINT(), because is not allowed outside of contrib directory
  662. SET(_NO_LINT_VALUE none_internal)
  663. when ($_COMMON_GOOGLE_APIS != "None") {
  664. PEERDIR += contrib/libs/googleapis-common-protos
  665. }
  666. _IGNORE_SELF_PEERS=
  667. _CPP_PROTO_LIBRARY=${MODDIR}/$_CPP_PROTO_MODULE_PREFIX$REALPRJNAME$_CPP_PROTO_MODULE_SUFFIX
  668. when ($OPTIMIZE_PY_PROTOS_FLAG == "no") {
  669. _IGNORE_PEERDIRSELF=CPP_PROTO
  670. }
  671. SET_APPEND(_WHOLE_ARCHIVE_LIBS_VALUE_GLOBAL $_CPP_PROTO_LIBRARY)
  672. }
  673. module GO_PROTO: GO_LIBRARY {
  674. .IGNORED=GENERATE_ENUM_SERIALIZATION GENERATE_ENUM_SERIALIZATION_WITH_HEADER YMAPS_SPROTO
  675. .SEM=IGNORED
  676. SET(PEERDIR_TAGS GO GO_PROTO)
  677. ENABLE(GO_PROTO)
  678. when ($_COMMON_GOOGLE_APIS == "None") {
  679. }
  680. elsewhen ($_COMMON_GOOGLE_APIS == "") {
  681. PEERDIR += $_GO_COMMON_GOOGLE_APIS
  682. ADDINCL += GLOBAL FOR proto ${ARCADIA_ROOT}/contrib/libs/googleapis-common-protos
  683. }
  684. otherwise {
  685. PEERDIR += $_COMMON_GOOGLE_APIS
  686. ADDINCL += GLOBAL FOR proto ${ARCADIA_ROOT}/contrib/libs/googleapis-common-protos
  687. }
  688. }
  689. module TS_PROTO: _TS_PROTO_IMPL {
  690. # opt-in. We don't want to have TS_PROTO by default
  691. # To include TS_PROTO user have to set INCLUDE_TAGS(TS_PROTO) in ya.make
  692. .INCLUDE_TAG=no
  693. .EPILOGUE=_TS_CONFIG_EPILOGUE
  694. .PEERDIRSELF=TS_PREPARE_DEPS
  695. DISABLE(_NEED_SBOM_INFO)
  696. }
  697. module TS_PREPARE_DEPS: _PREPARE_DEPS_BASE {
  698. .INCLUDE_TAG=no
  699. .IGNORED=PEERDIR
  700. DISABLE(_NEED_SBOM_INFO)
  701. }
  702. module DESC_PROTO: _BARE_UNIT {
  703. .CMD=_PROTO_DESC_MERGE_CMD
  704. .SEM=IGNORED
  705. .EXTS=.desc .rawproto
  706. .NODE_TYPE=Library
  707. .IGNORED=GENERATE_ENUM_SERIALIZATION GENERATE_ENUM_SERIALIZATION_WITH_HEADER YMAPS_SPROTO RESOURCE GO_PROTO_PLUGIN GRPC
  708. .ALIASES=SRCS=_SRCS_NO_GLOBAL
  709. SET(PEERDIR_TAGS DESC_PROTO)
  710. ENABLE(DESC_PROTO)
  711. DISABLE(_NEED_SBOM_INFO)
  712. MODULE_SUFFIX=.self.protodesc
  713. SET(MODULE_TYPE LIBRARY)
  714. SET(_MODDIR_HASH ${hash:MODDIR})
  715. _EVLOG_CMDLINE=$_PROTO_DESC_CMDLINE
  716. _PROTO_CMDLINE=$_PROTO_DESC_CMDLINE
  717. when ($_COMMON_GOOGLE_APIS != "None") {
  718. PEERDIR += contrib/libs/googleapis-common-protos
  719. }
  720. when ($NEED_GOOGLE_PROTO_PEERDIRS == "yes") {
  721. when ($USE_VANILLA_PROTOC == "yes") {
  722. PEERDIR += contrib/libs/protobuf_std/builtin_proto/protos_from_protobuf
  723. }
  724. otherwise {
  725. PEERDIR += contrib/libs/protobuf/builtin_proto/protos_from_protoc
  726. }
  727. }
  728. }
  729. }
  730. module PROTO_DESCRIPTIONS: _BARE_UNIT {
  731. .CMD=_PROTO_DESC_MERGE_PEERS_CMD
  732. .PEERDIR_POLICY=as_build_from
  733. .NODE_TYPE=Library
  734. .RESTRICTED=SRCS
  735. .FINAL_TARGET=yes
  736. SET(MODULE_TAG PROTO_DESCRIPTIONS)
  737. SET(PEERDIR_TAGS DESC_PROTO)
  738. SET(MODULE_SUFFIX .protodesc)
  739. SET(MODULE_TYPE PROTO_DESCRIPTIONS)
  740. }
  741. module PROTO_REGISTRY: PROTO_DESCRIPTIONS {
  742. SET(MODULE_TAG PROTO_REGISTRY)
  743. SET(MODULE_TYPE PROTO_REGISTRY)
  744. }
  745. macro EVLOG_CMD(SRC) {
  746. .CMD=$_EVLOG_CMDLINE
  747. .SEM=$_EVLOG_CMDLINE
  748. }
  749. macro PROTO_CMD(SRC) {
  750. .CMD=$_PROTO_CMDLINE
  751. .SEM=$_PROTO_CMDLINE
  752. }
  753. _CPP_EVLOG_CMDLINE=$_CPP_EVLOG_CMD($SRC)
  754. _CPP_PROTO_CMDLINE=$_CPP_PROTO_CMD($SRC)
  755. _CPP_PROTO_EVLOG_CMDLINE=$_CPP_PROTO_EVLOG_CMD($SRC)
  756. _CPP_VANILLA_PROTO_CMDLINE=$_CPP_VANILLA_PROTO_CMD($SRC)
  757. _JAVA_EVLOG_CMDLINE=$_JAVA_EVLOG_CMD($SRC)
  758. _JAVA_PROTO_CMDLINE=$_JAVA_PROTO_CMD($SRC)
  759. _PROTO_DESC_CMDLINE=$_PROTO_DESC_RAWPROTO_CMD($SRC)
  760. _PY_EVLOG_CMDLINE=$_PY_EVLOG_CMD($SRC)
  761. _PY_PROTO_CMDLINE=$_PY_PROTO_CMD($SRC)