Skip to content

Commit

Permalink
Fixed bug 4623 - better CMakeLists for SDL_image
Browse files Browse the repository at this point in the history
  • Loading branch information
1bsyl committed Aug 20, 2019
1 parent e4c8787 commit e3dfff1
Showing 1 changed file with 52 additions and 43 deletions.
95 changes: 52 additions & 43 deletions CMakeLists.txt
@@ -1,52 +1,61 @@
cmake_minimum_required(VERSION 3.0)
cmake_minimum_required(VERSION 3.3.2)
project(SDL_image C)


if (ANDROID)

option(SUPPORT_JPG "Support loading JPEG images" OFF)
option(SUPPORT_PNG "Support loading PNG images" ON)
option(SUPPORT_WEBP "Support loading WEBP images" OFF)

add_library(SDL2_image SHARED)
target_sources(SDL2_image PRIVATE IMG.c IMG_png.c IMG_bmp.c IMG_gif.c
IMG_jpg.c IMG_lbm.c IMG_pcx.c IMG_pnm.c IMG_svg.c IMG_tga.c
IMG_tif.c IMG_webp.c IMG_WIC.c IMG_xcf.c IMG_xpm.c IMG_xv.c IMG_xxx.c)

add_definitions(
-DLOAD_BMP -DLOAD_GIF -DLOAD_LBM -DLOAD_PCX -DLOAD_PNM
-DLOAD_TGA -DLOAD_XCF -DLOAD_XPM -DLOAD_XV -DLOAD_XPM)

if (SUPPORT_JPG)
add_definitions(-DLOAD_JPG)
# missing CMakeFiles
add_subdirectory(external/jpeg-9b)

target_link_libraries(SDL2_image PRIVATE jpeg)
endif()

if (SUPPORT_PNG)
# missing libpng.vers
set(HAVE_LD_VERSION_SCRIPT OFF CACHE BOOL "" FORCE)
add_definitions(-DLOAD_PNG)

add_subdirectory(external/libpng-1.6.37)
include_directories(external/libpng-1.6.37)
target_link_libraries(SDL2_image PRIVATE png)
endif()

if (SUPPORT_WEBP)
add_definitions(-DLOAD_WEBP)
# missing cpufeatures
add_subdirectory(external/libwebp-1.0.2)
target_link_libraries(SDL2_image PRIVATE webp)
endif()

target_include_directories(SDL2_image PUBLIC .)
target_link_libraries(SDL2_image PRIVATE SDL2)
else()
find_package(SDL2 REQUIRED)
endif()

option(SUPPORT_JPG "Support loading JPEG images" ON)
option(SUPPORT_PNG "Support loading PNG images" ON)
option(SUPPORT_WEBP "Support loading WEBP images" OFF)
option(BUILD_SHOWIMAGE "Build the showimage sample program" OFF)
option(BUILD_SHARED_LIBS "Build the library as a shared library" ON)

add_library(SDL2_image SHARED)
target_sources(SDL2_image PRIVATE IMG.c IMG_png.c IMG_bmp.c IMG_gif.c
IMG_jpg.c IMG_lbm.c IMG_pcx.c IMG_pnm.c IMG_svg.c IMG_tga.c
IMG_tif.c IMG_webp.c IMG_WIC.c IMG_xcf.c IMG_xpm.c IMG_xv.c IMG_xxx.c)

target_compile_definitions(SDL2_image PRIVATE
-DLOAD_BMP -DLOAD_GIF -DLOAD_LBM -DLOAD_PCX -DLOAD_PNM
-DLOAD_TGA -DLOAD_XCF -DLOAD_XPM -DLOAD_XV -DLOAD_XPM)

if (SUPPORT_JPG)
target_compile_definitions(SDL2_image PRIVATE -DLOAD_JPG)
add_subdirectory(external/jpeg-9b)
target_link_libraries(SDL2_image PRIVATE jpeg)
endif()

else()
if (SUPPORT_PNG)
# missing libpng.vers
set(HAVE_LD_VERSION_SCRIPT OFF CACHE BOOL "" FORCE)
target_compile_definitions(SDL2_image PRIVATE -DLOAD_PNG)

add_subdirectory(external/libpng-1.6.37)
include_directories(external/libpng-1.6.37)
target_link_libraries(SDL2_image PRIVATE png)
endif()

if (SUPPORT_WEBP)
target_compile_definitions(SDL2_image PRIVATE -DLOAD_WEBP)
# missing cpufeatures
add_subdirectory(external/libwebp-1.0.2)
target_link_libraries(SDL2_image PRIVATE webp)
endif()

add_library(SDL2::image ALIAS SDL2_image)

target_include_directories(SDL2_image PUBLIC ${CMAKE_CURRENT_SOURCE_DIR})

if (ANDROID)
target_link_libraries(SDL2_image PRIVATE SDL2)
else()
target_link_libraries(SDL2_image PRIVATE SDL2::SDL2)
endif()

if(BUILD_SHOWIMAGE)
add_executable(showimage showimage.c)
target_link_libraries(showimage PRIVATE SDL2::SDL2 SDL2::image)
endif()

0 comments on commit e3dfff1

Please sign in to comment.