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 614e4c045454361797490293359c6b1a982d56ea..d81dc459b6a54134c629d7464681e826f6dc4d26 100644 |
--- a/third_party/protobuf/cmake/protobuf-module.cmake.in |
+++ b/third_party/protobuf/cmake/protobuf-module.cmake.in |
@@ -1,4 +1,7 @@ |
-# Functions |
+if(PROTOBUF_SRC_ROOT_FOLDER) |
+ message(AUTHOR_WARNING "Variable PROTOBUF_SRC_ROOT_FOLDER defined, but not" |
+ " used in CONFIG mode") |
+endif() |
function(PROTOBUF_GENERATE_CPP SRCS HDRS) |
if(NOT ARGN) |
@@ -20,8 +23,12 @@ function(PROTOBUF_GENERATE_CPP SRCS HDRS) |
set(_protobuf_include_path -I ${CMAKE_CURRENT_SOURCE_DIR}) |
endif() |
- if(DEFINED Protobuf_IMPORT_DIRS) |
- foreach(DIR ${Protobuf_IMPORT_DIRS}) |
+ # 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}) |
get_filename_component(ABS_PATH ${DIR} ABSOLUTE) |
list(FIND _protobuf_include_path ${ABS_PATH} _contains_already) |
if(${_contains_already} EQUAL -1) |
@@ -42,11 +49,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) |
@@ -54,104 +61,29 @@ 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) |
- 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() |
+ 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() |
endfunction() |
# Internal function: find threads library |
@@ -175,59 +107,33 @@ 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 |
-get_target_property(Protobuf_INCLUDE_DIRS protobuf::libprotobuf |
- INTERFACE_INCLUDE_DIRECTORIES) |
+set(PROTOBUF_INCLUDE_DIR "${_PROTOBUF_IMPORT_PREFIX}/@CMAKE_INSTALL_INCLUDEDIR@") |
# Set the protoc Executable |
-get_target_property(Protobuf_PROTOC_EXECUTABLE protobuf::protoc |
+get_target_property(PROTOBUF_PROTOC_EXECUTABLE protoc |
IMPORTED_LOCATION_RELEASE) |
-if(NOT EXISTS "${Protobuf_PROTOC_EXECUTABLE}") |
- get_target_property(Protobuf_PROTOC_EXECUTABLE protobuf::protoc |
+if(NOT PROTOBUF_PROTOC_EXECUTABLE) |
+ get_target_property(PROTOBUF_PROTOC_EXECUTABLE protoc |
IMPORTED_LOCATION_DEBUG) |
endif() |
-# Version info variable |
-set(Protobuf_VERSION "@protobuf_VERSION@") |
- |
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() |
+FIND_PACKAGE_HANDLE_STANDARD_ARGS(PROTOBUF DEFAULT_MSG |
+ PROTOBUF_LIBRARY PROTOBUF_INCLUDE_DIR) |
+ |
+if(PROTOBUF_FOUND) |
+ set(PROTOBUF_INCLUDE_DIRS ${PROTOBUF_INCLUDE_DIR}) |
+endif() |