##
-## 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
project(pulseview)
+#===============================================================================
+#= User Options
+#-------------------------------------------------------------------------------
+
+option(ENABLE_TESTS "Enable unit tests" FALSE)
+
+#===============================================================================
+#= Dependencies
+#-------------------------------------------------------------------------------
+
find_package(PkgConfig)
pkg_check_modules(PKGDEPS REQUIRED
libsigrokdecode>=0.1.0
# 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)
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
)
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
)
set(pulseview_FORMS
- about.ui
+ pv/about.ui
)
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})
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
# 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)