X-Git-Url: http://developer.intra2net.com/git/?p=libftdi;a=blobdiff_plain;f=src%2FCMakeLists.txt;h=9fd86a6d6b13583e4328df137a5e4c72e938290f;hp=e1ab82d51a0b94d6a52efa814e835921af9d218f;hb=f838a4e3b0466abc34823750e9eef24d785c8232;hpb=b80aee72c93847f79295722315e53fb898b46a27 diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index e1ab82d..9fd86a6 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -1,60 +1,55 @@ # Includes -include_directories( ${CMAKE_CURRENT_BINARY_DIR} +include_directories(BEFORE ${CMAKE_CURRENT_BINARY_DIR} ${CMAKE_CURRENT_SOURCE_DIR} ) -# Targets -set(c_sources ftdi.c) -set(c_headers ftdi.h) - -add_library(ftdi SHARED ${c_sources}) - -# Static library -add_library(ftdi-static STATIC ${c_sources}) -set_target_properties(ftdi-static PROPERTIES OUTPUT_NAME "ftdi") - -# Prevent clobbering each other during the build -set_target_properties(ftdi PROPERTIES CLEAN_DIRECT_OUTPUT 1) -set_target_properties(ftdi-static PROPERTIES CLEAN_DIRECT_OUTPUT 1) - -# Dependencies -target_link_libraries(ftdi ${LIBUSB_LIBRARIES}) +# Version information +set(SNAPSHOT_VERSION "unknown") +execute_process(COMMAND git describe + OUTPUT_VARIABLE GIT_DESCRIBE_OUTPUT + RESULT_VARIABLE GIT_DESCRIBE_RESULT + OUTPUT_STRIP_TRAILING_WHITESPACE + ) +if(${GIT_DESCRIBE_RESULT} STREQUAL 0) + set(SNAPSHOT_VERSION ${GIT_DESCRIBE_OUTPUT}) +endif () +message(STATUS "Detected git snapshot version: ${SNAPSHOT_VERSION}") -# Install -if(${UNIX}) +configure_file(ftdi_version_i.h.in "${CMAKE_CURRENT_BINARY_DIR}/ftdi_version_i.h" @ONLY) - install( TARGETS ftdi - LIBRARY DESTINATION lib - COMPONENT sharedlibs - ) - - install( TARGETS ftdi-static - ARCHIVE DESTINATION lib - COMPONENT staticlibs - ) - - install( FILES ${c_headers} - DESTINATION include/${PROJECT_NAME} - COMPONENT headers - ) +# Targets +set(c_sources ${CMAKE_CURRENT_SOURCE_DIR}/ftdi.c ${CMAKE_CURRENT_SOURCE_DIR}/ftdi_stream.c CACHE INTERNAL "List of c sources" ) +set(c_headers ${CMAKE_CURRENT_SOURCE_DIR}/ftdi.h CACHE INTERNAL "List of c headers" ) -endif(${UNIX}) +add_library(ftdi1 SHARED ${c_sources}) -if(${WIN32}) +math(EXPR VERSION_FIXUP "${MAJOR_VERSION} + 1") # Compatiblity with previous releases +set_target_properties(ftdi1 PROPERTIES VERSION ${VERSION_FIXUP}.${MINOR_VERSION}.0 SOVERSION 2) +# Prevent clobbering each other during the build +set_target_properties ( ftdi1 PROPERTIES CLEAN_DIRECT_OUTPUT 1 ) - install( TARGETS ftdi - DESTINATION bin - COMPONENT sharedlibs - ) - install( TARGETS ftdi-static - DESTINATION bin +# Dependencies +target_link_libraries(ftdi1 ${LIBUSB_LIBRARIES}) + +install ( TARGETS ftdi1 + RUNTIME DESTINATION bin + LIBRARY DESTINATION lib${LIB_SUFFIX} + ARCHIVE DESTINATION lib${LIB_SUFFIX} + ) + +if ( STATICLIBS ) + add_library(ftdi1-static STATIC ${c_sources}) + target_link_libraries(ftdi1-static ${LIBUSB_LIBRARIES}) + set_target_properties(ftdi1-static PROPERTIES OUTPUT_NAME "ftdi1") + set_target_properties(ftdi1-static PROPERTIES CLEAN_DIRECT_OUTPUT 1) + install ( TARGETS ftdi1-static + ARCHIVE DESTINATION lib${LIB_SUFFIX} COMPONENT staticlibs - ) - - install( FILES ${c_headers} - DESTINATION include/${PROJECT_NAME} - COMPONENT headers - ) + ) +endif () -endif(${WIN32}) +install ( FILES ${c_headers} + DESTINATION include/${PROJECT_NAME} + COMPONENT headers + )