Skip to content

Commit

Permalink
Merge pull request #50 from ffontaine/master
Browse files Browse the repository at this point in the history
Do not always build static and dynamic
  • Loading branch information
FSMaxB authored Nov 4, 2016
2 parents 4d06882 + 8e79936 commit 050829f
Showing 1 changed file with 4 additions and 17 deletions.
21 changes: 4 additions & 17 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -7,46 +7,33 @@ project(${PROJ_CJSON} C)
file(GLOB HEADERS cJSON.h)
set(SOURCES cJSON.c)

add_library(${PROJ_CJSON} STATIC ${HEADERS} ${SOURCES})
add_library(${PROJ_CJSON} ${HEADERS} ${SOURCES})
if (NOT WIN32)
target_link_libraries(${PROJ_CJSON} m)
endif()

add_library(${PROJ_CJSON}.shared SHARED ${HEADERS} ${SOURCES})
set_target_properties(${PROJ_CJSON}.shared PROPERTIES OUTPUT_NAME cJSON)
if (NOT WIN32)
target_link_libraries(${PROJ_CJSON}.shared m)
endif()


set(PROJ_CJSON_UTILS cJSON_utils)

project(${PROJ_CJSON_UTILS} C)

file(GLOB HEADERS_UTILS cJSON_Utils.h)
set(SOURCES_UTILS cJSON_Utils.c)

add_library(${PROJ_CJSON_UTILS} STATIC ${HEADERS_UTILS} ${SOURCES_UTILS})
add_library(${PROJ_CJSON_UTILS} ${HEADERS_UTILS} ${SOURCES_UTILS})
target_link_libraries(${PROJ_CJSON_UTILS} ${PROJ_CJSON})

add_library(${PROJ_CJSON_UTILS}.shared SHARED ${HEADERS_UTILS} ${SOURCES_UTILS})
set_target_properties(${PROJ_CJSON_UTILS}.shared PROPERTIES OUTPUT_NAME cJSON_utils)
target_link_libraries(${PROJ_CJSON_UTILS}.shared ${PROJ_CJSON}.shared)

install (TARGETS ${PROJ_CJSON} DESTINATION lib${LIB_SUFFIX})
install (TARGETS ${PROJ_CJSON}.shared DESTINATION lib${LIB_SUFFIX})
install (FILES cJSON.h DESTINATION include/cJSON)
install (TARGETS ${PROJ_CJSON_UTILS} DESTINATION lib${LIB_SUFFIX})
install (TARGETS ${PROJ_CJSON_UTILS}.shared DESTINATION lib${LIB_SUFFIX})
install (FILES cJSON_Utils.h DESTINATION include/cJSON)

option(ENABLE_CJSON_TEST "Enable building cJSON test" OFF)
if(ENABLE_CJSON_TEST)
set(TEST_CJSON cJSON_test)
add_executable(${TEST_CJSON} test.c)
target_link_libraries(${TEST_CJSON} ${PROJ_CJSON}.shared)
target_link_libraries(${TEST_CJSON} ${PROJ_CJSON})

set(TEST_CJSON_UTILS cJSON_test_utils)
add_executable(${TEST_CJSON_UTILS} test_utils.c)
target_link_libraries(${TEST_CJSON_UTILS} ${PROJ_CJSON_UTILS}.shared)
target_link_libraries(${TEST_CJSON_UTILS} ${PROJ_CJSON_UTILS})
endif()

0 comments on commit 050829f

Please sign in to comment.