2016-11-22 05:40:45 +08:00
|
|
|
include(vcpkg_common_functions)
|
2019-06-28 02:08:20 +08:00
|
|
|
|
|
|
|
vcpkg_from_github(
|
|
|
|
OUT_SOURCE_PATH SOURCE_PATH
|
|
|
|
REPO GNOME/libxslt
|
|
|
|
REF v1.1.33
|
|
|
|
SHA512 2c20b2af3c19952b25b10dca0d95fe227602f7f815db352b04dd061c52c458d745f92c597ce08ac9207ba0fbe0169ea2fb78263d8590743717553f84463fe1d9
|
|
|
|
HEAD_REF master
|
2019-09-06 01:43:09 +08:00
|
|
|
PATCHES
|
|
|
|
0001-Fix-makefile.patch
|
|
|
|
0002-Fix-lzma.patch
|
2016-11-22 05:40:45 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
find_program(NMAKE nmake)
|
|
|
|
|
|
|
|
set(SCRIPTS_DIR ${SOURCE_PATH}/win32)
|
|
|
|
|
|
|
|
set(CONFIGURE_COMMAND_TEMPLATE cscript configure.js
|
|
|
|
cruntime=@CRUNTIME@
|
|
|
|
debug=@DEBUGMODE@
|
|
|
|
prefix=@INSTALL_DIR@
|
|
|
|
include=@INCLUDE_DIR@
|
|
|
|
lib=@LIB_DIR@
|
|
|
|
bindir=$(PREFIX)\\tools\\
|
|
|
|
sodir=$(PREFIX)\\bin\\
|
|
|
|
)
|
|
|
|
|
|
|
|
# Create some directories ourselves, because the makefile doesn't
|
|
|
|
file(MAKE_DIRECTORY ${CURRENT_PACKAGES_DIR}/bin)
|
|
|
|
file(MAKE_DIRECTORY ${CURRENT_PACKAGES_DIR}/debug/bin)
|
|
|
|
|
|
|
|
#
|
|
|
|
# Release
|
|
|
|
#
|
|
|
|
|
|
|
|
message(STATUS "Configuring ${TARGET_TRIPLET}-rel")
|
|
|
|
|
|
|
|
if(VCPKG_CRT_LINKAGE STREQUAL dynamic)
|
|
|
|
set(CRUNTIME /MD)
|
|
|
|
else()
|
|
|
|
set(CRUNTIME /MT)
|
|
|
|
endif()
|
|
|
|
set(DEBUGMODE no)
|
|
|
|
set(LIB_DIR ${CURRENT_INSTALLED_DIR}/lib)
|
|
|
|
set(INCLUDE_DIR ${CURRENT_INSTALLED_DIR}/include)
|
|
|
|
set(INSTALL_DIR ${CURRENT_PACKAGES_DIR})
|
|
|
|
file(TO_NATIVE_PATH "${LIB_DIR}" LIB_DIR)
|
|
|
|
file(TO_NATIVE_PATH "${INCLUDE_DIR}" INCLUDE_DIR)
|
|
|
|
file(TO_NATIVE_PATH "${INSTALL_DIR}" INSTALL_DIR)
|
|
|
|
string(CONFIGURE "${CONFIGURE_COMMAND_TEMPLATE}" CONFIGURE_COMMAND)
|
|
|
|
vcpkg_execute_required_process(
|
|
|
|
COMMAND ${CONFIGURE_COMMAND}
|
|
|
|
WORKING_DIRECTORY ${SCRIPTS_DIR}
|
|
|
|
LOGNAME config-${TARGET_TRIPLET}-rel
|
|
|
|
)
|
2016-11-22 16:44:37 +08:00
|
|
|
# Handle build output directory
|
|
|
|
file(TO_NATIVE_PATH "${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-rel" OUTDIR)
|
|
|
|
file(MAKE_DIRECTORY "${OUTDIR}")
|
2016-11-22 05:40:45 +08:00
|
|
|
message(STATUS "Configuring ${TARGET_TRIPLET}-rel done")
|
|
|
|
|
|
|
|
message(STATUS "Building ${TARGET_TRIPLET}-rel")
|
|
|
|
vcpkg_execute_required_process(
|
2016-11-22 16:44:37 +08:00
|
|
|
COMMAND ${NMAKE} /f Makefile.msvc rebuild OUTDIR=${OUTDIR}
|
2016-11-22 05:40:45 +08:00
|
|
|
WORKING_DIRECTORY ${SCRIPTS_DIR}
|
|
|
|
LOGNAME build-${TARGET_TRIPLET}-rel
|
|
|
|
)
|
|
|
|
message(STATUS "Building ${TARGET_TRIPLET}-rel done")
|
|
|
|
|
|
|
|
message(STATUS "Installing ${TARGET_TRIPLET}-rel")
|
|
|
|
vcpkg_execute_required_process(
|
2016-11-22 16:44:37 +08:00
|
|
|
COMMAND ${NMAKE} /f Makefile.msvc install OUTDIR=${OUTDIR}
|
2016-11-22 05:40:45 +08:00
|
|
|
WORKING_DIRECTORY ${SCRIPTS_DIR}
|
|
|
|
LOGNAME install-${TARGET_TRIPLET}-rel
|
|
|
|
)
|
|
|
|
message(STATUS "Installing ${TARGET_TRIPLET}-rel done")
|
|
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
# Debug
|
|
|
|
#
|
|
|
|
|
|
|
|
message(STATUS "Configuring ${TARGET_TRIPLET}-dbg")
|
|
|
|
|
|
|
|
if(VCPKG_CRT_LINKAGE STREQUAL dynamic)
|
|
|
|
set(CRUNTIME /MDd)
|
|
|
|
else()
|
|
|
|
set(CRUNTIME /MTd)
|
|
|
|
endif()
|
|
|
|
set(DEBUGMODE yes)
|
|
|
|
set(LIB_DIR ${CURRENT_INSTALLED_DIR}/debug/lib)
|
|
|
|
set(INSTALL_DIR ${CURRENT_PACKAGES_DIR}/debug)
|
|
|
|
file(TO_NATIVE_PATH "${LIB_DIR}" LIB_DIR)
|
|
|
|
file(TO_NATIVE_PATH "${INSTALL_DIR}" INSTALL_DIR)
|
|
|
|
string(CONFIGURE "${CONFIGURE_COMMAND_TEMPLATE}" CONFIGURE_COMMAND)
|
|
|
|
|
|
|
|
vcpkg_execute_required_process(
|
|
|
|
COMMAND ${CONFIGURE_COMMAND}
|
|
|
|
WORKING_DIRECTORY ${SCRIPTS_DIR}
|
|
|
|
LOGNAME config-${TARGET_TRIPLET}-dbg
|
|
|
|
)
|
2016-11-22 16:44:37 +08:00
|
|
|
# Handle build output directory
|
|
|
|
file(TO_NATIVE_PATH "${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-dbg" OUTDIR)
|
|
|
|
file(MAKE_DIRECTORY "${OUTDIR}")
|
2016-11-22 05:40:45 +08:00
|
|
|
message(STATUS "Configuring ${TARGET_TRIPLET}-dbg done")
|
|
|
|
|
|
|
|
message(STATUS "Building ${TARGET_TRIPLET}-dbg")
|
|
|
|
vcpkg_execute_required_process(
|
2016-11-22 16:44:37 +08:00
|
|
|
COMMAND ${NMAKE} /f Makefile.msvc rebuild OUTDIR=${OUTDIR}
|
2016-11-22 05:40:45 +08:00
|
|
|
WORKING_DIRECTORY ${SCRIPTS_DIR}
|
|
|
|
LOGNAME build-${TARGET_TRIPLET}-dbg
|
|
|
|
)
|
|
|
|
message(STATUS "Building ${TARGET_TRIPLET}-dbg done")
|
|
|
|
|
|
|
|
message(STATUS "Installing ${TARGET_TRIPLET}-dbg")
|
|
|
|
vcpkg_execute_required_process(
|
2016-11-22 16:44:37 +08:00
|
|
|
COMMAND ${NMAKE} /f Makefile.msvc install OUTDIR=${OUTDIR}
|
2016-11-22 05:40:45 +08:00
|
|
|
WORKING_DIRECTORY ${SCRIPTS_DIR}
|
|
|
|
LOGNAME install-${TARGET_TRIPLET}-dbg
|
|
|
|
)
|
|
|
|
message(STATUS "Installing ${TARGET_TRIPLET}-dbg done")
|
|
|
|
|
|
|
|
#
|
|
|
|
# Cleanup
|
|
|
|
#
|
|
|
|
|
|
|
|
# You have to define LIB(E)XSLT_STATIC or not, depending on how you link
|
|
|
|
file(READ ${CURRENT_PACKAGES_DIR}/include/libxslt/xsltexports.h XSLTEXPORTS_H)
|
|
|
|
if(VCPKG_LIBRARY_LINKAGE STREQUAL "static")
|
|
|
|
string(REPLACE "!defined(LIBXSLT_STATIC)" "0" XSLTEXPORTS_H "${XSLTEXPORTS_H}")
|
|
|
|
else()
|
|
|
|
string(REPLACE "!defined(LIBXSLT_STATIC)" "1" XSLTEXPORTS_H "${XSLTEXPORTS_H}")
|
|
|
|
endif()
|
|
|
|
file(WRITE ${CURRENT_PACKAGES_DIR}/include/libxslt/xsltexports.h "${XSLTEXPORTS_H}")
|
|
|
|
|
|
|
|
file(READ ${CURRENT_PACKAGES_DIR}/include/libexslt/exsltexports.h EXSLTEXPORTS_H)
|
|
|
|
if(VCPKG_LIBRARY_LINKAGE STREQUAL "static")
|
|
|
|
string(REPLACE "!defined(LIBEXSLT_STATIC)" "0" EXSLTEXPORTS_H "${EXSLTEXPORTS_H}")
|
|
|
|
else()
|
|
|
|
string(REPLACE "!defined(LIBEXSLT_STATIC)" "1" EXSLTEXPORTS_H "${EXSLTEXPORTS_H}")
|
|
|
|
endif()
|
|
|
|
file(WRITE ${CURRENT_PACKAGES_DIR}/include/libexslt/exsltexports.h "${EXSLTEXPORTS_H}")
|
|
|
|
|
|
|
|
# Remove tools and debug include directories
|
|
|
|
file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/tools)
|
|
|
|
file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/debug/tools)
|
|
|
|
file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/debug/include)
|
|
|
|
|
|
|
|
# The makefile builds both static and dynamic libraries, so remove the ones we don't want
|
|
|
|
if(VCPKG_LIBRARY_LINKAGE STREQUAL dynamic)
|
|
|
|
file(REMOVE ${CURRENT_PACKAGES_DIR}/lib/libxslt_a.lib ${CURRENT_PACKAGES_DIR}/lib/libexslt_a.lib)
|
|
|
|
file(REMOVE ${CURRENT_PACKAGES_DIR}/debug/lib/libxslt_a.lib ${CURRENT_PACKAGES_DIR}/debug/lib/libexslt_a.lib)
|
|
|
|
else()
|
|
|
|
file(REMOVE ${CURRENT_PACKAGES_DIR}/lib/libxslt.lib ${CURRENT_PACKAGES_DIR}/lib/libexslt.lib)
|
|
|
|
file(REMOVE ${CURRENT_PACKAGES_DIR}/debug/lib/libxslt.lib ${CURRENT_PACKAGES_DIR}/debug/lib/libexslt.lib)
|
|
|
|
file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/bin ${CURRENT_PACKAGES_DIR}/debug/bin)
|
|
|
|
# Rename the libs to match the dynamic lib names
|
|
|
|
file(RENAME ${CURRENT_PACKAGES_DIR}/lib/libxslt_a.lib ${CURRENT_PACKAGES_DIR}/lib/libxslt.lib)
|
|
|
|
file(RENAME ${CURRENT_PACKAGES_DIR}/lib/libexslt_a.lib ${CURRENT_PACKAGES_DIR}/lib/libexslt.lib)
|
|
|
|
file(RENAME ${CURRENT_PACKAGES_DIR}/debug/lib/libxslt_a.lib ${CURRENT_PACKAGES_DIR}/debug/lib/libxslt.lib)
|
|
|
|
file(RENAME ${CURRENT_PACKAGES_DIR}/debug/lib/libexslt_a.lib ${CURRENT_PACKAGES_DIR}/debug/lib/libexslt.lib)
|
|
|
|
endif()
|
|
|
|
|
2019-09-06 01:43:09 +08:00
|
|
|
vcpkg_copy_pdbs()
|
|
|
|
|
|
|
|
file(INSTALL ${SOURCE_PATH}/Copyright DESTINATION ${CURRENT_PACKAGES_DIR}/share/${PORT} RENAME copyright)
|
2016-11-22 05:40:45 +08:00
|
|
|
|