aboutsummaryrefslogtreecommitdiff
path: root/vcpkg/ports/libideviceactivation/CMakeLists.txt
diff options
context:
space:
mode:
Diffstat (limited to 'vcpkg/ports/libideviceactivation/CMakeLists.txt')
-rw-r--r--vcpkg/ports/libideviceactivation/CMakeLists.txt103
1 files changed, 103 insertions, 0 deletions
diff --git a/vcpkg/ports/libideviceactivation/CMakeLists.txt b/vcpkg/ports/libideviceactivation/CMakeLists.txt
new file mode 100644
index 0000000..833545e
--- /dev/null
+++ b/vcpkg/ports/libideviceactivation/CMakeLists.txt
@@ -0,0 +1,103 @@
+cmake_minimum_required(VERSION 3.15)
+project(libideviceactivation C)
+
+option(BUILD_TOOLS "Build tools." OFF)
+
+include(GNUInstallDirs)
+
+file(GLOB_RECURSE LIBIDEVICEACTIVATION_HEADER include/*.h)
+file(GLOB_RECURSE LIBIDEVICEACTIVATION_SOURCE src/*.c)
+
+set(DEFINITIONS)
+
+if(BUILD_SHARED_LIBS)
+ if(WIN32)
+ list(APPEND LIBIDEVICEACTIVATION_SOURCE exports.def)
+ endif()
+else()
+ list(APPEND DEFINITIONS -DLIBIDEVICEACTIVATION_STATIC)
+endif()
+
+if(WIN32)
+ list(APPEND DEFINITIONS -D_CRT_SECURE_NO_WARNINGS)
+ list(APPEND DEFINITIONS -DWIN32_LEAN_AND_MEAN)
+ list(APPEND DEFINITIONS -DWIN32)
+endif()
+
+find_package(unofficial-libplist CONFIG REQUIRED)
+find_package(unofficial-libimobiledevice CONFIG REQUIRED)
+find_package(CURL CONFIG REQUIRED)
+find_package(LibXml2 CONFIG REQUIRED)
+
+add_library(libideviceactivation ${LIBIDEVICEACTIVATION_SOURCE})
+target_include_directories(libideviceactivation PUBLIC
+ "$<BUILD_INTERFACE:${CMAKE_CURRENT_LIST_DIR}/include>"
+ "$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}>"
+)
+target_compile_definitions(libideviceactivation PRIVATE ${DEFINITIONS})
+target_link_libraries(libideviceactivation
+ PRIVATE
+ CURL::libcurl
+ LibXml2::LibXml2
+ PUBLIC
+ unofficial::libplist::libplist
+ unofficial::libimobiledevice::libimobiledevice
+)
+set_target_properties(libideviceactivation PROPERTIES OUTPUT_NAME ideviceactivation-1.0)
+
+install(TARGETS libideviceactivation EXPORT unofficial-libideviceactivation)
+
+install(
+ EXPORT unofficial-libideviceactivation
+ FILE unofficial-libideviceactivation-config.cmake
+ DESTINATION "${CMAKE_INSTALL_DATAROOTDIR}/unofficial-libideviceactivation"
+ NAMESPACE unofficial::libideviceactivation::
+)
+
+install(
+ FILES ${LIBIDEVICEACTIVATION_HEADER}
+ DESTINATION "${CMAKE_INSTALL_INCLUDEDIR}"
+)
+
+set(LIBPLIST_VERSION 2.0)
+set(LIBIMOBILEDEVICE_VERSION 1.0)
+set(LIBCURL_VERSION 7.0)
+set(LIBXML2_VERSION 2.0)
+set(PACKAGE_NAME libideviceactivation)
+set(PACKAGE_VERSION 1.0)
+set(prefix "")
+set(exec_prefix "\${prefix}")
+set(libdir "\${prefix}/lib")
+set(includedir "\${prefix}/include")
+
+configure_file(
+ "${CMAKE_CURRENT_SOURCE_DIR}/src/libideviceactivation-1.0.pc.in"
+ "${CMAKE_CURRENT_BINARY_DIR}/libideviceactivation-1.0.pc"
+ @ONLY
+)
+install(
+ FILES "${CMAKE_CURRENT_BINARY_DIR}/libideviceactivation-1.0.pc"
+ DESTINATION "${CMAKE_INSTALL_LIBDIR}/pkgconfig"
+)
+
+if(BUILD_TOOLS)
+ add_executable(ideviceactivation "tools/ideviceactivation.c")
+ target_compile_definitions(ideviceactivation PRIVATE
+ -DPACKAGE_VERSION="1.1.1"
+ -DPACKAGE_URL="https://github.com/libimobiledevice/libideviceactivation"
+ -DPACKAGE_BUGREPORT="https://github.com/libimobiledevice/libideviceactivation/issues"
+ )
+ if(WIN32)
+ target_compile_definitions(ideviceactivation PRIVATE
+ -D_CRT_SECURE_NO_WARNINGS
+ -DWIN32_LEAN_AND_MEAN
+ -DWIN32
+ )
+ endif()
+ target_link_libraries(ideviceactivation PRIVATE libideviceactivation)
+
+ install(
+ TARGETS ideviceactivation
+ RUNTIME DESTINATION "${CMAKE_INSTALL_BINDIR}"
+ )
+endif()