Index: third_party/protobuf/cmake/protobuf-module.cmake.in |
diff --git a/third_party/protobuf/cmake/protobuf-module.cmake.in b/third_party/protobuf/cmake/protobuf-module.cmake.in |
index d81dc459b6a54134c629d7464681e826f6dc4d26..614e4c045454361797490293359c6b1a982d56ea 100644 |
--- a/third_party/protobuf/cmake/protobuf-module.cmake.in |
+++ b/third_party/protobuf/cmake/protobuf-module.cmake.in |
@@ -1,7 +1,4 @@ |
-if(PROTOBUF_SRC_ROOT_FOLDER) |
- message(AUTHOR_WARNING "Variable PROTOBUF_SRC_ROOT_FOLDER defined, but not" |
- " used in CONFIG mode") |
-endif() |
+# Functions |
function(PROTOBUF_GENERATE_CPP SRCS HDRS) |
if(NOT ARGN) |
@@ -23,12 +20,8 @@ function(PROTOBUF_GENERATE_CPP SRCS HDRS) |
set(_protobuf_include_path -I ${CMAKE_CURRENT_SOURCE_DIR}) |
endif() |
- # Add well-known type protos include path |
- list(APPEND _protobuf_include_path |
- -I "${_PROTOBUF_IMPORT_PREFIX}/@CMAKE_INSTALL_INCLUDEDIR@") |
- |
- if(DEFINED PROTOBUF_IMPORT_DIRS) |
- foreach(DIR ${PROTOBUF_IMPORT_DIRS}) |
+ if(DEFINED Protobuf_IMPORT_DIRS) |
+ foreach(DIR ${Protobuf_IMPORT_DIRS}) |
get_filename_component(ABS_PATH ${DIR} ABSOLUTE) |
list(FIND _protobuf_include_path ${ABS_PATH} _contains_already) |
if(${_contains_already} EQUAL -1) |
@@ -49,11 +42,11 @@ function(PROTOBUF_GENERATE_CPP SRCS HDRS) |
add_custom_command( |
OUTPUT "${CMAKE_CURRENT_BINARY_DIR}/${FIL_WE}.pb.cc" |
"${CMAKE_CURRENT_BINARY_DIR}/${FIL_WE}.pb.h" |
- COMMAND ${PROTOBUF_PROTOC_EXECUTABLE} |
+ COMMAND ${Protobuf_PROTOC_EXECUTABLE} |
ARGS --cpp_out ${CMAKE_CURRENT_BINARY_DIR} ${_protobuf_include_path} ${ABS_FIL} |
- DEPENDS ${ABS_FIL} ${PROTOBUF_PROTOC_EXECUTABLE} |
+ DEPENDS ${ABS_FIL} ${Protobuf_PROTOC_EXECUTABLE} |
COMMENT "Running C++ protocol buffer compiler on ${FIL}" |
- VERBATIM) |
+ VERBATIM ) |
endforeach() |
set_source_files_properties(${${SRCS}} ${${HDRS}} PROPERTIES GENERATED TRUE) |
@@ -61,29 +54,104 @@ function(PROTOBUF_GENERATE_CPP SRCS HDRS) |
set(${HDRS} ${${HDRS}} PARENT_SCOPE) |
endfunction() |
+function(PROTOBUF_GENERATE_PYTHON SRCS) |
+ if(NOT ARGN) |
+ message(SEND_ERROR "Error: PROTOBUF_GENERATE_PYTHON() called without any proto files") |
+ return() |
+ endif() |
+ |
+ if(PROTOBUF_GENERATE_CPP_APPEND_PATH) |
+ # Create an include path for each file specified |
+ foreach(FIL ${ARGN}) |
+ get_filename_component(ABS_FIL ${FIL} ABSOLUTE) |
+ get_filename_component(ABS_PATH ${ABS_FIL} PATH) |
+ list(FIND _protobuf_include_path ${ABS_PATH} _contains_already) |
+ if(${_contains_already} EQUAL -1) |
+ list(APPEND _protobuf_include_path -I ${ABS_PATH}) |
+ endif() |
+ endforeach() |
+ else() |
+ set(_protobuf_include_path -I ${CMAKE_CURRENT_SOURCE_DIR}) |
+ endif() |
+ |
+ if(DEFINED Protobuf_IMPORT_DIRS) |
+ foreach(DIR ${Protobuf_IMPORT_DIRS}) |
+ get_filename_component(ABS_PATH ${DIR} ABSOLUTE) |
+ list(FIND _protobuf_include_path ${ABS_PATH} _contains_already) |
+ if(${_contains_already} EQUAL -1) |
+ list(APPEND _protobuf_include_path -I ${ABS_PATH}) |
+ endif() |
+ endforeach() |
+ endif() |
+ |
+ set(${SRCS}) |
+ foreach(FIL ${ARGN}) |
+ get_filename_component(ABS_FIL ${FIL} ABSOLUTE) |
+ get_filename_component(FIL_WE ${FIL} NAME_WE) |
+ |
+ list(APPEND ${SRCS} "${CMAKE_CURRENT_BINARY_DIR}/${FIL_WE}_pb2.py") |
+ add_custom_command( |
+ OUTPUT "${CMAKE_CURRENT_BINARY_DIR}/${FIL_WE}_pb2.py" |
+ COMMAND ${Protobuf_PROTOC_EXECUTABLE} --python_out ${CMAKE_CURRENT_BINARY_DIR} ${_protobuf_include_path} ${ABS_FIL} |
+ DEPENDS ${ABS_FIL} ${Protobuf_PROTOC_EXECUTABLE} |
+ COMMENT "Running Python protocol buffer compiler on ${FIL}" |
+ VERBATIM ) |
+ endforeach() |
+ |
+ set(${SRCS} ${${SRCS}} PARENT_SCOPE) |
+endfunction() |
+ |
+# Environment |
+ |
+# Backwards compatibility |
+# Define camel case versions of input variables |
+foreach(UPPER |
+ PROTOBUF_SRC_ROOT_FOLDER |
+ PROTOBUF_IMPORT_DIRS |
+ PROTOBUF_DEBUG |
+ PROTOBUF_LIBRARY |
+ PROTOBUF_PROTOC_LIBRARY |
+ PROTOBUF_INCLUDE_DIR |
+ PROTOBUF_PROTOC_EXECUTABLE |
+ PROTOBUF_LIBRARY_DEBUG |
+ PROTOBUF_PROTOC_LIBRARY_DEBUG |
+ PROTOBUF_LITE_LIBRARY |
+ PROTOBUF_LITE_LIBRARY_DEBUG |
+ ) |
+ if (DEFINED ${UPPER}) |
+ string(REPLACE "PROTOBUF_" "Protobuf_" Camel ${UPPER}) |
+ if (NOT DEFINED ${Camel}) |
+ set(${Camel} ${${UPPER}}) |
+ endif() |
+ endif() |
+endforeach() |
+ |
+if(DEFINED Protobuf_SRC_ROOT_FOLDER) |
+ message(AUTHOR_WARNING "Variable Protobuf_SRC_ROOT_FOLDER defined, but not" |
+ " used in CONFIG mode") |
+endif() |
+ |
+include(SelectLibraryConfigurations) |
+ |
# Internal function: search for normal library as well as a debug one |
# if the debug one is specified also include debug/optimized keywords |
# in *_LIBRARIES variable |
function(_protobuf_find_libraries name filename) |
- get_target_property(${name}_LIBRARY lib${filename} |
- IMPORTED_LOCATION_RELEASE) |
- set(${name}_LIBRARY "${${name}_LIBRARY}" PARENT_SCOPE) |
- get_target_property(${name}_LIBRARY_DEBUG lib${filename} |
- IMPORTED_LOCATION_DEBUG) |
- set(${name}_LIBRARY_DEBUG "${${name}_LIBRARY_DEBUG}" PARENT_SCOPE) |
- |
- if(NOT ${name}_LIBRARY_DEBUG) |
- # There is no debug library |
- set(${name}_LIBRARY_DEBUG ${${name}_LIBRARY} PARENT_SCOPE) |
- set(${name}_LIBRARIES ${${name}_LIBRARY} PARENT_SCOPE) |
- else() |
- # There IS a debug library |
- set(${name}_LIBRARIES |
- optimized ${${name}_LIBRARY} |
- debug ${${name}_LIBRARY_DEBUG} |
- PARENT_SCOPE |
- ) |
- endif() |
+ if(${name}_LIBRARIES) |
+ # Use result recorded by a previous call. |
+ elseif(${name}_LIBRARY) |
+ # Honor cache entry used by CMake 3.5 and lower. |
+ set(${name}_LIBRARIES "${${name}_LIBRARY}" PARENT_SCOPE) |
+ else() |
+ get_target_property(${name}_LIBRARY_RELEASE protobuf::lib${filename} |
+ LOCATION_RELEASE) |
+ get_target_property(${name}_LIBRARY_DEBUG protobuf::lib${filename} |
+ LOCATION_DEBUG) |
+ |
+ select_library_configurations(${name}) |
+ set(${name}_LIBRARY ${${name}_LIBRARY} PARENT_SCOPE) |
+ set(${name}_LIBRARIES ${${name}_LIBRARIES} PARENT_SCOPE) |
+ endif() |
endfunction() |
# Internal function: find threads library |
@@ -107,33 +175,59 @@ if(NOT DEFINED PROTOBUF_GENERATE_CPP_APPEND_PATH) |
endif() |
# The Protobuf library |
-_protobuf_find_libraries(PROTOBUF protobuf) |
+_protobuf_find_libraries(Protobuf protobuf) |
# The Protobuf Lite library |
-_protobuf_find_libraries(PROTOBUF_LITE protobuf-lite) |
+_protobuf_find_libraries(Protobuf_LITE protobuf-lite) |
# The Protobuf Protoc Library |
-_protobuf_find_libraries(PROTOBUF_PROTOC protoc) |
+_protobuf_find_libraries(Protobuf_PROTOC protoc) |
if(UNIX) |
_protobuf_find_threads() |
endif() |
# Set the include directory |
-set(PROTOBUF_INCLUDE_DIR "${_PROTOBUF_IMPORT_PREFIX}/@CMAKE_INSTALL_INCLUDEDIR@") |
+get_target_property(Protobuf_INCLUDE_DIRS protobuf::libprotobuf |
+ INTERFACE_INCLUDE_DIRECTORIES) |
# Set the protoc Executable |
-get_target_property(PROTOBUF_PROTOC_EXECUTABLE protoc |
+get_target_property(Protobuf_PROTOC_EXECUTABLE protobuf::protoc |
IMPORTED_LOCATION_RELEASE) |
-if(NOT PROTOBUF_PROTOC_EXECUTABLE) |
- get_target_property(PROTOBUF_PROTOC_EXECUTABLE protoc |
+if(NOT EXISTS "${Protobuf_PROTOC_EXECUTABLE}") |
+ get_target_property(Protobuf_PROTOC_EXECUTABLE protobuf::protoc |
IMPORTED_LOCATION_DEBUG) |
endif() |
-include(FindPackageHandleStandardArgs) |
-FIND_PACKAGE_HANDLE_STANDARD_ARGS(PROTOBUF DEFAULT_MSG |
- PROTOBUF_LIBRARY PROTOBUF_INCLUDE_DIR) |
+# Version info variable |
+set(Protobuf_VERSION "@protobuf_VERSION@") |
-if(PROTOBUF_FOUND) |
- set(PROTOBUF_INCLUDE_DIRS ${PROTOBUF_INCLUDE_DIR}) |
-endif() |
+include(FindPackageHandleStandardArgs) |
+FIND_PACKAGE_HANDLE_STANDARD_ARGS(Protobuf |
+ REQUIRED_VARS Protobuf_PROTOC_EXECUTABLE Protobuf_LIBRARIES Protobuf_INCLUDE_DIRS |
+ VERSION_VAR Protobuf_VERSION |
+) |
+ |
+# Backwards compatibility |
+# Define upper case versions of output variables |
+foreach(Camel |
+ Protobuf_VERSION |
+ Protobuf_SRC_ROOT_FOLDER |
+ Protobuf_IMPORT_DIRS |
+ Protobuf_DEBUG |
+ Protobuf_INCLUDE_DIRS |
+ Protobuf_LIBRARIES |
+ Protobuf_PROTOC_LIBRARIES |
+ Protobuf_LITE_LIBRARIES |
+ Protobuf_LIBRARY |
+ Protobuf_PROTOC_LIBRARY |
+ Protobuf_INCLUDE_DIR |
+ Protobuf_PROTOC_EXECUTABLE |
+ Protobuf_LIBRARY_DEBUG |
+ Protobuf_PROTOC_LIBRARY_DEBUG |
+ Protobuf_LITE_LIBRARY |
+ Protobuf_LITE_LIBRARY_DEBUG |
+ ) |
+ string(TOUPPER ${Camel} UPPER) |
+ set(${UPPER} ${${Camel}}) |
+endforeach() |