From 933bd02a9984d5a9716a0e92b84b75c7a0697ab1 Mon Sep 17 00:00:00 2001 From: Kai Pastor Date: Sat, 16 Mar 2024 07:34:24 +0100 Subject: [PATCH] [cld3] Cleanup, use protobuf config --- ports/cld3/fix-build.patch | 83 ++++++++++++++++++++++++++++++ ports/cld3/portfile.cmake | 2 +- ports/cld3/unofficial-export.patch | 35 +++---------- ports/cld3/vcpkg.json | 2 +- versions/baseline.json | 2 +- versions/c-/cld3.json | 5 ++ 6 files changed, 98 insertions(+), 31 deletions(-) create mode 100644 ports/cld3/fix-build.patch diff --git a/ports/cld3/fix-build.patch b/ports/cld3/fix-build.patch new file mode 100644 index 00000000000000..5711d518bb4ac4 --- /dev/null +++ b/ports/cld3/fix-build.patch @@ -0,0 +1,83 @@ +diff --git a/CMakeLists.txt b/CMakeLists.txt +index 2fa3908..37e9944 100644 +--- a/CMakeLists.txt ++++ b/CMakeLists.txt +@@ -1,11 +1,11 @@ + # This cmake scripts only builds a static cld3 lib and the unittests. + +-project(cld3) + + # Old versions of cmake dont search/find protobuf lite + cmake_minimum_required(VERSION 3.9) ++project(cld3) + +-find_package(Protobuf REQUIRED) ++find_package(Protobuf CONFIG REQUIRED) + message(STATUS "Protobuf_FOUND= ${Protobuf_FOUND}") + message(STATUS "Protobuf_VERSION= ${Protobuf_VERSION}") + message(WARNING "Protobuf 2.5 and CLD3 seems happy together. This script does NOT check if your verison of protobuf is compatible.") +@@ -20,9 +20,6 @@ include(${CMAKE_CURRENT_SOURCE_DIR}/misc/myprotobuf.cmake) + my_protobuf_generate_cpp(cld_3/protos PROTO_SRCS PROTO_HDRS src/feature_extractor.proto src/sentence.proto src/task_spec.proto) + message(STATUS "PROTO_HDRS= ${PROTO_HDRS}") + +-add_definitions(-fPIC) # Position Independant Code +-add_definitions(-D_GLIBCXX_USE_CXX11_ABI=0) +-add_definitions(-std=c++11) # Needed for std::to_string(), ... + + include_directories(${CMAKE_CURRENT_BINARY_DIR} ${Protobuf_INCLUDE_DIRS}) # needed to include generated pb headers + +@@ -58,6 +55,10 @@ add_library(${PROJECT_NAME} + src/script_span/fixunicodevalue.cc + ) + ++target_compile_features(${PROJECT_NAME} PUBLIC cxx_std_11) ++target_link_libraries(${PROJECT_NAME} PUBLIC protobuf::libprotobuf-lite) ++ ++if(BUILD_TESTS) + # unit tests exec: + add_executable(language_identifier_main src/language_identifier_main.cc) + target_link_libraries(language_identifier_main cld3 ${Protobuf_LITE_LIBRARIES}) +@@ -67,3 +68,4 @@ target_link_libraries(getonescriptspan_test cld3 ${Protobuf_LITE_LIBRARIES}) + + add_executable(language_identifier_features_test src/language_identifier_features_test.cc) + target_link_libraries(language_identifier_features_test cld3 ${Protobuf_LITE_LIBRARIES}) ++endif() +diff --git a/src/base.h b/src/base.h +index 20189e2..3c610e3 100644 +--- a/src/base.h ++++ b/src/base.h +@@ -71,7 +71,7 @@ typedef unsigned short uint16; // NOLINT + typedef signed int char32; + #endif // SWIG + +-#ifdef COMPILER_MSVC ++#ifdef _MSC_VER + typedef __int64 int64; + #else + typedef long long int64; // NOLINT +diff --git a/src/script_span/utf8statetable.cc b/src/script_span/utf8statetable.cc +index 8fcfb1e..87da972 100644 +--- a/src/script_span/utf8statetable.cc ++++ b/src/script_span/utf8statetable.cc +@@ -17,7 +17,7 @@ + // 32- or 16-bit Unicode values. + // + +-#ifdef COMPILER_MSVC ++#ifdef _MSC_VER + // MSVC warns: warning C4309: 'initializing' : truncation of constant value + // But the value is in fact not truncated. 0xFF still comes out 0xFF at + // runtime. +diff --git a/src/sentence_features.h b/src/sentence_features.h +index cc0be88..e2e27d2 100644 +--- a/src/sentence_features.h ++++ b/src/sentence_features.h +@@ -34,7 +34,7 @@ using WholeSentenceExtractor = FeatureExtractor; + // for clang's -Wundefined-var-template. However, MSVC has a bug which treats + // this declaration as a definition, leading to multiple definition errors, so + // omit this on MSVC. +-#if !defined(COMPILER_MSVC) ++#if !defined(_MSC_VER) + template <> + WholeSentenceFeature::Registry + *RegisterableClass::registry_; diff --git a/ports/cld3/portfile.cmake b/ports/cld3/portfile.cmake index a6057fc221521b..4f204c6ce0f5ab 100644 --- a/ports/cld3/portfile.cmake +++ b/ports/cld3/portfile.cmake @@ -9,12 +9,12 @@ vcpkg_from_github( SHA512 c3650ffbf5855aaf04d03930f01c6efd76e1f2b2d47365348721f16531a14653ae5b3aff8fefa8e5fa1c769fdf1a9b441a88bc687f97f8c579b84f17c6984c9e HEAD_REF master PATCHES + fix-build.patch unofficial-export.patch ) vcpkg_cmake_configure( SOURCE_PATH "${SOURCE_PATH}" - OPTIONS ${FEATURE_OPTIONS} ) vcpkg_cmake_install() diff --git a/ports/cld3/unofficial-export.patch b/ports/cld3/unofficial-export.patch index 1f4474627eb1fd..99b900d089e09a 100644 --- a/ports/cld3/unofficial-export.patch +++ b/ports/cld3/unofficial-export.patch @@ -1,35 +1,11 @@ diff --git a/CMakeLists.txt b/CMakeLists.txt -index 2fa3908..d776dd1 100644 +index 37e9944..fb27632 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt -@@ -21,7 +21,6 @@ my_protobuf_generate_cpp(cld_3/protos PROTO_SRCS PROTO_HDRS src/feature_extracto - message(STATUS "PROTO_HDRS= ${PROTO_HDRS}") +@@ -57,6 +57,19 @@ add_library(${PROJECT_NAME} - add_definitions(-fPIC) # Position Independant Code --add_definitions(-D_GLIBCXX_USE_CXX11_ABI=0) - add_definitions(-std=c++11) # Needed for std::to_string(), ... - - include_directories(${CMAKE_CURRENT_BINARY_DIR} ${Protobuf_INCLUDE_DIRS}) # needed to include generated pb headers -@@ -58,6 +57,7 @@ add_library(${PROJECT_NAME} - src/script_span/fixunicodevalue.cc - ) - -+if (0) # Disable unit tests - # unit tests exec: - add_executable(language_identifier_main src/language_identifier_main.cc) - target_link_libraries(language_identifier_main cld3 ${Protobuf_LITE_LIBRARIES}) -@@ -67,3 +67,24 @@ target_link_libraries(getonescriptspan_test cld3 ${Protobuf_LITE_LIBRARIES}) - - add_executable(language_identifier_features_test src/language_identifier_features_test.cc) - target_link_libraries(language_identifier_features_test cld3 ${Protobuf_LITE_LIBRARIES}) -+endif() -+ -+if (MSVC) -+ add_compile_definitions(COMPILER_MSVC) -+endif() -+ -+target_link_libraries(${PROJECT_NAME} PUBLIC protobuf::libprotobuf-lite) -+ + target_compile_features(${PROJECT_NAME} PUBLIC cxx_std_11) + target_link_libraries(${PROJECT_NAME} PUBLIC protobuf::libprotobuf-lite) +target_include_directories(${PROJECT_NAME} PUBLIC $) + +install(TARGETS ${PROJECT_NAME} @@ -43,3 +19,6 @@ index 2fa3908..d776dd1 100644 + NAMESPACE unofficial::cld3:: + DESTINATION share/unofficial-cld3 +) + + if(BUILD_TESTS) + # unit tests exec: diff --git a/ports/cld3/vcpkg.json b/ports/cld3/vcpkg.json index c8b367387bc1bd..7cd1f19da08d30 100644 --- a/ports/cld3/vcpkg.json +++ b/ports/cld3/vcpkg.json @@ -1,7 +1,7 @@ { "name": "cld3", "version": "3.0.14", - "port-version": 1, + "port-version": 2, "description": "Compact Language Detector v3", "homepage": "https://github.com/google/cld3", "license": "Apache-2.0", diff --git a/versions/baseline.json b/versions/baseline.json index 53e46d00659846..609ad37c271e05 100644 --- a/versions/baseline.json +++ b/versions/baseline.json @@ -1642,7 +1642,7 @@ }, "cld3": { "baseline": "3.0.14", - "port-version": 1 + "port-version": 2 }, "clfft": { "baseline": "2.12.2", diff --git a/versions/c-/cld3.json b/versions/c-/cld3.json index 23422054041cac..6a64aeac70f21d 100644 --- a/versions/c-/cld3.json +++ b/versions/c-/cld3.json @@ -1,5 +1,10 @@ { "versions": [ + { + "git-tree": "41fd2fe36358570f0bdbfaf689bf12132af99a6f", + "version": "3.0.14", + "port-version": 2 + }, { "git-tree": "a9553fd0c6e8053c54c83a51d8e93bdfab419c8e", "version": "3.0.14",