]> sigrok.org Git - pulseview.git/blobdiff - CMakeLists.txt
Offer unit tests with a cmake option
[pulseview.git] / CMakeLists.txt
index c17e77f46ed81f7c45d6812bccdf2f554bd886ec..512ad18765509a90f6e950caa471c2f70095f742 100644 (file)
@@ -1,7 +1,8 @@
 ##
-## This file is part of PulseView.
+## This file is part of the PulseView project.
 ##
 ## Copyright (C) 2012 Joel Holdsworth <joel@airwebreathe.org.uk>
+## Copyright (C) 2012 Alexandru Gagniuc <mr.nuke.me@gmail.com>
 ##
 ## This program is free software: you can redistribute it and/or modify
 ## it under the terms of the GNU General Public License as published by
@@ -22,6 +23,16 @@ include(FindPkgConfig)
 
 project(pulseview)
 
+#===============================================================================
+#= User Options
+#-------------------------------------------------------------------------------
+
+option(ENABLE_TESTS "Enable unit tests" FALSE)
+
+#===============================================================================
+#= Dependencies
+#-------------------------------------------------------------------------------
+
 find_package(PkgConfig)
 pkg_check_modules(PKGDEPS REQUIRED
        libsigrokdecode>=0.1.0
@@ -30,7 +41,7 @@ pkg_check_modules(PKGDEPS REQUIRED
 
 # On Windows/MinGW we explicitly point cmake to the Boost directory.
 if(WIN32)
-set(BOOST_ROOT /usr/local)
+       set(BOOST_ROOT /usr/local)
 endif(WIN32)
 
 find_package(Qt4 REQUIRED)
@@ -38,18 +49,22 @@ find_package(Boost 1.46 COMPONENTS unit_test_framework REQUIRED)
 
 set(VERSION 0.1.0)
 
+#===============================================================================
+#= Sources
+#-------------------------------------------------------------------------------
+
 set(pulseview_SOURCES
-       about.cpp
-       datasnapshot.cpp
-       logicdata.cpp
-       logicdatasnapshot.cpp
-       logicsignal.cpp
        main.cpp
-       mainwindow.cpp
-       samplingbar.cpp
-       signaldata.cpp
-       sigsession.cpp
-       signal.cpp
+       pv/about.cpp
+       pv/datasnapshot.cpp
+       pv/logicdata.cpp
+       pv/logicdatasnapshot.cpp
+       pv/logicsignal.cpp
+       pv/mainwindow.cpp
+       pv/samplingbar.cpp
+       pv/signaldata.cpp
+       pv/sigsession.cpp
+       pv/signal.cpp
        pv/view/header.cpp
        pv/view/ruler.cpp
        pv/view/view.cpp
@@ -57,10 +72,10 @@ set(pulseview_SOURCES
 )
 
 set(pulseview_HEADERS
-       about.h
-       mainwindow.h
-       samplingbar.h
-       sigsession.h
+       pv/about.h
+       pv/mainwindow.h
+       pv/samplingbar.h
+       pv/sigsession.h
        pv/view/header.h
        pv/view/ruler.h
        pv/view/view.h
@@ -68,7 +83,7 @@ set(pulseview_HEADERS
 )
 
 set(pulseview_FORMS
-       about.ui
+       pv/about.ui
 )
 
 set(pulseview_RESOURCES
@@ -76,10 +91,10 @@ set(pulseview_RESOURCES
 )
 
 set(pulseview_TEST_SOURCES
+       pv/datasnapshot.cpp
+       pv/logicdatasnapshot.cpp
        test/logicdatasnapshot.cpp
        test/test.cpp
-       datasnapshot.cpp
-       logicdatasnapshot.cpp
 )
 
 qt4_wrap_cpp(pulseview_HEADERS_MOC ${pulseview_HEADERS})
@@ -88,35 +103,49 @@ qt4_add_resources(pulseview_RESOURCES_RCC ${pulseview_RESOURCES})
 
 include(${QT_USE_FILE})
 
+#===============================================================================
+#= Global Definitions
+#-------------------------------------------------------------------------------
+
 add_definitions(${QT_DEFINITIONS})
 add_definitions(-DAPP_VERSION="${VERSION}")
 
+#===============================================================================
+#= Global Include Directories
+#-------------------------------------------------------------------------------
+
 # On Windows/MinGW we need PKGDEPS_STATIC_INCLUDE_DIRS.
 if(WIN32)
-include_directories(
-       ${include_directories}
-       ${Boost_INCLUDE_DIRS}
-       ${PKGDEPS_STATIC_INCLUDE_DIRS}
-)
+       include_directories(
+               ${include_directories}
+               ${CMAKE_CURRENT_BINARY_DIR}
+               ${Boost_INCLUDE_DIRS}
+               ${PKGDEPS_STATIC_INCLUDE_DIRS}
+       )
 else(WIN32)
-include_directories(
-       ${include_directories}
-       ${Boost_INCLUDE_DIRS}
-       ${PKGDEPS_INCLUDE_DIRS}
-)
+       include_directories(
+               ${include_directories}
+               ${CMAKE_CURRENT_BINARY_DIR}
+               ${Boost_INCLUDE_DIRS}
+               ${PKGDEPS_INCLUDE_DIRS}
+       )
 endif(WIN32)
 
+#===============================================================================
+#= Linker Configuration
+#-------------------------------------------------------------------------------
+
 # On Windows/MinGW we need PKGDEPS_STATIC_LIBRARY_DIRS.
 if(WIN32)
-link_directories(
-       ${Boost_LIBRARY_DIRS}
-       ${PKGDEPS_STATIC_LIBRARY_DIRS}
-)
+       link_directories(
+               ${Boost_LIBRARY_DIRS}
+               ${PKGDEPS_STATIC_LIBRARY_DIRS}
+       )
 else(WIN32)
-link_directories(
-       ${Boost_LIBRARY_DIRS}
-       ${PKGDEPS_LIBRARY_DIRS}
-)
+       link_directories(
+               ${Boost_LIBRARY_DIRS}
+               ${PKGDEPS_LIBRARY_DIRS}
+       )
 endif(WIN32)
 
 add_executable(pulseview
@@ -128,45 +157,53 @@ add_executable(pulseview
 
 # On Windows/MinGW we need PKGDEPS_STATIC_LIBRARIES.
 if(WIN32)
-target_link_libraries(pulseview
-       ${Boost_LIBRARIES}
-       ${PKGDEPS_STATIC_LIBRARIES}
-       ${QT_LIBRARIES}
-)
+       target_link_libraries(pulseview
+               ${Boost_LIBRARIES}
+               ${PKGDEPS_STATIC_LIBRARIES}
+               ${QT_LIBRARIES}
+       )
 else(WIN32)
-target_link_libraries(pulseview
-       ${Boost_LIBRARIES}
-       ${PKGDEPS_LIBRARIES}
-       ${QT_LIBRARIES}
-)
+       target_link_libraries(pulseview
+               ${Boost_LIBRARIES}
+               ${PKGDEPS_LIBRARIES}
+               ${QT_LIBRARIES}
+       )
 endif(WIN32)
 
-if(ENABLE_TESTS)
-
-add_definitions(-DBOOST_TEST_DYN_LINK)
+#===============================================================================
+#= Installation
+#-------------------------------------------------------------------------------
 
-add_executable(pulseview-test
-       ${pulseview_TEST_SOURCES}
-)
+install(PROGRAMS pulseview DESTINATION bin/)
 
-# On Windows/MinGW we need PKGDEPS_STATIC_LIBRARIES.
-if(WIN32)
-target_link_libraries(pulseview-test
-       ${Boost_LIBRARIES}
-       ${PKGDEPS_STATIC_LIBRARIES}
-       ${QT_LIBRARIES}
-)
-else(WIN32)
-target_link_libraries(pulseview-test
-       ${Boost_LIBRARIES}
-       ${PKGDEPS_LIBRARIES}
-       ${QT_LIBRARIES}
-)
-endif(WIN32)
+#===============================================================================
+#= Tests
+#-------------------------------------------------------------------------------
 
-enable_testing()
-add_test(test ${CMAKE_CURRENT_BINARY_DIR}/pulseview-test)
+if(ENABLE_TESTS)
 
-install(PROGRAMS pulseview DESTINATION bin/)
+       add_definitions(-DBOOST_TEST_DYN_LINK)
+
+       add_executable(pulseview-test
+               ${pulseview_TEST_SOURCES}
+       )
+
+       # On Windows/MinGW we need PKGDEPS_STATIC_LIBRARIES.
+       if(WIN32)
+               target_link_libraries(pulseview-test
+                       ${Boost_LIBRARIES}
+                       ${PKGDEPS_STATIC_LIBRARIES}
+                       ${QT_LIBRARIES}
+               )
+       else(WIN32)
+               target_link_libraries(pulseview-test
+                       ${Boost_LIBRARIES}
+                       ${PKGDEPS_LIBRARIES}
+                       ${QT_LIBRARIES}
+               )
+       endif(WIN32)
+
+       enable_testing()
+       add_test(test ${CMAKE_CURRENT_BINARY_DIR}/pulseview-test)
 
 endif(ENABLE_TESTS)