X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=CMakeLists.txt;h=6147f271ed0a74de2176cb8f6469d3d856a89c41;hb=816d914c4e4765888de74cd3c1b1000d8575d479;hp=8a9ab9714da1be374045290435ef1f18aede0714;hpb=4c9a60d4fd7ac361dc68b2a41d2fc9326c3ab725;p=openjpeg.git diff --git a/CMakeLists.txt b/CMakeLists.txt index 8a9ab971..6147f271 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -92,9 +92,13 @@ IF(NOT OPENJPEG_INSTALL_DATA_DIR) ENDIF(NOT OPENJPEG_INSTALL_DATA_DIR) IF(NOT OPENJPEG_INSTALL_INCLUDE_DIR) - SET(OPENJPEG_INSTALL_INCLUDE_DIR "include/${subdir}") + SET(OPENJPEG_INSTALL_INCLUDE_DIR "include/") ENDIF(NOT OPENJPEG_INSTALL_INCLUDE_DIR) +IF(NOT OPENJPEG_INSTALL_MAN_DIR) + SET(OPENJPEG_INSTALL_MAN_DIR "share/man/") +ENDIF(NOT OPENJPEG_INSTALL_MAN_DIR) + IF(NOT OPENJPEG_INSTALL_DOC_DIR) SET(OPENJPEG_INSTALL_DOC_DIR "share/doc/${subdir}") ENDIF(NOT OPENJPEG_INSTALL_DOC_DIR) @@ -122,7 +126,7 @@ CONFIGURE_FILE( #----------------------------------------------------------------------------- # OpenJPEG build configuration options. -OPTION(BUILD_SHARED_LIBS "Build OpenJPEG with shared libraries." ON) +OPTION(BUILD_SHARED_LIBS "Build OpenJPEG shared library and link executables against it." ON) #----------------------------------------------------------------------------- SET (EXECUTABLE_OUTPUT_PATH ${OPENJPEG_BINARY_DIR}/bin CACHE PATH "Single output directory for building all executables.") @@ -139,54 +143,52 @@ CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/openjpeg_mangle.h.in @ONLY IMMEDIATE) ENDIF(EXISTS ${CMAKE_CURRENT_SOURCE_DIR}/openjpeg_mangle.h.in) -#----------------------------------------------------------------------------- -# Translate CMake configuration options into #defines that can be queried from -# the code. -#CONFIGURE_FILE( -# ${PROJECT_SOURCE_DIR}/opj_configh.cmake.in -# ${PROJECT_BINARY_DIR}/opj_config.h) - #----------------------------------------------------------------------------- # Always build the library INCLUDE_DIRECTORIES(BEFORE ${CMAKE_CURRENT_BINARY_DIR}) -SUBDIRS( - libopenjpeg - mj2 - ) - -IF(NOT UNIX) -SUBDIRS( - indexer_JPIP - ) -ENDIF(NOT UNIX) +SUBDIRS(libopenjpeg) #----------------------------------------------------------------------------- -# Build example codec ? -OPTION(BUILD_EXAMPLES "Build the Examples (codec...)." ON) -IF(BUILD_EXAMPLES) +# Build CODEC executables ? +OPTION(BUILD_CODEC "Build the CODEC executables" ON) +IF(BUILD_CODEC) SUBDIRS(codec) -ENDIF(BUILD_EXAMPLES) +ENDIF(BUILD_CODEC) #----------------------------------------------------------------------------- -# Build JPWL binaries ? -OPTION(BUILD_JPWL "Build the JPWL binaries" OFF) +# Build MJ2 executables ? +OPTION(BUILD_MJ2 "Build the MJ2 executables." OFF) +IF(BUILD_MJ2) + SUBDIRS(mj2) +ENDIF(BUILD_MJ2) + +#----------------------------------------------------------------------------- +# Build JPWL executables ? +OPTION(BUILD_JPWL "Build the JPWL executables" OFF) IF(BUILD_JPWL) SUBDIRS(jpwl) ENDIF(BUILD_JPWL) #----------------------------------------------------------------------------- -# Build JP3D binaries ? -OPTION(BUILD_JP3D "Build the JP3D binaries" OFF) +# Build JP3D executables ? +OPTION(BUILD_JP3D "Build the JP3D executables" OFF) IF(BUILD_JP3D) SUBDIRS(jp3d) ENDIF(BUILD_JP3D) #----------------------------------------------------------------------------- -# Build documentation ? -OPTION(BUILD_DOCUMENTATION "Build the doxygen documentation" OFF) -IF(BUILD_DOCUMENTATION) +# Build INDEXER_JPIP executables ? +OPTION(BUILD_INDEXER_JPIP "Build the INDEXER_JPIP executables" OFF) +IF(BUILD_INDEXER_JPIP AND NOT UNIX) + SUBDIRS(indexer_JPIP) +ENDIF(BUILD_INDEXER_JPIP AND NOT UNIX) + +#----------------------------------------------------------------------------- +# Build DOCUMENTATION ? +OPTION(BUILD_DOC "Build the doxygen documentation" OFF) +IF(BUILD_DOC) SUBDIRS(doc) -ENDIF(BUILD_DOCUMENTATION) +ENDIF(BUILD_DOC) #----------------------------------------------------------------------------- # For openjpeg team if they ever want CDash+CMake @@ -225,60 +227,93 @@ CONFIGURE_FILE( ${OPENJPEG_SOURCE_DIR}/CMake/OpenJPEGConfig.cmake.in INSTALL( FILES ${OPENJPEG_BINARY_DIR}/OpenJPEGConfig.cmake DESTINATION ${OPENJPEG_INSTALL_PACKAGE_DIR} ) +# install CHANGES and LICENSE +INSTALL( + FILES CHANGES + LICENSE + DESTINATION ${OPENJPEG_INSTALL_DOC_DIR}) # -SET(CMAKE_PREFIX_PATH /usr /usr/local /opt /opt/local) +IF(UNIX OR CYGWIN) + SET(CMAKE_INCLUDE_PATH /usr/include /usr/local/include /opt/include + /opt/local/include /usr/include/libpng /usr/include/libpng14 + /usr/include/libpng12 /usr/local/include/libpng + /usr/local/include/libpng14 /usr/local/include/libpng12 + /opt/include/libpng /opt/include/libpng14 /opt/include/libpng12 + /opt/local/include/libpng /opt/local/include/libpng14 + /opt/local/include/libpng12 ) + SET(CMAKE_LIBRARY_PATH /usr/lib /usr/local/lib /opt/lib /opt/local/lib) +ELSEIF(WIN32) + SET(CMAKE_INCLUDE_PATH ${OPENJPEG_SOURCE_DIR}/libs/libtiff + ${OPENJPEG_SOURCE_DIR}/libs/png ${OPENJPEG_SOURCE_DIR}/libs/lcms2 + C:/WINDOWS/system32/user ) + SET(CMAKE_LIBRARY_PATH ${OPENJPEG_SOURCE_DIR}/libs/libtiff + C:/WINDOWS/system32/user ) +ENDIF() # -FIND_FILE(HAVE_STRINGS_H strings.h) -FIND_FILE(HAVE_INTTYPES_H inttypes.h) -FIND_FILE(HAVE_MEMORY_H memory.h) -FIND_FILE(HAVE_STDLIB_H stdlib.h) -FIND_FILE(HAVE_STRING_H string.h) -FIND_FILE(HAVE_SYS_STAT_H sys/stat.h) -FIND_FILE(HAVE_SYS_TYPES_H sys/types.h) -FIND_FILE(HAVE_UNISTD_H unistd.h) +FIND_FILE(HAVE_STRINGS_H_FOUND strings.h) +IF(NOT HAVE_STRINGS_H_FOUND STREQUAL "HAVE_STRINGS_H_FOUND-NOTFOUND") + FIND_FILE(HAVE_STRINGS_H strings.h) + SET(HAS_STRINGS_H 1) +ENDIF() +FIND_FILE(HAVE_INTTYPES_H_FOUND inttypes.h) +IF(NOT HAVE_INTTYPES_H_FOUND STREQUAL "HAVE_INTTYPES_H_FOUND-NOTFOUND") + FIND_FILE(HAVE_INTTYPES_H inttypes.h) + SET(HAS_INTTYPES_H 1) +ENDIF() +FIND_FILE(HAVE_MEMORY_H_FOUND memory.h) +IF(NOT HAVE_MEMORY_H_FOUND STREQUAL "HAVE_MEMORY_H_FOUND-NOTFOUND") + FIND_FILE(HAVE_MEMORY_H memory.h) + SET(HAS_MEMORY_H 1) +ENDIF() +FIND_FILE(HAVE_STDINT_H_FOUND stdint.h) +IF(NOT HAVE_STDINT_H_FOUND STREQUAL "HAVE_STDINT_H_FOUND-NOTFOUND") + FIND_FILE(HAVE_STDINT_H stdint.h) + SET(HAS_STDINT_H 1) +ENDIF() +FIND_FILE(HAVE_STDLIB_H_FOUND stdlib.h) +IF(NOT HAVE_STDLIB_H_FOUND STREQUAL "HAVE_STDLIB_H_FOUND-NOTFOUND") + FIND_FILE(HAVE_STDLIB_H stdlib.h) + SET(HAS_STDLIB_H 1) +ENDIF() +FIND_FILE(HAVE_STRING_H_FOUND string.h) +IF(NOT HAVE_STRING_H_FOUND STREQUAL "HAVE_STRING_H_FOUND-NOTFOUND") + FIND_FILE(HAVE_STRING_H string.h) + SET(HAS_STRING_H 1) +ENDIF() +FIND_FILE(HAVE_SYS_STAT_H_FOUND sys/stat.h) +IF(NOT HAVE_SYS_STAT_H_FOUND STREQUAL "HAVE_SYS_STAT_H_FOUND-NOTFOUND") + FIND_FILE(HAVE_SYS_STAT_H sys/stat.h) + SET(HAS_SYS_STAT_H 1) +ENDIF() +FIND_FILE(HAVE_SYS_TYPES_H_FOUND sys/types.h) +IF(NOT HAVE_SYS_TYPES_H_FOUND STREQUAL "HAVE_SYS_TYPES_H_FOUND-NOTFOUND") + FIND_FILE(HAVE_SYS_TYPES_H sys/types.h) + SET(HAS_SYS_TYPES_H 1) +ENDIF() +FIND_FILE(HAVE_UNISTD_H_FOUND unistd.h) +IF(NOT HAVE_UNISTD_H_FOUND STREQUAL "HAVE_UNISTD_H_FOUND-NOTFOUND") + FIND_FILE(HAVE_UNISTD_H unistd.h) + SET(HAS_UNISTD_H 1) +ENDIF() # # Does the system have png library installed ? -# FIND_PACKAGE not used because not robust enough # -FIND_PATH(PNG_INCLUDE_DIR png.h PATHS /usr/include /usr/include/libpng14 /usr/include/libpng12 /usr/include/libpng /usr/local/include /usr/local/include/libpng14 /usr/local/include/libpng12 /usr/local/include/libpng /opt/include /opt/include/libpng14 /opt/include/libpng12 /opt/include/libpng /opt/local/include /opt/local/include/libpng14 /opt/local/include/libpng12 /opt/local/include/libpng) +FIND_PACKAGE(PNG) # -IF(PNG_INCLUDE_DIR STREQUAL "PNG_INCLUDE_DIR-NOTFOUND") - SET(HAVE_PNG_H 0) -ELSE() +IF(PNG_FOUND) SET(HAVE_PNG_H 1) -ENDIF() -FIND_LIBRARY(PNG_LIBRARIES NAMES png14 png12 png ) -IF(PNG_LIBRARIES STREQUAL "PNG_LIBRARIES-NOTFOUND") - SET(HAVE_LIBPNG 0) -ELSE() SET(HAVE_LIBPNG 1) ENDIF() -IF(HAVE_LIBPNG AND HAVE_PNG_H) - SET(PNG_FOUND 1) -ELSE() - SET(PNG_FOUND 0) -ENDIF() # # Does the system have tiff library installed ? -# FIND_PACKAGE not used because not robust enough +# +FIND_PACKAGE(TIFF) # -FIND_PATH(TIFF_INCLUDE_DIR tiff.h) -IF(TIFF_INCLUDE_DIR STREQUAL "TIFF_INCLUDE_DIR-NOTFOUND") - SET(HAVE_TIFF_H 0) -ELSE() +IF(TIFF_FOUND) SET(HAVE_TIFF_H 1) -ENDIF() -FIND_LIBRARY(TIFF_LIBRARIES tiff) -IF(TIFF_LIBRARIES STREQUAL "TIFF_LIBRARIES-NOTFOUND") - SET(HAVE_LIBTIFF 0) -ELSE() SET(HAVE_LIBTIFF 1) ENDIF() -IF(HAVE_LIBTIFF AND HAVE_TIFF_H) - SET(TIFF_FOUND 1) -ELSE() - SET(TIFF_FOUND 0) -ENDIF() +# # # Does the system have lcms library installed ? # @@ -290,7 +325,11 @@ IF(LCMS2_HEADER_FOUND STREQUAL "LCMS2_HEADER_FOUND-NOTFOUND") ENDIF() IF(LCMS2_HEADER_FOUND) FIND_PATH(LCMS_INCLUDE_DIR lcms2.h) - FIND_LIBRARY(HAVE_LIBLCMS2 lcms2) + IF(UNIX OR CYGWIN) + FIND_LIBRARY(HAVE_LIBLCMS2 lcms2) + ELSE() + FIND_LIBRARY(HAVE_LIBLCMS2 lcms2_static.lib) + ENDIF() IF(HAVE_LIBLCMS2 STREQUAL "HAVE_LIBLCMS2-NOTFOUND") SET(HAVE_LIBLCMS2 "") ENDIF() @@ -321,6 +360,7 @@ ENDIF() # # generate opj_config.h CONFIGURE_FILE("${OPENJPEG_SOURCE_DIR}/opj_configh.cmake.in" - "${OPENJPEG_BINARY_DIR}/opj_config.h" + "${OPENJPEG_BINARY_DIR}/opj_config.h" + @ONLY )