aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohnny Willemsen <jwillemsen@remedy.nl>2019-03-08 18:18:37 +0000
committerPhil Christensen <philc@microsoft.com>2019-03-08 10:18:37 -0800
commit1d8e65482f3474372c1215709cc3d366fb9fd001 (patch)
tree11ee4036a14aedb60165a188e677827de427fbf4
parentc297b43896edfcaad7b8b81e6a7994e5c13c1146 (diff)
downloadvcpkg-1d8e65482f3474372c1215709cc3d366fb9fd001.tar.gz
vcpkg-1d8e65482f3474372c1215709cc3d366fb9fd001.zip
[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
-rw-r--r--ports/ace/CONTROL2
-rw-r--r--ports/ace/portfile.cmake81
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)