aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLong Huan <8551701+longhuan2018@users.noreply.github.com>2019-09-12 04:03:07 +0800
committerPhil Christensen <philc@microsoft.com>2019-09-11 13:03:07 -0700
commit942371f44f1772bcb5f9279728b07dc72a4d0ae0 (patch)
treec58a32b0e739a9f9c1ae265b3915aa43918830f2
parentcdbaa03cdda27071675daa21f65a8ab0550fd280 (diff)
downloadvcpkg-942371f44f1772bcb5f9279728b07dc72a4d0ae0.tar.gz
vcpkg-942371f44f1772bcb5f9279728b07dc72a4d0ae0.zip
[libspatialite]make libspatialite support linux and osx (#8025)
-rw-r--r--ports/libspatialite/CONTROL2
-rw-r--r--ports/libspatialite/fix-configure-debug.patch58
-rw-r--r--ports/libspatialite/geos-config-debug.in75
-rw-r--r--ports/libspatialite/geos-config.in75
-rw-r--r--ports/libspatialite/portfile.cmake311
5 files changed, 425 insertions, 96 deletions
diff --git a/ports/libspatialite/CONTROL b/ports/libspatialite/CONTROL
index 55d3f4577..51d6a4f5e 100644
--- a/ports/libspatialite/CONTROL
+++ b/ports/libspatialite/CONTROL
@@ -1,5 +1,5 @@
Source: libspatialite
-Version: 4.3.0a-3
+Version: 4.3.0a-4
Homepage: https://www.gaia-gis.it/gaia-sins/libspatialite-sources
Description: SpatiaLite is an open source library intended to extend the SQLite core to support fully fledged Spatial SQL capabilities.
Build-Depends: libxml2, sqlite3, geos, proj4, zlib, freexl, libiconv
diff --git a/ports/libspatialite/fix-configure-debug.patch b/ports/libspatialite/fix-configure-debug.patch
new file mode 100644
index 000000000..77a4c77a0
--- /dev/null
+++ b/ports/libspatialite/fix-configure-debug.patch
@@ -0,0 +1,58 @@
+diff --git a/configure b/configure
+index aafdad55b..11dde35fa 100644
+--- a/configure
++++ b/configure
+@@ -18089,7 +18089,7 @@ return GEOSCoveredBy ();
+ return 0;
+ }
+ _ACEOF
+-for ac_lib in '' geos_c; do
++for ac_lib in '' geos_cd; do
+ if test -z "$ac_lib"; then
+ ac_res="none required"
+ else
+@@ -18124,7 +18124,7 @@ else
+ fi
+
+ LIBS="$LIBS_SAVE"
+- LIBS="$LIBS $GEOS_LDFLAGS -lgeos_c"
++ LIBS="$LIBS $GEOS_LDFLAGS -lgeos_cd"
+
+ #-----------------------------------------------------------------------
+ # --enable-controlpoints
+@@ -18176,7 +18176,7 @@ return GEOSDelaunayTriangulation ();
+ return 0;
+ }
+ _ACEOF
+-for ac_lib in '' geos_c; do
++for ac_lib in '' geos_cd; do
+ if test -z "$ac_lib"; then
+ ac_res="none required"
+ else
+@@ -18240,7 +18240,7 @@ fi
+ done
+
+ _save_libs="$LIBS"
+- LIBS=$LIBS' -llwgeom -lgeos_c'
++ LIBS=$LIBS' -llwgeom -lgeos_cd'
+ cat confdefs.h - <<_ACEOF >conftest.$ac_ext
+ /* end confdefs.h. */
+ int main() { return lwgeom_make_valid(); return 0; }
+@@ -18255,7 +18255,7 @@ fi
+ rm -f core conftest.err conftest.$ac_objext \
+ conftest$ac_exeext conftest.$ac_ext
+ LIBS="$_save_libs"
+- LIBS=$LIBS' -llwgeom -lgeos_c'
++ LIBS=$LIBS' -llwgeom -lgeos_cd'
+ #
+ # testing for PostGIS 2.1 - lwgeom_set_handlers
+ #
+@@ -18283,7 +18283,7 @@ return lwgeom_set_handlers ();
+ return 0;
+ }
+ _ACEOF
+-for ac_lib in '' geos_c; do
++for ac_lib in '' geos_cd; do
+ if test -z "$ac_lib"; then
+ ac_res="none required"
+ else
diff --git a/ports/libspatialite/geos-config-debug.in b/ports/libspatialite/geos-config-debug.in
new file mode 100644
index 000000000..d274c2a68
--- /dev/null
+++ b/ports/libspatialite/geos-config-debug.in
@@ -0,0 +1,75 @@
+#!/bin/sh
+prefix=@prefix@
+exec_prefix=@exec_prefix@
+libdir=@libdir@
+
+usage()
+{
+ cat <<EOF
+Usage: geos-config [OPTIONS]
+Options:
+ [--prefix]
+ [--version]
+ [--libs]
+ [--clibs]
+ [--cclibs]
+ [--static-clibs]
+ [--static-cclibs]
+ [--cflags]
+ [--ldflags]
+ [--includes]
+ [--jtsport]
+EOF
+ exit $1
+}
+if test $# -eq 0; then
+ usage 1 1>&2
+fi
+while test $# -gt 0; do
+case "$1" in
+ -*=*) optarg=`echo "$1" | sed 's/[-_a-zA-Z0-9]*=//'` ;;
+ *) optarg= ;;
+esac
+case $1 in
+ --prefix)
+ echo ${prefix}
+ ;;
+ --version)
+ echo 3.6.3
+ ;;
+ --cflags)
+ echo -I${prefix}/include
+ ;;
+ --libs)
+ # TODO: make an alias for --clibs
+ # see http://trac.osgeo.org/geos/ticket/497
+ echo -L${libdir} -lgeosd
+ ;;
+ --clibs)
+ echo -L${libdir} -lgeos_cd
+ ;;
+ --cclibs)
+ echo -L${libdir} -lgeosd
+ ;;
+ --static-clibs)
+ echo -L${libdir} -lgeos_cd -lgeosd -lm
+ ;;
+ --static-cclibs)
+ echo -L${libdir} -lgeosd -lm
+ ;;
+ --ldflags)
+ echo -L${libdir} -lgeos_cd -lgeosd -lstdc++ -lm
+ ;;
+ --includes)
+ echo ${prefix}/include
+ ;;
+ --jtsport)
+ echo 1.13.0
+ ;;
+ *)
+ usage 1 1>&2
+ ;;
+ esac
+ shift
+done
+
diff --git a/ports/libspatialite/geos-config.in b/ports/libspatialite/geos-config.in
new file mode 100644
index 000000000..a2a6d5d17
--- /dev/null
+++ b/ports/libspatialite/geos-config.in
@@ -0,0 +1,75 @@
+#!/bin/sh
+prefix=@prefix@
+exec_prefix=@exec_prefix@
+libdir=@libdir@
+
+usage()
+{
+ cat <<EOF
+Usage: geos-config [OPTIONS]
+Options:
+ [--prefix]
+ [--version]
+ [--libs]
+ [--clibs]
+ [--cclibs]
+ [--static-clibs]
+ [--static-cclibs]
+ [--cflags]
+ [--ldflags]
+ [--includes]
+ [--jtsport]
+EOF
+ exit $1
+}
+if test $# -eq 0; then
+ usage 1 1>&2
+fi
+while test $# -gt 0; do
+case "$1" in
+ -*=*) optarg=`echo "$1" | sed 's/[-_a-zA-Z0-9]*=//'` ;;
+ *) optarg= ;;
+esac
+case $1 in
+ --prefix)
+ echo ${prefix}
+ ;;
+ --version)
+ echo 3.6.3
+ ;;
+ --cflags)
+ echo -I${prefix}/include
+ ;;
+ --libs)
+ # TODO: make an alias for --clibs
+ # see http://trac.osgeo.org/geos/ticket/497
+ echo -L${libdir} -lgeos
+ ;;
+ --clibs)
+ echo -L${libdir} -lgeos_c
+ ;;
+ --cclibs)
+ echo -L${libdir} -lgeos
+ ;;
+ --static-clibs)
+ echo -L${libdir} -lgeos_c -lgeos -lm
+ ;;
+ --static-cclibs)
+ echo -L${libdir} -lgeos -lm
+ ;;
+ --ldflags)
+ echo -L${libdir} -lgeos_c -lgeos -lstdc++ -lm
+ ;;
+ --includes)
+ echo ${prefix}/include
+ ;;
+ --jtsport)
+ echo 1.13.0
+ ;;
+ *)
+ usage 1 1>&2
+ ;;
+ esac
+ shift
+done
+
diff --git a/ports/libspatialite/portfile.cmake b/ports/libspatialite/portfile.cmake
index b73733ff2..f998d50d1 100644
--- a/ports/libspatialite/portfile.cmake
+++ b/ports/libspatialite/portfile.cmake
@@ -1,114 +1,235 @@
include(vcpkg_common_functions)
-set(SOURCE_PATH ${CURRENT_BUILDTREES_DIR}/src/libspatialite-4.3.0a)
+set(LIBSPATIALITE_VERSION_STR "4.3.0a")
vcpkg_download_distfile(ARCHIVE
- URLS "http://www.gaia-gis.it/gaia-sins/libspatialite-sources/libspatialite-4.3.0a.tar.gz"
- FILENAME "libspatialite-4.3.0a.tar.gz"
+ URLS "http://www.gaia-gis.it/gaia-sins/libspatialite-sources/libspatialite-${LIBSPATIALITE_VERSION_STR}.tar.gz"
+ FILENAME "libspatialite-${LIBSPATIALITE_VERSION_STR}.tar.gz"
SHA512 adfd63e8dde0f370b07e4e7bb557647d2bfb5549205b60bdcaaca69ff81298a3d885e7c1ca515ef56dd0aca152ae940df8b5dbcb65bb61ae0a9337499895c3c0
)
-vcpkg_extract_source_archive(${ARCHIVE})
-find_program(NMAKE nmake)
+if (VCPKG_TARGET_IS_WINDOWS)
+ find_program(NMAKE nmake)
-vcpkg_apply_patches(
- SOURCE_PATH ${SOURCE_PATH}
- PATCHES
- ${CMAKE_CURRENT_LIST_DIR}/fix-makefiles.patch
- ${CMAKE_CURRENT_LIST_DIR}/fix-sources.patch
- ${CMAKE_CURRENT_LIST_DIR}/fix-latin-literals.patch
-)
+ vcpkg_extract_source_archive_ex(
+ OUT_SOURCE_PATH SOURCE_PATH
+ ARCHIVE ${ARCHIVE}
+ PATCHES
+ ${CMAKE_CURRENT_LIST_DIR}/fix-makefiles.patch
+ ${CMAKE_CURRENT_LIST_DIR}/fix-sources.patch
+ ${CMAKE_CURRENT_LIST_DIR}/fix-latin-literals.patch
+ )
-# fix most of the problems when spacebar is in the path
-set(CURRENT_INSTALLED_DIR "\"${CURRENT_INSTALLED_DIR}\"")
-
-if(VCPKG_CRT_LINKAGE STREQUAL dynamic)
- set(CL_FLAGS_DBG "/MDd /Zi")
- set(CL_FLAGS_REL "/MD /Ox")
- set(GEOS_LIBS_REL "${CURRENT_INSTALLED_DIR}/lib/geos_c.lib")
- set(GEOS_LIBS_DBG "${CURRENT_INSTALLED_DIR}/debug/lib/geos_cd.lib")
- set(LIBXML2_LIBS_REL "${CURRENT_INSTALLED_DIR}/lib/libxml2.lib")
- set(LIBXML2_LIBS_DBG "${CURRENT_INSTALLED_DIR}/debug/lib/libxml2.lib")
-else()
- set(CL_FLAGS_DBG "/MTd /Zi")
- set(CL_FLAGS_REL "/MT /Ox")
- set(GEOS_LIBS_REL "${CURRENT_INSTALLED_DIR}/lib/libgeos_c.lib ${CURRENT_INSTALLED_DIR}/lib/libgeos.lib")
- set(GEOS_LIBS_DBG "${CURRENT_INSTALLED_DIR}/debug/lib/libgeos_cd.lib ${CURRENT_INSTALLED_DIR}/debug/lib/libgeosd.lib")
- set(LIBXML2_LIBS_REL "${CURRENT_INSTALLED_DIR}/lib/libxml2.lib ${CURRENT_INSTALLED_DIR}/lib/lzma.lib ws2_32.lib")
- set(LIBXML2_LIBS_DBG "${CURRENT_INSTALLED_DIR}/debug/lib/libxml2.lib ${CURRENT_INSTALLED_DIR}/debug/lib/lzmad.lib ws2_32.lib")
-endif()
-
-set(LIBS_ALL_DBG
- "${CURRENT_INSTALLED_DIR}/debug/lib/libiconv.lib \
- ${CURRENT_INSTALLED_DIR}/debug/lib/libcharset.lib \
- ${CURRENT_INSTALLED_DIR}/debug/lib/sqlite3.lib \
- ${CURRENT_INSTALLED_DIR}/debug/lib/freexl.lib \
- ${CURRENT_INSTALLED_DIR}/debug/lib/zlibd.lib \
- ${LIBXML2_LIBS_DBG} \
- ${GEOS_LIBS_DBG} \
- ${CURRENT_INSTALLED_DIR}/debug/lib/projd.lib"
- )
-set(LIBS_ALL_REL
- "${CURRENT_INSTALLED_DIR}/lib/libiconv.lib \
- ${CURRENT_INSTALLED_DIR}/lib/libcharset.lib \
- ${CURRENT_INSTALLED_DIR}/lib/sqlite3.lib \
- ${CURRENT_INSTALLED_DIR}/lib/freexl.lib \
- ${CURRENT_INSTALLED_DIR}/lib/zlib.lib \
- ${LIBXML2_LIBS_REL} \
- ${GEOS_LIBS_REL} \
- ${CURRENT_INSTALLED_DIR}/lib/proj.lib"
- )
-
-################
-# Debug build
-################
-if(NOT DEFINED VCPKG_BUILD_TYPE OR VCPKG_BUILD_TYPE STREQUAL "debug")
- message(STATUS "Building ${TARGET_TRIPLET}-dbg")
+ # fix most of the problems when spacebar is in the path
+ set(CURRENT_INSTALLED_DIR "\"${CURRENT_INSTALLED_DIR}\"")
+
+ if(VCPKG_CRT_LINKAGE STREQUAL dynamic)
+ set(CL_FLAGS_DBG "/MDd /Zi")
+ set(CL_FLAGS_REL "/MD /Ox")
+ set(GEOS_LIBS_REL "${CURRENT_INSTALLED_DIR}/lib/geos_c.lib")
+ set(GEOS_LIBS_DBG "${CURRENT_INSTALLED_DIR}/debug/lib/geos_cd.lib")
+ set(LIBXML2_LIBS_REL "${CURRENT_INSTALLED_DIR}/lib/libxml2.lib")
+ set(LIBXML2_LIBS_DBG "${CURRENT_INSTALLED_DIR}/debug/lib/libxml2.lib")
+ else()
+ set(CL_FLAGS_DBG "/MTd /Zi")
+ set(CL_FLAGS_REL "/MT /Ox")
+ set(GEOS_LIBS_REL "${CURRENT_INSTALLED_DIR}/lib/libgeos_c.lib ${CURRENT_INSTALLED_DIR}/lib/libgeos.lib")
+ set(GEOS_LIBS_DBG "${CURRENT_INSTALLED_DIR}/debug/lib/libgeos_cd.lib ${CURRENT_INSTALLED_DIR}/debug/lib/libgeosd.lib")
+ set(LIBXML2_LIBS_REL "${CURRENT_INSTALLED_DIR}/lib/libxml2.lib ${CURRENT_INSTALLED_DIR}/lib/lzma.lib ws2_32.lib")
+ set(LIBXML2_LIBS_DBG "${CURRENT_INSTALLED_DIR}/debug/lib/libxml2.lib ${CURRENT_INSTALLED_DIR}/debug/lib/lzmad.lib ws2_32.lib")
+ endif()
+
+ set(LIBS_ALL_DBG
+ "${CURRENT_INSTALLED_DIR}/debug/lib/libiconv.lib \
+ ${CURRENT_INSTALLED_DIR}/debug/lib/libcharset.lib \
+ ${CURRENT_INSTALLED_DIR}/debug/lib/sqlite3.lib \
+ ${CURRENT_INSTALLED_DIR}/debug/lib/freexl.lib \
+ ${CURRENT_INSTALLED_DIR}/debug/lib/zlibd.lib \
+ ${LIBXML2_LIBS_DBG} \
+ ${GEOS_LIBS_DBG} \
+ ${CURRENT_INSTALLED_DIR}/debug/lib/projd.lib"
+ )
+ set(LIBS_ALL_REL
+ "${CURRENT_INSTALLED_DIR}/lib/libiconv.lib \
+ ${CURRENT_INSTALLED_DIR}/lib/libcharset.lib \
+ ${CURRENT_INSTALLED_DIR}/lib/sqlite3.lib \
+ ${CURRENT_INSTALLED_DIR}/lib/freexl.lib \
+ ${CURRENT_INSTALLED_DIR}/lib/zlib.lib \
+ ${LIBXML2_LIBS_REL} \
+ ${GEOS_LIBS_REL} \
+ ${CURRENT_INSTALLED_DIR}/lib/proj.lib"
+ )
+
+ ################
+ # Debug build
+ ################
+ if(NOT DEFINED VCPKG_BUILD_TYPE OR VCPKG_BUILD_TYPE STREQUAL "debug")
+ message(STATUS "Building ${TARGET_TRIPLET}-dbg")
+
+ file(TO_NATIVE_PATH "${CURRENT_PACKAGES_DIR}/debug" INST_DIR_DBG)
+
+ vcpkg_execute_required_process(
+ COMMAND ${NMAKE} -f makefile.vc clean install
+ "INST_DIR=\"${INST_DIR_DBG}\"" INSTALLED_ROOT=${CURRENT_INSTALLED_DIR} "LINK_FLAGS=/debug" "CL_FLAGS=${CL_FLAGS_DBG}" "LIBS_ALL=${LIBS_ALL_DBG}"
+ WORKING_DIRECTORY ${SOURCE_PATH}
+ LOGNAME nmake-build-${TARGET_TRIPLET}-debug
+ )
+ message(STATUS "Building ${TARGET_TRIPLET}-dbg done")
+ vcpkg_copy_pdbs()
+ endif()
+
+ ################
+ # Release build
+ ################
+ if(NOT DEFINED VCPKG_BUILD_TYPE OR VCPKG_BUILD_TYPE STREQUAL "release")
+ message(STATUS "Building ${TARGET_TRIPLET}-rel")
+
+ file(TO_NATIVE_PATH "${CURRENT_PACKAGES_DIR}" INST_DIR_REL)
+ vcpkg_execute_required_process(
+ COMMAND ${NMAKE} -f makefile.vc clean install
+ "INST_DIR=\"${INST_DIR_REL}\"" INSTALLED_ROOT=${CURRENT_INSTALLED_DIR} "LINK_FLAGS=" "CL_FLAGS=${CL_FLAGS_REL}" "LIBS_ALL=${LIBS_ALL_REL}"
+ WORKING_DIRECTORY ${SOURCE_PATH}
+ LOGNAME nmake-build-${TARGET_TRIPLET}-release
+ )
+ message(STATUS "Building ${TARGET_TRIPLET}-rel done")
+ endif()
- file(TO_NATIVE_PATH "${CURRENT_PACKAGES_DIR}/debug" INST_DIR_DBG)
+ file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/debug/include)
+ file(INSTALL ${SOURCE_PATH}/COPYING DESTINATION ${CURRENT_PACKAGES_DIR}/share/libspatialite RENAME copyright)
+
+ if (VCPKG_LIBRARY_LINKAGE STREQUAL static)
+ file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/bin)
+ file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/debug/bin)
+ file(REMOVE ${CURRENT_PACKAGES_DIR}/lib/spatialite_i.lib)
+ file(REMOVE ${CURRENT_PACKAGES_DIR}/debug/lib/spatialite_i.lib)
+ else()
+ file(REMOVE ${CURRENT_PACKAGES_DIR}/lib/spatialite.lib)
+ file(REMOVE ${CURRENT_PACKAGES_DIR}/debug/lib/spatialite.lib)
+ if(NOT DEFINED VCPKG_BUILD_TYPE OR VCPKG_BUILD_TYPE STREQUAL "release")
+ file(RENAME ${CURRENT_PACKAGES_DIR}/lib/spatialite_i.lib ${CURRENT_PACKAGES_DIR}/lib/spatialite.lib)
+ endif()
+ if(NOT DEFINED VCPKG_BUILD_TYPE OR VCPKG_BUILD_TYPE STREQUAL "debug")
+ file(RENAME ${CURRENT_PACKAGES_DIR}/debug/lib/spatialite_i.lib ${CURRENT_PACKAGES_DIR}/debug/lib/spatialite.lib)
+ endif()
+ endif()
+
+ message(STATUS "Packaging ${TARGET_TRIPLET} done")
+elseif (VCPKG_TARGET_IS_LINUX OR VCPKG_TARGET_IS_OSX) # Build in UNIX
+ # Check build system first
+ find_program(MAKE make)
+ if (NOT MAKE)
+ message(FATAL_ERROR "MAKE not found")
+ endif()
+
+ if(NOT DEFINED VCPKG_BUILD_TYPE OR VCPKG_BUILD_TYPE STREQUAL "release")
+ ################
+ # Release build
+ ################
+ vcpkg_extract_source_archive_ex(
+ OUT_SOURCE_PATH SOURCE_PATH_RELEASE
+ ARCHIVE ${ARCHIVE}
+ REF release
+ PATCHES
+ ${CMAKE_CURRENT_LIST_DIR}/fix-sources.patch
+ ${CMAKE_CURRENT_LIST_DIR}/fix-latin-literals.patch
+ )
+ message(STATUS "Configuring ${TARGET_TRIPLET}-rel")
+ set(OUT_PATH_RELEASE ${SOURCE_PATH_RELEASE}/../../make-build-${TARGET_TRIPLET}-release)
+ file(REMOVE_RECURSE ${OUT_PATH_RELEASE})
+ file(MAKE_DIRECTORY ${OUT_PATH_RELEASE})
+ set(prefix ${CURRENT_INSTALLED_DIR})
+ set(exec_prefix ${prefix}/bin)
+ set(includedir ${prefix}/include)
+ set(libdir ${prefix}/lib)
+ configure_file(${CMAKE_CURRENT_LIST_DIR}/geos-config.in
+ ${SOURCE_PATH_RELEASE}/geos-config @ONLY)
+ vcpkg_execute_required_process(
+ COMMAND chmod -R 777 ${SOURCE_PATH_RELEASE}/geos-config
+ WORKING_DIRECTORY ${SOURCE_PATH_RELEASE}
+ LOGNAME config-${TARGET_TRIPLET}-rel
+ )
vcpkg_execute_required_process(
- COMMAND ${NMAKE} -f makefile.vc clean install
- "INST_DIR=\"${INST_DIR_DBG}\"" INSTALLED_ROOT=${CURRENT_INSTALLED_DIR} "LINK_FLAGS=/debug" "CL_FLAGS=${CL_FLAGS_DBG}" "LIBS_ALL=${LIBS_ALL_DBG}"
- WORKING_DIRECTORY ${SOURCE_PATH}
- LOGNAME nmake-build-${TARGET_TRIPLET}-debug
+ COMMAND "${SOURCE_PATH_RELEASE}/configure" --prefix=${OUT_PATH_RELEASE} "CFLAGS=-I${includedir} ${VCPKG_C_FLAGS} ${VCPKG_C_FLAGS_RELEASE}" "LDFLAGS=-L${libdir}" "LIBS=-lpthread -ldl" "--with-geosconfig=${SOURCE_PATH_RELEASE}/geos-config" "LIBXML2_LIBS=-lxml2 -llzma" "LIBXML2_CFLAGS=${includedir}"
+ WORKING_DIRECTORY ${SOURCE_PATH_RELEASE}
+ LOGNAME config-${TARGET_TRIPLET}-rel
)
- message(STATUS "Building ${TARGET_TRIPLET}-dbg done")
- vcpkg_copy_pdbs()
-endif()
-
-################
-# Release build
-################
-if(NOT DEFINED VCPKG_BUILD_TYPE OR VCPKG_BUILD_TYPE STREQUAL "release")
- message(STATUS "Building ${TARGET_TRIPLET}-rel")
- file(TO_NATIVE_PATH "${CURRENT_PACKAGES_DIR}" INST_DIR_REL)
+ message(STATUS "Building ${TARGET_TRIPLET}-rel")
vcpkg_execute_required_process(
- COMMAND ${NMAKE} -f makefile.vc clean install
- "INST_DIR=\"${INST_DIR_REL}\"" INSTALLED_ROOT=${CURRENT_INSTALLED_DIR} "LINK_FLAGS=" "CL_FLAGS=${CL_FLAGS_REL}" "LIBS_ALL=${LIBS_ALL_REL}"
- WORKING_DIRECTORY ${SOURCE_PATH}
- LOGNAME nmake-build-${TARGET_TRIPLET}-release
+ COMMAND make
+ WORKING_DIRECTORY ${SOURCE_PATH_RELEASE}
+ LOGNAME make-build-${TARGET_TRIPLET}-release
)
- message(STATUS "Building ${TARGET_TRIPLET}-rel done")
-endif()
+ message(STATUS "Installing ${TARGET_TRIPLET}-rel")
+ vcpkg_execute_required_process(
+ COMMAND make install
+ WORKING_DIRECTORY ${SOURCE_PATH_RELEASE}
+ LOGNAME make-install-${TARGET_TRIPLET}-release
+ )
-file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/debug/include)
-file(INSTALL ${SOURCE_PATH}/COPYING DESTINATION ${CURRENT_PACKAGES_DIR}/share/libspatialite RENAME copyright)
-
-if (VCPKG_LIBRARY_LINKAGE STREQUAL static)
- file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/bin)
- file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/debug/bin)
- file(REMOVE ${CURRENT_PACKAGES_DIR}/lib/spatialite_i.lib)
- file(REMOVE ${CURRENT_PACKAGES_DIR}/debug/lib/spatialite_i.lib)
-else()
- file(REMOVE ${CURRENT_PACKAGES_DIR}/lib/spatialite.lib)
- file(REMOVE ${CURRENT_PACKAGES_DIR}/debug/lib/spatialite.lib)
- if(NOT DEFINED VCPKG_BUILD_TYPE OR VCPKG_BUILD_TYPE STREQUAL "release")
- file(RENAME ${CURRENT_PACKAGES_DIR}/lib/spatialite_i.lib ${CURRENT_PACKAGES_DIR}/lib/spatialite.lib)
+ set(VERSION ${LIBSPATIALITE_VERSION_STR})
+ configure_file(${SOURCE_PATH_RELEASE}/spatialite.pc.in
+ ${OUT_PATH_RELEASE}/lib/pkgconfig/spatialite.pc @ONLY)
+ file(COPY ${OUT_PATH_RELEASE}/lib DESTINATION ${CURRENT_PACKAGES_DIR})
+ file(COPY ${OUT_PATH_RELEASE}/include DESTINATION ${CURRENT_PACKAGES_DIR})
+ file(INSTALL ${SOURCE_PATH_RELEASE}/COPYING DESTINATION ${CURRENT_PACKAGES_DIR}/share/libspatialite RENAME copyright)
+ message(STATUS "Installing ${TARGET_TRIPLET}-rel done")
endif()
+
if(NOT DEFINED VCPKG_BUILD_TYPE OR VCPKG_BUILD_TYPE STREQUAL "debug")
- file(RENAME ${CURRENT_PACKAGES_DIR}/debug/lib/spatialite_i.lib ${CURRENT_PACKAGES_DIR}/debug/lib/spatialite.lib)
- endif()
-endif()
+ ################
+ # Debug build
+ ################
+ vcpkg_extract_source_archive_ex(
+ OUT_SOURCE_PATH SOURCE_PATH_DEBUG
+ ARCHIVE ${ARCHIVE}
+ REF debug
+ PATCHES
+ ${CMAKE_CURRENT_LIST_DIR}/fix-sources.patch
+ ${CMAKE_CURRENT_LIST_DIR}/fix-latin-literals.patch
+ ${CMAKE_CURRENT_LIST_DIR}/fix-configure-debug.patch
+ )
+ message(STATUS "Configuring ${TARGET_TRIPLET}-dbg")
+ set(OUT_PATH_DEBUG ${SOURCE_PATH_DEBUG}/../../make-build-${TARGET_TRIPLET}-debug)
+ file(REMOVE_RECURSE ${OUT_PATH_DEBUG})
+ file(MAKE_DIRECTORY ${OUT_PATH_DEBUG})
+ set(prefix ${CURRENT_INSTALLED_DIR})
+ set(exec_prefix ${prefix}/debug/bin)
+ set(includedir ${prefix}/include)
+ set(libdir ${prefix}/debug/lib)
+ configure_file(${CMAKE_CURRENT_LIST_DIR}/geos-config-debug.in
+ ${SOURCE_PATH_DEBUG}/geos-config @ONLY)
+ vcpkg_execute_required_process(
+ COMMAND chmod -R 777 ${SOURCE_PATH_DEBUG}/geos-config
+ WORKING_DIRECTORY ${SOURCE_PATH_DEBUG}
+ LOGNAME config-${TARGET_TRIPLET}-debug
+ )
+ vcpkg_execute_required_process(
+ COMMAND "${SOURCE_PATH_DEBUG}/configure" --prefix=${OUT_PATH_DEBUG} "CFLAGS=-I${includedir} ${VCPKG_C_FLAGS} ${VCPKG_C_FLAGS_DEBUG}" "LDFLAGS=-L${libdir}" "LIBS=-lpthread -ldl" "--with-geosconfig=${SOURCE_PATH_DEBUG}/geos-config" "LIBXML2_LIBS=-lxml2 -llzmad" "LIBXML2_CFLAGS=${includedir}"
+ WORKING_DIRECTORY ${SOURCE_PATH_DEBUG}
+ LOGNAME config-${TARGET_TRIPLET}-debug
+ )
-message(STATUS "Packaging ${TARGET_TRIPLET} done")
+ message(STATUS "Building ${TARGET_TRIPLET}-dbg")
+ vcpkg_execute_required_process(
+ COMMAND make
+ WORKING_DIRECTORY ${SOURCE_PATH_DEBUG}
+ LOGNAME make-build-${TARGET_TRIPLET}-debug
+ )
+
+ message(STATUS "Installing ${TARGET_TRIPLET}-dbg")
+ vcpkg_execute_required_process(
+ COMMAND make -j install
+ WORKING_DIRECTORY ${SOURCE_PATH_DEBUG}
+ LOGNAME make-install-${TARGET_TRIPLET}-debug
+ )
+
+ set(VERSION ${LIBSPATIALITE_VERSION_STR})
+ configure_file(${SOURCE_PATH_DEBUG}/spatialite.pc.in
+ ${OUT_PATH_DEBUG}/lib/pkgconfig/spatialite.pc @ONLY)
+ file(COPY ${OUT_PATH_DEBUG}/lib DESTINATION ${CURRENT_PACKAGES_DIR}/debug)
+ message(STATUS "Installing ${TARGET_TRIPLET}-dbg done")
+ endif()
+else() # Other build system
+ message(FATAL_ERROR "Unsupport build system.")
+endif() \ No newline at end of file