Commit c2044022 authored by Feng Xiao's avatar Feng Xiao Committed by GitHub

Merge pull request #3675 from hesmar/hesmar/cmakeAddDllExport

protobuf_generate: add EXPORT_MACRO option
parents c6275309 9829b8f5
...@@ -11,7 +11,7 @@ function(protobuf_generate) ...@@ -11,7 +11,7 @@ function(protobuf_generate)
include(CMakeParseArguments) include(CMakeParseArguments)
set(_options APPEND_PATH) set(_options APPEND_PATH)
set(_singleargs LANGUAGE OUT_VAR) set(_singleargs LANGUAGE OUT_VAR EXPORT_MACRO)
if(COMMAND target_sources) if(COMMAND target_sources)
list(APPEND _singleargs TARGET) list(APPEND _singleargs TARGET)
endif() endif()
...@@ -34,6 +34,10 @@ function(protobuf_generate) ...@@ -34,6 +34,10 @@ function(protobuf_generate)
endif() endif()
string(TOLOWER ${protobuf_generate_LANGUAGE} protobuf_generate_LANGUAGE) string(TOLOWER ${protobuf_generate_LANGUAGE} protobuf_generate_LANGUAGE)
if(protobuf_generate_EXPORT_MACRO AND protobuf_generate_LANGUAGE STREQUAL cpp)
set(_dll_export_decl "dllexport_decl=${protobuf_generate_EXPORT_MACRO}:")
endif()
if(NOT protobuf_GENERATE_EXTENSIONS) if(NOT protobuf_GENERATE_EXTENSIONS)
if(protobuf_generate_LANGUAGE STREQUAL cpp) if(protobuf_generate_LANGUAGE STREQUAL cpp)
set(protobuf_GENERATE_EXTENSIONS .pb.h .pb.cc) set(protobuf_GENERATE_EXTENSIONS .pb.h .pb.cc)
...@@ -95,7 +99,7 @@ function(protobuf_generate) ...@@ -95,7 +99,7 @@ function(protobuf_generate)
add_custom_command( add_custom_command(
OUTPUT ${_generated_srcs} OUTPUT ${_generated_srcs}
COMMAND protobuf::protoc COMMAND protobuf::protoc
ARGS --${protobuf_generate_LANGUAGE}_out ${CMAKE_CURRENT_BINARY_DIR} ${_protobuf_include_path} ${_abs_file} ARGS --${protobuf_generate_LANGUAGE}_out ${_dll_export_decl}${CMAKE_CURRENT_BINARY_DIR} ${_protobuf_include_path} ${_abs_file}
DEPENDS ${ABS_FIL} protobuf::protoc DEPENDS ${ABS_FIL} protobuf::protoc
COMMENT "Running ${protobuf_generate_LANGUAGE} protocol buffer compiler on ${_proto}" COMMENT "Running ${protobuf_generate_LANGUAGE} protocol buffer compiler on ${_proto}"
VERBATIM ) VERBATIM )
......
...@@ -2,7 +2,10 @@ ...@@ -2,7 +2,10 @@
# Functions # Functions
function(PROTOBUF_GENERATE_CPP SRCS HDRS) function(PROTOBUF_GENERATE_CPP SRCS HDRS)
if(NOT ARGN) cmake_parse_arguments(protobuf_generate_cpp "" "EXPORT_MACRO" "" ${ARGN})
set(_proto_files "${protobuf_generate_cpp_UNPARSED_ARGUMENTS}")
if(NOT _proto_files)
message(SEND_ERROR "Error: PROTOBUF_GENERATE_CPP() called without any proto files") message(SEND_ERROR "Error: PROTOBUF_GENERATE_CPP() called without any proto files")
return() return()
endif() endif()
...@@ -16,7 +19,7 @@ function(PROTOBUF_GENERATE_CPP SRCS HDRS) ...@@ -16,7 +19,7 @@ function(PROTOBUF_GENERATE_CPP SRCS HDRS)
endif() endif()
set(_outvar) set(_outvar)
protobuf_generate(${append_arg} LANGUAGE cpp OUT_VAR _outvar ${_import_arg} PROTOS ${ARGN}) protobuf_generate(${append_arg} LANGUAGE cpp EXPORT_MACRO ${protobuf_generate_cpp_EXPORT_MACRO} OUT_VAR _outvar ${_import_arg} PROTOS ${_proto_files})
set(${SRCS}) set(${SRCS})
set(${HDRS}) set(${HDRS})
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment