From c4005f2c92b4e3c411abc8ef6095784d43a59ec1 Mon Sep 17 00:00:00 2001 From: Mike Kruskal Date: Tue, 21 Mar 2023 13:15:07 -0700 Subject: [PATCH] Only include utf8_range if it hasn't been included already PiperOrigin-RevId: 518361290 --- cmake/libprotobuf-lite.cmake | 1 - cmake/libprotobuf.cmake | 1 - cmake/utf8_range.cmake | 19 +++++++++++-------- 3 files changed, 11 insertions(+), 10 deletions(-) diff --git a/cmake/libprotobuf-lite.cmake b/cmake/libprotobuf-lite.cmake index 9a82d927993a..5f9e2f01d2dd 100644 --- a/cmake/libprotobuf-lite.cmake +++ b/cmake/libprotobuf-lite.cmake @@ -40,5 +40,4 @@ set_target_properties(libprotobuf-lite PROPERTIES ) add_library(protobuf::libprotobuf-lite ALIAS libprotobuf-lite) -target_include_directories(libprotobuf-lite PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/third_party/utf8_range) target_link_libraries(libprotobuf-lite PRIVATE utf8_validity) diff --git a/cmake/libprotobuf.cmake b/cmake/libprotobuf.cmake index 23528427b915..715ffb51c033 100644 --- a/cmake/libprotobuf.cmake +++ b/cmake/libprotobuf.cmake @@ -43,5 +43,4 @@ set_target_properties(libprotobuf PROPERTIES ) add_library(protobuf::libprotobuf ALIAS libprotobuf) -target_include_directories(libprotobuf PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/third_party/utf8_range) target_link_libraries(libprotobuf PRIVATE utf8_validity) diff --git a/cmake/utf8_range.cmake b/cmake/utf8_range.cmake index 701de8d4d6af..f411a8c5b37a 100644 --- a/cmake/utf8_range.cmake +++ b/cmake/utf8_range.cmake @@ -1,12 +1,15 @@ -set(utf8_range_ENABLE_TESTS OFF CACHE BOOL "Disable utf8_range tests") +if (NOT TARGET utf8_range) + set(utf8_range_ENABLE_TESTS OFF CACHE BOOL "Disable utf8_range tests") -if (NOT EXISTS "${protobuf_SOURCE_DIR}/third_party/utf8_range/CMakeLists.txt") - message(FATAL_ERROR - "Cannot find third_party/utf8_range directory that's needed for " - "the protobuf runtime.\n") -endif() + if (NOT EXISTS "${protobuf_SOURCE_DIR}/third_party/utf8_range/CMakeLists.txt") + message(FATAL_ERROR + "Cannot find third_party/utf8_range directory that's needed for " + "the protobuf runtime.\n") + endif() -set(utf8_range_ENABLE_INSTALL ${protobuf_INSTALL} CACHE BOOL "Set install") -add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/third_party/utf8_range third_party/utf8_range) + set(utf8_range_ENABLE_INSTALL ${protobuf_INSTALL} CACHE BOOL "Set install") + add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/third_party/utf8_range third_party/utf8_range) + include_directories(${CMAKE_CURRENT_SOURCE_DIR}/third_party/utf8_range) +endif () set(_protobuf_FIND_UTF8_RANGE "if(NOT TARGET utf8_range)\n find_package(utf8_range CONFIG)\nendif()")