From 23f29908174da16811f79f1013bad67b1d9ea47a Mon Sep 17 00:00:00 2001 From: Kip Date: Mon, 18 Nov 2024 18:48:44 -0800 Subject: [PATCH] Added pkg-config / pkgconf support... --- CMakeLists.txt | 31 +++++++++++++++++++++++++++++++ libhnswlib.pc.in | 12 ++++++++++++ 2 files changed, 43 insertions(+) create mode 100644 libhnswlib.pc.in diff --git a/CMakeLists.txt b/CMakeLists.txt index be0d40f0..eef573e9 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -25,6 +25,37 @@ install(EXPORT hnswlibTargets NAMESPACE hnswlib:: DESTINATION ${CMAKE_INSTALL_LIBDIR}/cmake/hnswlib) +# pkg-config / pkgconf support +option(HNSWLIB_PKG_CONFIG "Build pkg-config manifest" ON) +if(HNSWLIB_PKG_CONFIG) + + function(JOIN_PATHS joined_path first_path_segment) + set(temp_path "${first_path_segment}") + foreach(current_segment IN LISTS ARGN) + if(NOT ("${current_segment}" STREQUAL "")) + if(IS_ABSOLUTE "${current_segment}") + set(temp_path "${current_segment}") + else() + set(temp_path "${temp_path}/${current_segment}") + endif() + endif() + endforeach() + set(${joined_path} "${temp_path}" PARENT_SCOPE) + endfunction() + + JOIN_PATHS(libdir_for_pc_file "\${exec_prefix}" "${CMAKE_INSTALL_LIBDIR}") + JOIN_PATHS(includedir_for_pc_file "\${prefix}" "${CMAKE_INSTALL_INCLUDEDIR}") + + configure_file( + "libhnswlib.pc.in" + "libhnswlib.pc" + @ONLY) + + install(FILES "${CMAKE_CURRENT_BINARY_DIR}/libhnswlib.pc" + DESTINATION "${CMAKE_INSTALL_LIBDIR}/pkgconfig") + +endif() + # Examples and tests if(CMAKE_PROJECT_NAME STREQUAL PROJECT_NAME) option(HNSWLIB_EXAMPLES "Build examples and tests." ON) diff --git a/libhnswlib.pc.in b/libhnswlib.pc.in new file mode 100644 index 00000000..d878dfaa --- /dev/null +++ b/libhnswlib.pc.in @@ -0,0 +1,12 @@ +prefix=@CMAKE_INSTALL_PREFIX@ +exec_prefix=@CMAKE_INSTALL_PREFIX@ +libdir=@libdir_for_pc_file@ +includedir=@includedir_for_pc_file@ + +Name: lib@CMAKE_PROJECT_NAME@ +Description: Header-only C++/python library for fast approximate nearest neighbors. +Version: +URL: https://github.com/nmslib/hnswlib +Libs: -L${libdir} +Cflags: -I${includedir} +