2017-01-05 21:22:32 +01:00
|
|
|
diff --git a/CMakeLists.txt b/CMakeLists.txt
|
2019-08-24 13:43:57 -07:00
|
|
|
index bd80b12..6509541 100644
|
2017-01-05 21:22:32 +01:00
|
|
|
--- a/CMakeLists.txt
|
|
|
|
+++ b/CMakeLists.txt
|
2019-08-24 13:43:57 -07:00
|
|
|
@@ -148,10 +148,6 @@ IF (CMAKE_C_COMPILER_ID MATCHES "^XL$")
|
|
|
|
SET(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} -qinfo=pro:use")
|
|
|
|
ENDIF(CMAKE_C_COMPILER_ID MATCHES "^XL$")
|
|
|
|
IF (MSVC)
|
|
|
|
- if (ENABLE_WERROR)
|
|
|
|
- # /WX option is the same as gcc's -Werror option.
|
|
|
|
- SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /WX")
|
|
|
|
- endif ()
|
2017-01-05 21:22:32 +01:00
|
|
|
#################################################################
|
2019-08-24 13:43:57 -07:00
|
|
|
# Set compile flags for debug build.
|
|
|
|
# This is added into CMAKE_C_FLAGS when CMAKE_BUILD_TYPE is "Debug"
|
|
|
|
@@ -377,8 +373,6 @@ IF(DEFINED __GNUWIN32PATH AND EXISTS "${__GNUWIN32PATH}")
|
|
|
|
# Maybe DLL path is "C:/Program Files/GnuWin32/bin".
|
2017-01-05 21:22:32 +01:00
|
|
|
# The zlib and the bzip2 Setup program have installed programs and DLLs into
|
|
|
|
# "C:/Program Files/GnuWin32" by default.
|
2019-08-24 13:43:57 -07:00
|
|
|
- # This is convenience setting for Windows.
|
2017-01-05 21:22:32 +01:00
|
|
|
- SET(CMAKE_PREFIX_PATH ${__GNUWIN32PATH} $(CMAKE_PREFIX_PATH))
|
|
|
|
#
|
|
|
|
# If you didn't use Setup program or installed into nonstandard path,
|
|
|
|
# cmake cannot find out your zlib or bzip2 libraries and include files,
|
2019-08-24 13:43:57 -07:00
|
|
|
@@ -415,14 +409,7 @@ IF(ZLIB_FOUND)
|
|
|
|
INCLUDE_DIRECTORIES(${ZLIB_INCLUDE_DIR})
|
|
|
|
LIST(APPEND ADDITIONAL_LIBS ${ZLIB_LIBRARIES})
|
|
|
|
IF(WIN32 AND NOT CYGWIN)
|
|
|
|
- #
|
|
|
|
- # Test if ZLIB_WINAPI macro is needed to use.
|
|
|
|
- #
|
2017-01-05 21:22:32 +01:00
|
|
|
- TRY_MACRO_FOR_LIBRARY(
|
|
|
|
- "${ZLIB_INCLUDE_DIR}" "${ZLIB_LIBRARIES}"
|
|
|
|
- RUNS
|
|
|
|
- "#include <zlib.h>\nint main() {uLong f = zlibCompileFlags(); return (f&(1U<<10))?0:-1; }"
|
|
|
|
- ZLIB_WINAPI)
|
2017-04-05 16:06:42 +02:00
|
|
|
+ SET(ZLIB_WINAPI OFF) # skip following test, it crashes with weird message box
|
2017-01-05 21:22:32 +01:00
|
|
|
IF(ZLIB_WINAPI)
|
|
|
|
ADD_DEFINITIONS(-DZLIB_WINAPI)
|
|
|
|
ELSE(ZLIB_WINAPI)
|
2019-08-24 13:43:57 -07:00
|
|
|
@@ -482,8 +469,6 @@ IF(LIBLZMA_FOUND)
|
2017-04-05 16:06:42 +02:00
|
|
|
SET(HAVE_LIBLZMA 1)
|
|
|
|
SET(HAVE_LZMA_H 1)
|
2019-08-24 13:43:57 -07:00
|
|
|
CMAKE_PUSH_CHECK_STATE()
|
2017-04-05 16:06:42 +02:00
|
|
|
- SET(CMAKE_REQUIRED_INCLUDES ${LIBLZMA_INCLUDE_DIR})
|
|
|
|
- SET(CMAKE_REQUIRED_LIBRARIES ${LIBLZMA_LIBRARIES})
|
|
|
|
INCLUDE_DIRECTORIES(${LIBLZMA_INCLUDE_DIRS})
|
|
|
|
LIST(APPEND ADDITIONAL_LIBS ${LIBLZMA_LIBRARIES})
|
|
|
|
# Test if a macro is needed for the library.
|
2019-08-24 13:43:57 -07:00
|
|
|
@@ -1327,7 +1312,7 @@ CHECK_FUNCTION_EXISTS_GLIBC(localtime_r HAVE_LOCALTIME_R)
|
2017-04-05 16:06:42 +02:00
|
|
|
CHECK_FUNCTION_EXISTS_GLIBC(lstat HAVE_LSTAT)
|
|
|
|
CHECK_FUNCTION_EXISTS_GLIBC(lutimes HAVE_LUTIMES)
|
|
|
|
CHECK_FUNCTION_EXISTS_GLIBC(mbrtowc HAVE_MBRTOWC)
|
|
|
|
-CHECK_FUNCTION_EXISTS_GLIBC(memmove HAVE_MEMMOVE)
|
|
|
|
+set(HAVE_MEMMOVE 1)
|
|
|
|
CHECK_FUNCTION_EXISTS_GLIBC(mkdir HAVE_MKDIR)
|
|
|
|
CHECK_FUNCTION_EXISTS_GLIBC(mkfifo HAVE_MKFIFO)
|
|
|
|
CHECK_FUNCTION_EXISTS_GLIBC(mknod HAVE_MKNOD)
|
2019-08-24 13:43:57 -07:00
|
|
|
@@ -1359,11 +1344,11 @@ CHECK_FUNCTION_EXISTS_GLIBC(utime HAVE_UTIME)
|
2017-04-05 16:06:42 +02:00
|
|
|
CHECK_FUNCTION_EXISTS_GLIBC(utimes HAVE_UTIMES)
|
|
|
|
CHECK_FUNCTION_EXISTS_GLIBC(utimensat HAVE_UTIMENSAT)
|
|
|
|
CHECK_FUNCTION_EXISTS_GLIBC(vfork HAVE_VFORK)
|
|
|
|
-CHECK_FUNCTION_EXISTS_GLIBC(wcrtomb HAVE_WCRTOMB)
|
|
|
|
-CHECK_FUNCTION_EXISTS_GLIBC(wcscmp HAVE_WCSCMP)
|
|
|
|
-CHECK_FUNCTION_EXISTS_GLIBC(wcscpy HAVE_WCSCPY)
|
|
|
|
-CHECK_FUNCTION_EXISTS_GLIBC(wcslen HAVE_WCSLEN)
|
|
|
|
-CHECK_FUNCTION_EXISTS_GLIBC(wctomb HAVE_WCTOMB)
|
|
|
|
+set(HAVE_WCRTOMB 1)
|
|
|
|
+set(HAVE_WCSCMP 1)
|
|
|
|
+set(HAVE_WCSCPY 1)
|
|
|
|
+set(HAVE_WCSLEN 1)
|
|
|
|
+set(HAVE_WCTOMB 1)
|
|
|
|
CHECK_FUNCTION_EXISTS_GLIBC(_ctime64_s HAVE__CTIME64_S)
|
|
|
|
CHECK_FUNCTION_EXISTS_GLIBC(_fseeki64 HAVE__FSEEKI64)
|
|
|
|
CHECK_FUNCTION_EXISTS_GLIBC(_get_timezone HAVE__GET_TIMEZONE)
|
2019-08-24 13:43:57 -07:00
|
|
|
@@ -1375,10 +1360,10 @@ CHECK_FUNCTION_EXISTS(cygwin_conv_path HAVE_CYGWIN_CONV_PATH)
|
2017-04-05 16:06:42 +02:00
|
|
|
CHECK_FUNCTION_EXISTS(fseeko HAVE_FSEEKO)
|
|
|
|
CHECK_FUNCTION_EXISTS(strerror_r HAVE_STRERROR_R)
|
|
|
|
CHECK_FUNCTION_EXISTS(strftime HAVE_STRFTIME)
|
|
|
|
-CHECK_FUNCTION_EXISTS(vprintf HAVE_VPRINTF)
|
|
|
|
-CHECK_FUNCTION_EXISTS(wmemcmp HAVE_WMEMCMP)
|
|
|
|
-CHECK_FUNCTION_EXISTS(wmemcpy HAVE_WMEMCPY)
|
|
|
|
-CHECK_FUNCTION_EXISTS(wmemmove HAVE_WMEMMOVE)
|
|
|
|
+set(HAVE_VPRINTF 1)
|
|
|
|
+set(HAVE_WMEMCMP 1)
|
|
|
|
+set(HAVE_WMEMCPY 1)
|
|
|
|
+set(HAVE_WMEMMOVE 1)
|
2017-01-05 21:22:32 +01:00
|
|
|
|
2017-04-05 16:06:42 +02:00
|
|
|
CMAKE_POP_CHECK_STATE() # Restore the state of the variables
|
|
|
|
|
2019-08-24 13:43:57 -07:00
|
|
|
@@ -1419,9 +1404,13 @@ CHECK_C_SOURCE_COMPILES(
|
2017-01-05 21:22:32 +01:00
|
|
|
"#include <sys/sysmacros.h>\nint main() { return major(256); }"
|
|
|
|
MAJOR_IN_SYSMACROS)
|
|
|
|
|
|
|
|
+CMAKE_PUSH_CHECK_STATE()
|
2017-04-05 16:06:42 +02:00
|
|
|
+SET(CMAKE_REQUIRED_INCLUDES ${LIBLZMA_INCLUDE_DIR})
|
|
|
|
+SET(CMAKE_REQUIRED_LIBRARIES ${LIBLZMA_LIBRARIES})
|
2017-01-05 21:22:32 +01:00
|
|
|
CHECK_C_SOURCE_COMPILES(
|
|
|
|
"#include <lzma.h>\n#if LZMA_VERSION < 50020000\n#error unsupported\n#endif\nint main(void){lzma_stream_encoder_mt(0, 0); return 0;}"
|
|
|
|
HAVE_LZMA_STREAM_ENCODER_MT)
|
|
|
|
+CMAKE_POP_CHECK_STATE()
|
|
|
|
|
|
|
|
IF(HAVE_STRERROR_R)
|
|
|
|
SET(HAVE_DECL_STRERROR_R 1)
|
2019-08-24 13:43:57 -07:00
|
|
|
@@ -1977,13 +1966,10 @@ CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/build/cmake/config.h.in
|
|
|
|
INCLUDE_DIRECTORIES(BEFORE ${CMAKE_CURRENT_BINARY_DIR})
|
2017-01-05 21:22:32 +01:00
|
|
|
ADD_DEFINITIONS(-DHAVE_CONFIG_H)
|
|
|
|
|
2019-08-24 13:43:57 -07:00
|
|
|
-# Handle generation of the libarchive.pc file for pkg-config
|
2017-01-05 21:22:32 +01:00
|
|
|
-INCLUDE(CreatePkgConfigFile)
|
2019-08-24 13:43:57 -07:00
|
|
|
-
|
2017-01-05 21:22:32 +01:00
|
|
|
#
|
|
|
|
# Register installation of PDF documents.
|
|
|
|
#
|
|
|
|
-IF(WIN32 AND NOT CYGWIN)
|
2019-08-24 13:43:57 -07:00
|
|
|
+IF(0)
|
2017-01-05 21:22:32 +01:00
|
|
|
#
|
|
|
|
# On Windows platform, It's better that we install PDF documents
|
|
|
|
# on one's computer.
|
|
|
|
diff --git a/libarchive/CMakeLists.txt b/libarchive/CMakeLists.txt
|
2019-08-24 13:43:57 -07:00
|
|
|
index ec775bb..d63ac7c 100644
|
2017-01-05 21:22:32 +01:00
|
|
|
--- a/libarchive/CMakeLists.txt
|
|
|
|
+++ b/libarchive/CMakeLists.txt
|
2019-08-24 13:43:57 -07:00
|
|
|
@@ -235,28 +235,22 @@ ELSEIF(ARCHIVE_ACL_SUNOS)
|
2017-07-12 18:26:28 +02:00
|
|
|
ENDIF()
|
2017-01-05 21:22:32 +01:00
|
|
|
|
2019-08-24 13:43:57 -07:00
|
|
|
# Libarchive is a shared library
|
2017-01-05 21:22:32 +01:00
|
|
|
-ADD_LIBRARY(archive SHARED ${libarchive_SOURCES} ${include_HEADERS})
|
|
|
|
+ADD_LIBRARY(archive ${libarchive_SOURCES} ${include_HEADERS})
|
2019-08-24 13:43:57 -07:00
|
|
|
TARGET_INCLUDE_DIRECTORIES(archive PUBLIC .)
|
2017-01-05 21:22:32 +01:00
|
|
|
TARGET_LINK_LIBRARIES(archive ${ADDITIONAL_LIBS})
|
2017-04-05 16:06:42 +02:00
|
|
|
-SET_TARGET_PROPERTIES(archive PROPERTIES SOVERSION ${SOVERSION})
|
2017-01-05 21:22:32 +01:00
|
|
|
-
|
|
|
|
-# archive_static is a static library
|
|
|
|
-ADD_LIBRARY(archive_static STATIC ${libarchive_SOURCES} ${include_HEADERS})
|
|
|
|
-TARGET_LINK_LIBRARIES(archive_static ${ADDITIONAL_LIBS})
|
|
|
|
-SET_TARGET_PROPERTIES(archive_static PROPERTIES COMPILE_DEFINITIONS
|
2017-04-05 16:06:42 +02:00
|
|
|
+IF(BUILD_SHARED_LIBS)
|
2019-08-24 13:43:57 -07:00
|
|
|
+ SET_TARGET_PROPERTIES(archive PROPERTIES SOVERSION ${SOVERSION})
|
2017-04-05 16:06:42 +02:00
|
|
|
+ELSE()
|
2019-08-24 13:43:57 -07:00
|
|
|
+ SET_TARGET_PROPERTIES(archive PROPERTIES COMPILE_DEFINITIONS
|
2017-04-05 16:06:42 +02:00
|
|
|
LIBARCHIVE_STATIC)
|
2017-01-05 21:22:32 +01:00
|
|
|
-# On Posix systems, libarchive.so and libarchive.a can co-exist.
|
|
|
|
-IF(NOT WIN32 OR CYGWIN)
|
|
|
|
- SET_TARGET_PROPERTIES(archive_static PROPERTIES OUTPUT_NAME archive)
|
|
|
|
-ENDIF(NOT WIN32 OR CYGWIN)
|
|
|
|
+ENDIF()
|
|
|
|
|
|
|
|
IF(ENABLE_INSTALL)
|
|
|
|
# How to install the libraries
|
|
|
|
- INSTALL(TARGETS archive archive_static
|
|
|
|
+ INSTALL(TARGETS archive
|
|
|
|
RUNTIME DESTINATION bin
|
|
|
|
LIBRARY DESTINATION lib
|
|
|
|
ARCHIVE DESTINATION lib)
|
|
|
|
- INSTALL_MAN(${libarchive_MANS})
|
|
|
|
INSTALL(FILES ${include_HEADERS} DESTINATION include)
|
|
|
|
ENDIF()
|
|
|
|
|