diff options
author | dimdim11 <dimdim11@yandex-team.com> | 2024-03-21 17:31:46 +0300 |
---|---|---|
committer | dimdim11 <dimdim11@yandex-team.com> | 2024-03-21 18:13:49 +0300 |
commit | a3786143c42fa67f7f22e8258d17985ca35b13de (patch) | |
tree | dfff4696511abe4a1fc92ef2dd07528bf1b4599f | |
parent | b2e858b03f5a3a6209ff4803af9f464ba01a47aa (diff) | |
download | ydb-a3786143c42fa67f7f22e8258d17985ca35b13de.tar.gz |
Add vanilla_protobuf attribute and logic in cmake generator
Add vanilla_protobuf attribute and logic in cmake generator
4019392e1b6894819bd2ea0a1601539803f333e8
-rw-r--r-- | build/export_generators/hardcoded-cmake/cmake/protobuf.cmake | 90 | ||||
-rw-r--r-- | build/export_generators/hardcoded-cmake/root_cmake_lists.jinja | 5 |
2 files changed, 45 insertions, 50 deletions
diff --git a/build/export_generators/hardcoded-cmake/cmake/protobuf.cmake b/build/export_generators/hardcoded-cmake/cmake/protobuf.cmake index a445e8b7d2..4588ad4ff5 100644 --- a/build/export_generators/hardcoded-cmake/cmake/protobuf.cmake +++ b/build/export_generators/hardcoded-cmake/cmake/protobuf.cmake @@ -21,53 +21,34 @@ function(target_proto_outs Tgt) ) endfunction() -function(target_proto_messages Tgt Scope) - get_built_tool_path(protoc_bin protoc_dependency contrib/tools/protoc/bin protoc) - get_built_tool_path(cpp_styleguide_bin cpp_styleguide_dependency contrib/tools/protoc/plugins/cpp_styleguide cpp_styleguide) +function(target_messages Tgt Scope UseStyleguide UseEvent2Cpp) + if (vanilla_protobuf STREQUAL "yes") + set(protoc_bin ${PROJECT_BINARY_DIR}/bin/protoc${CMAKE_EXECUTABLE_SUFFIX}) + set(protoc_dependency "") + set(UseStyleguide "no") # cpp_styleguide can't compile with vanilla protobuf + else() + get_built_tool_path(protoc_bin protoc_dependency "contrib/tools/protoc/bin" "protoc") + endif() - get_property(ProtocExtraOutsSuf TARGET ${Tgt} PROPERTY PROTOC_EXTRA_OUTS) - foreach(proto ${ARGN}) - if(proto MATCHES ${PROJECT_BINARY_DIR}) - file(RELATIVE_PATH protoRel ${PROJECT_BINARY_DIR} ${proto}) - elseif (proto MATCHES ${PROJECT_SOURCE_DIR}) - file(RELATIVE_PATH protoRel ${PROJECT_SOURCE_DIR} ${proto}) - else() - set(protoRel ${proto}) - endif() - get_filename_component(OutputBase ${protoRel} NAME_WLE) - get_filename_component(OutputDir ${PROJECT_BINARY_DIR}/${protoRel} DIRECTORY) - list(TRANSFORM ProtocExtraOutsSuf PREPEND ${OutputDir}/${OutputBase} OUTPUT_VARIABLE ProtocExtraOuts) - add_custom_command( - OUTPUT - ${OutputDir}/${OutputBase}.pb.cc - ${OutputDir}/${OutputBase}.pb.h - ${ProtocExtraOuts} - COMMAND ${protoc_bin} - ${COMMON_PROTOC_FLAGS} - "-I$<JOIN:$<TARGET_GENEX_EVAL:${Tgt},$<TARGET_PROPERTY:${Tgt},PROTO_ADDINCL>>,;-I>" - "$<JOIN:$<TARGET_GENEX_EVAL:${Tgt},$<TARGET_PROPERTY:${Tgt},PROTO_OUTS>>,;>" - --plugin=protoc-gen-cpp_styleguide=${cpp_styleguide_bin} - "$<JOIN:$<TARGET_GENEX_EVAL:${Tgt},$<TARGET_PROPERTY:${Tgt},PROTOC_OPTS>>,;>" - ${protoRel} - DEPENDS - ${proto} - $<TARGET_PROPERTY:${Tgt},PROTOC_DEPS> - ${protoc_dependency} - ${cpp_styleguide_dependency} - WORKING_DIRECTORY ${PROJECT_SOURCE_DIR} - COMMAND_EXPAND_LISTS - ) - target_sources(${Tgt} ${Scope} - ${OutputDir}/${OutputBase}.pb.cc ${OutputDir}/${OutputBase}.pb.h - ${ProtocExtraOuts} - ) - endforeach() -endfunction() + if (UseStyleguide STREQUAL "yes") + get_built_tool_path(cpp_styleguide_bin cpp_styleguide_dependency "contrib/tools/protoc/plugins/cpp_styleguide" "cpp_styleguide") + set(protoc_styleguide_plugin --plugin=protoc-gen-cpp_styleguide=${cpp_styleguide_bin}) + else() + set(protoc_styleguide_plugin "") + set(cpp_styleguide_dependency "") + endif() -function(target_ev_messages Tgt Scope) - get_built_tool_path(protoc_bin protoc_dependency contrib/tools/protoc/bin protoc) - get_built_tool_path(cpp_styleguide_bin cpp_styleguide_dependency contrib/tools/protoc/plugins/cpp_styleguide cpp_styleguide) - get_built_tool_path(event2cpp_bin event2cpp_dependency tools/event2cpp/bin event2cpp) + if (UseEvent2Cpp STREQUAL "yes") + get_built_tool_path(event2cpp_bin event2cpp_dependency "tools/event2cpp/bin" "event2cpp") + set(protoc_event2cpp_plugin --plugin=protoc-gen-event2cpp=${event2cpp_bin}) + set(ext_h ".ev.pb.h") + set(ext_c ".ev.pb.cc") + else() + set(protoc_event2cpp_plugin "") + set(event2cpp_dependency "") + set(ext_h ".pb.h") + set(ext_c ".pb.cc") + endif() get_property(ProtocExtraOutsSuf TARGET ${Tgt} PROPERTY PROTOC_EXTRA_OUTS) foreach(proto ${ARGN}) @@ -83,17 +64,18 @@ function(target_ev_messages Tgt Scope) list(TRANSFORM ProtocExtraOutsSuf PREPEND ${OutputDir}/${OutputBase} OUTPUT_VARIABLE ProtocExtraOuts) add_custom_command( OUTPUT - ${OutputDir}/${OutputBase}.ev.pb.cc - ${OutputDir}/${OutputBase}.ev.pb.h + ${OutputDir}/${OutputBase}${ext_c} + ${OutputDir}/${OutputBase}${ext_h} ${ProtocExtraOuts} COMMAND ${protoc_bin} ${COMMON_PROTOC_FLAGS} "-I$<JOIN:$<TARGET_GENEX_EVAL:${Tgt},$<TARGET_PROPERTY:${Tgt},PROTO_ADDINCL>>,;-I>" "$<JOIN:$<TARGET_GENEX_EVAL:${Tgt},$<TARGET_PROPERTY:${Tgt},PROTO_OUTS>>,;>" - --plugin=protoc-gen-cpp_styleguide=${cpp_styleguide_bin} - --plugin=protoc-gen-event2cpp=${event2cpp_bin} + ${protoc_styleguide_plugin} + ${protoc_event2cpp_plugin} "$<JOIN:$<TARGET_GENEX_EVAL:${Tgt},$<TARGET_PROPERTY:${Tgt},PROTOC_OPTS>>,;>" ${protoRel} + COMMAND sed -s -i 's/final :/:/g' ${OutputDir}/${OutputBase}${ext_c} ${OutputDir}/${OutputBase}${ext_h} DEPENDS ${proto} $<TARGET_PROPERTY:${Tgt},PROTOC_DEPS> @@ -104,8 +86,16 @@ function(target_ev_messages Tgt Scope) COMMAND_EXPAND_LISTS ) target_sources(${Tgt} ${Scope} - ${OutputDir}/${OutputBase}.ev.pb.cc ${OutputDir}/${OutputBase}.ev.pb.h + ${OutputDir}/${OutputBase}${ext_c} ${OutputDir}/${OutputBase}${ext_h} ${ProtocExtraOuts} ) endforeach() endfunction() + +function(target_proto_messages Tgt Scope) + target_messages(${Tgt} ${Scope} "yes" "no" ${ARGN}) +endfunction() + +function(target_ev_messages Tgt Scope) + target_messages(${Tgt} ${Scope} "yes" "yes" ${ARGN}) +endfunction() diff --git a/build/export_generators/hardcoded-cmake/root_cmake_lists.jinja b/build/export_generators/hardcoded-cmake/root_cmake_lists.jinja index 5c564061ef..d98b691fe9 100644 --- a/build/export_generators/hardcoded-cmake/root_cmake_lists.jinja +++ b/build/export_generators/hardcoded-cmake/root_cmake_lists.jinja @@ -39,6 +39,11 @@ else() CONF "tools.cmake.cmaketoolchain:generator=${CMAKE_GENERATOR}" ) endif(){% endif %} + +{%- if vanilla_protobuf %} +set(vanilla_protobuf "yes") +{%- endif -%} + {% set platforms_count = platform_names|length -%} {% if platforms_count > 0 -%} {% for i in range(platforms_count) %} |