CMake: reorder Python detection
[libftdi] / ftdipp / CMakeLists.txt
index 8423b2e..a9e3418 100644 (file)
@@ -1,89 +1,47 @@
-# Check
-set(FTDI_BUILD_CPP False PARENT_SCOPE)
+# vim: ts=2:sw=2:sts=2
 
-option(FTDIPP "Build C++ binding library libftdi++" ON)
+# Targets
+set(cpp_sources ${CMAKE_CURRENT_SOURCE_DIR}/ftdi.cpp CACHE INTERNAL "List of cpp sources" )
+set(cpp_headers ${CMAKE_CURRENT_SOURCE_DIR}/ftdi.hpp CACHE INTERNAL "List of cpp headers" )
 
-if (FTDIPP)
+# Includes
+include_directories(BEFORE ${CMAKE_CURRENT_BINARY_DIR}
+       ${CMAKE_CURRENT_SOURCE_DIR}
+       ${CMAKE_SOURCE_DIR}/src)
 
-    # Includes
-    include_directories( ${CMAKE_CURRENT_BINARY_DIR}
-                        ${CMAKE_CURRENT_SOURCE_DIR}
-                        ${CMAKE_CURRENT_SOURCE_DIR}/../src
-                        )
+include_directories(${Boost_INCLUDE_DIRS})
 
-    # Targets
-    set(cpp_sources   ftdi.cpp)
-    set(cpp_headers   ftdi.hpp)
+# Shared library
+add_library(ftdipp1 SHARED ${cpp_sources})
 
-    # Find Boost
-    find_package(Boost)
-    if(Boost_FOUND)
-    set(FTDI_BUILD_CPP True PARENT_SCOPE)
-    message(STATUS "Building libftdi++")
+math(EXPR VERSION_FIXUP "${MAJOR_VERSION} + 1")    # Compatiblity with previous releases
+set_target_properties(ftdipp1 PROPERTIES VERSION ${VERSION_FIXUP}.${MINOR_VERSION}.0 SOVERSION 3)
 
-    # Targets
-    add_library(ftdipp SHARED ${cpp_sources})
+# Prevent clobbering each other during the build
+set_target_properties(ftdipp1 PROPERTIES CLEAN_DIRECT_OUTPUT 1)
 
-    math(EXPR VERSION_FIXUP "${MAJOR_VERSION} + 1")    # Compatiblity with previous releases
-    set_target_properties(ftdipp PROPERTIES VERSION ${VERSION_FIXUP}.${MINOR_VERSION}.0 SOVERSION 1)
+# Dependencies
+target_link_libraries(ftdipp1 ftdi1 ${LIBUSB_LIBRARIES} ${BOOST_LIBRARIES})
 
-    # Static library
-    add_library(ftdipp-static STATIC ${cpp_sources})
-    set_target_properties(ftdipp-static PROPERTIES OUTPUT_NAME "ftdipp")
+install ( TARGETS ftdipp1
+                                       RUNTIME DESTINATION bin
+                                       LIBRARY DESTINATION lib${LIB_SUFFIX}
+                                       ARCHIVE DESTINATION lib${LIB_SUFFIX}
+                               )
 
-    # Prevent clobbering each other during the build
-    set_target_properties(ftdipp PROPERTIES CLEAN_DIRECT_OUTPUT 1)
-    set_target_properties(ftdipp-static PROPERTIES CLEAN_DIRECT_OUTPUT 1)
+# Static library
+if ( STATICLIBS )
+       add_library(ftdipp1-static STATIC ${cpp_sources})
+       set_target_properties(ftdipp1-static PROPERTIES OUTPUT_NAME "ftdipp1")
+       set_target_properties(ftdipp1-static PROPERTIES CLEAN_DIRECT_OUTPUT 1)
 
-    # Dependencies
-    target_link_libraries(ftdipp ftdi ${LIBUSB_LIBRARIES} ${BOOST_LIBRARIES})
-
-    # Install
-    if(${UNIX})
-
-    install( TARGETS ftdipp
-                LIBRARY DESTINATION lib${LIB_SUFFIX}
-                COMPONENT sharedlibs
-                )
-
-    install( TARGETS ftdipp-static
-                ARCHIVE DESTINATION lib${LIB_SUFFIX}
-                COMPONENT staticlibs
-                )
-
-    install( FILES ${cpp_headers}
-                DESTINATION include/${PROJECT_NAME}
-                COMPONENT headers
-                )
-
-    endif(${UNIX})
-
-    if(${WIN32})
-
-    install( TARGETS ftdipp
-                DESTINATION bin
-                COMPONENT sharedlibs
-                )
-
-    install( TARGETS ftdipp-static
-                DESTINATION bin
-                COMPONENT staticlibs
-                )
-
-    install( FILES ${cpp_headers}
-                DESTINATION include/${PROJECT_NAME}
-                COMPONENT headers
-                )
-
-    endif(${WIN32})
-
-    else(Boost_FOUND)
-    message(STATUS "Boost not found, won't build libftdi++")
-    endif(Boost_FOUND)
-
-else(FTDIPP)
-
-    message(STATUS "Not building libftdi++")
-
-endif(FTDIPP)
+       install ( TARGETS ftdipp1-static
+                                               ARCHIVE DESTINATION lib${LIB_SUFFIX}
+                                               COMPONENT staticlibs
+                                       )
+endif ()
 
+install ( FILES ${cpp_headers}
+                                       DESTINATION include/${PROJECT_NAME}
+                                       COMPONENT headers
+                               )