From 1d8e65482f3474372c1215709cc3d366fb9fd001 Mon Sep 17 00:00:00 2001 From: Johnny Willemsen Date: Fri, 8 Mar 2019 18:18:37 +0000 Subject: [PATCH] [ace] Use source package and add static support (#5601) * Use our source only distribution and generate the necessary solution as part of the build * ports/ace/portfile.cmake: * Add ACE_ROOT * ports/ace/portfile.cmake: * Support static and generate within the ace directory * ports/ace/portfile.cmake: * Set missing environment * ports/ace/portfile.cmake: * Fixed install for static * ports/ace/portfile.cmake: * Also install pdb in a static job * ports/ace/portfile.cmake: * pdb files are only created in a dynamic build * ports/ace/portfile.cmake: * Add missing library * ports/ace/portfile.cmake: * Add missing header directory * ports/ace/portfile.cmake: * Use ACE_ROOT for the copyright file * ports/ace/portfile.cmake: * [ace] bump dash version in control to force rebuild --- ports/ace/CONTROL | 2 +- ports/ace/portfile.cmake | 81 ++++++++++++++++++++++++++-------------- 2 files changed, 55 insertions(+), 28 deletions(-) diff --git a/ports/ace/CONTROL b/ports/ace/CONTROL index 9f8070e17..d0f1e6292 100644 --- a/ports/ace/CONTROL +++ b/ports/ace/CONTROL @@ -1,3 +1,3 @@ Source: ace -Version: 6.5.4 +Version: 6.5.4-1 Description: The ADAPTIVE Communication Environment diff --git a/ports/ace/portfile.cmake b/ports/ace/portfile.cmake index f3dcbc6bf..105cd31aa 100644 --- a/ports/ace/portfile.cmake +++ b/ports/ace/portfile.cmake @@ -3,18 +3,24 @@ if(VCPKG_CMAKE_SYSTEM_NAME STREQUAL "WindowsStore") endif() if (VCPKG_LIBRARY_LINKAGE STREQUAL static) - message(STATUS "Warning: Static building not supported yet. Building dynamic.") - set(VCPKG_LIBRARY_LINKAGE dynamic) + set(MPC_STATIC_FLAG -static) + set(DLL_DECORATOR s) endif() include(vcpkg_common_functions) +set(ACE_ROOT ${CURRENT_BUILDTREES_DIR}/src/ACE_wrappers) +set(ENV{ACE_ROOT} ${ACE_ROOT}) set(SOURCE_PATH ${CURRENT_BUILDTREES_DIR}/src/ACE_wrappers/ace) vcpkg_download_distfile(ARCHIVE - URLS "https://github.com/DOCGroup/ACE_TAO/releases/download/ACE%2BTAO-6_5_4/ACE-6.5.4.zip" - FILENAME ACE-6.5.4.zip - SHA512 d18248f1fcea0e4993d5ba9c62ff99883d4eaecfb0b6b88062961723c0f30ac423c9f550ada98042cd7913d2586feb2f8d47b5779403017afaa89a622613d1ae + URLS "https://github.com/DOCGroup/ACE_TAO/releases/download/ACE%2BTAO-6_5_4/ACE-src-6.5.4.zip" + FILENAME ACE-src-6.5.4.zip + SHA512 e699b24aa65c44137b7bdbe3c045b6c8d76c43ff4c78a05efe6d0d7fd05acdd1166b74529cc4d7ba9440b6b29cce3aa2dcc97f574c94afc05b0fef18475d6ce3 ) vcpkg_extract_source_archive(${ARCHIVE}) +vcpkg_find_acquire_program(PERL) +get_filename_component(PERL_PATH ${PERL} DIRECTORY) +vcpkg_add_to_path(${PERL_PATH}) + if (TRIPLET_SYSTEM_ARCH MATCHES "arm") message(FATAL_ERROR "ARM is currently not supported.") elseif (TRIPLET_SYSTEM_ARCH MATCHES "x86") @@ -30,10 +36,18 @@ else() endif() # Add ace/config.h file -# see http://www.dre.vanderbilt.edu/~schmidt/DOC_ROOT/ACE/ACE-INSTALL.html#win32 +# see https://htmlpreview.github.io/?https://github.com/DOCGroup/ACE_TAO/blob/master/ACE/ACE-INSTALL.html file(WRITE ${SOURCE_PATH}/config.h "#include \"ace/config-windows.h\"") + +# Invoke mwc.pl to generate the necessary solution and project files +vcpkg_execute_required_process( + COMMAND ${PERL} ${ACE_ROOT}/bin/mwc.pl -type ${SOLUTION_TYPE} ace ${MPC_STATIC_FLAG} + WORKING_DIRECTORY ${ACE_ROOT} + LOGNAME mwc +) + vcpkg_build_msbuild( - PROJECT_PATH ${SOURCE_PATH}/ace_${SOLUTION_TYPE}.sln + PROJECT_PATH ${SOURCE_PATH}/ace.sln PLATFORM ${MSBUILD_PLATFORM} ) @@ -54,6 +68,7 @@ file(INSTALL ${HEADER_FILES} DESTINATION ${CURRENT_PACKAGES_DIR}/include/ace/) install_ace_headers_subdirectory(${SOURCE_PATH} "Compression") install_ace_headers_subdirectory(${SOURCE_PATH} "Compression/rle") install_ace_headers_subdirectory(${SOURCE_PATH} "ETCL") +install_ace_headers_subdirectory(${SOURCE_PATH} "QoS") install_ace_headers_subdirectory(${SOURCE_PATH} "Monitor_Control") install_ace_headers_subdirectory(${SOURCE_PATH} "os_include") install_ace_headers_subdirectory(${SOURCE_PATH} "os_include/arpa") @@ -63,37 +78,49 @@ install_ace_headers_subdirectory(${SOURCE_PATH} "os_include/sys") # Install the libraries function(install_ace_library SOURCE_PATH ACE_LIBRARY) - set(LIB_PATH ${SOURCE_PATH}/../lib/) - file(INSTALL - ${LIB_PATH}/${ACE_LIBRARY}d.dll - ${LIB_PATH}/${ACE_LIBRARY}d_dll.pdb - DESTINATION ${CURRENT_PACKAGES_DIR}/debug/bin - ) + set(LIB_PATH ${SOURCE_PATH}/lib/) + if (VCPKG_LIBRARY_LINKAGE STREQUAL dynamic) + # Install the DLL files + file(INSTALL + ${LIB_PATH}/${ACE_LIBRARY}d.dll + DESTINATION ${CURRENT_PACKAGES_DIR}/debug/bin + ) + file(INSTALL + ${LIB_PATH}/${ACE_LIBRARY}.dll + DESTINATION ${CURRENT_PACKAGES_DIR}/bin + ) - file(INSTALL - ${LIB_PATH}/${ACE_LIBRARY}.dll - ${LIB_PATH}/${ACE_LIBRARY}.pdb - DESTINATION ${CURRENT_PACKAGES_DIR}/bin - ) + # Install the pdb files + file(INSTALL + ${LIB_PATH}/${ACE_LIBRARY}${DLL_DECORATOR}d_dll.pdb + DESTINATION ${CURRENT_PACKAGES_DIR}/debug/bin + ) + file(INSTALL + ${LIB_PATH}/${ACE_LIBRARY}${DLL_DECORATOR}.pdb + DESTINATION ${CURRENT_PACKAGES_DIR}/bin + ) + endif() + # Install the lib files file(INSTALL - ${LIB_PATH}/${ACE_LIBRARY}d.lib + ${LIB_PATH}/${ACE_LIBRARY}${DLL_DECORATOR}d.lib DESTINATION ${CURRENT_PACKAGES_DIR}/debug/lib ) file(INSTALL - ${LIB_PATH}/${ACE_LIBRARY}.lib + ${LIB_PATH}/${ACE_LIBRARY}${DLL_DECORATOR}.lib DESTINATION ${CURRENT_PACKAGES_DIR}/lib ) endfunction() -install_ace_library(${SOURCE_PATH} "ACE") -install_ace_library(${SOURCE_PATH} "ACE_Compression") -install_ace_library(${SOURCE_PATH} "ACE_ETCL") -install_ace_library(${SOURCE_PATH} "ACE_Monitor_Control") -install_ace_library(${SOURCE_PATH} "ACE_QoS") -install_ace_library(${SOURCE_PATH} "ACE_RLECompression") +install_ace_library(${ACE_ROOT} "ACE") +install_ace_library(${ACE_ROOT} "ACE_Compression") +install_ace_library(${ACE_ROOT} "ACE_ETCL") +install_ace_library(${ACE_ROOT} "ACE_ETCL_Parser") +install_ace_library(${ACE_ROOT} "ACE_Monitor_Control") +install_ace_library(${ACE_ROOT} "ACE_QoS") +install_ace_library(${ACE_ROOT} "ACE_RLECompression") # Handle copyright -file(COPY ${SOURCE_PATH}/../COPYING DESTINATION ${CURRENT_PACKAGES_DIR}/share/ace) +file(COPY ${ACE_ROOT}/COPYING DESTINATION ${CURRENT_PACKAGES_DIR}/share/ace) file(RENAME ${CURRENT_PACKAGES_DIR}/share/ace/COPYING ${CURRENT_PACKAGES_DIR}/share/ace/copyright)