CMAKE_MINIMUM_REQUIRED(VERSION 2.6) CMAKE_POLICY(SET CMP0012 NEW) # Prevent dereferencing of OFF/ON as variables SET(name "dali-core") PROJECT(${name}) SET(PKG_NAME ${name}) # API VERSION (Not DALi release version) SET(${name}_VERSION_MAJOR 0) SET(${name}_VERSION_MINOR 1) SET(${name}_VERSION_PATCH 1) SET(${name}_VERSION ${${name}_VERSION_MAJOR}.${${name}_VERSION_MINOR}.${${name}_VERSION_PATCH}) SET(DALI_VERSION ${${name}_VERSION} ) # Define options to CMake OPTION(ENABLE_EXPORTALL "Enable Export all symbols" OFF) OPTION(ENABLE_DEBUG "Enable Debug" OFF) OPTION(ENABLE_BACKTRACE "Enable Backtrace" OFF) OPTION(ENABLE_LOCK_BACKTRACE "Enable" OFF) OPTION(ENABLE_COVERAGE "Coverage" OFF) SET(GLES_VERSION 20 CACHE INTEGER "Gles Version") # Set up compiler definitions ADD_DEFINITIONS(-DPLATFORM_TIZEN -DDALI_COMPILATION) ADD_DEFINITIONS(-DDALI_GLES_VERSION=${GLES_VERSION}) ADD_DEFINITIONS(-DPIC -DSTDC_HEADERS) IF("${ARCH}" STREQUAL "arm") ADD_DEFINITIONS("-DTARGET") ENDIF("${ARCH}" STREQUAL "arm") IF( NOT ${ENABLE_EXPORTALL} AND NOT ${ENABLE_DEBUG} ) ADD_DEFINITIONS( "-fvisibility=hidden -DHIDE_DALI_INTERNALS" ) ENDIF( NOT ${ENABLE_EXPORTALL} AND NOT ${ENABLE_DEBUG} ) IF( ENABLE_DEBUG ) ADD_DEFINITIONS( "-DDEBUG_ENABLED" ) ENDIF( ENABLE_DEBUG ) IF( ENABLE_BACKTRACE OR ENABLE_LOCK_BACKTRACE ) ADD_DEFINITIONS( "-DBACKTRACE_ENABLED" ) ENDIF( ENABLE_BACKTRACE OR ENABLE_LOCK_BACKTRACE ) IF( ENABLE_LOCK_BACKTRACE ) ADD_DEFINITIONS( "-DLOCK_BACKTRACE_ENABLED" ) ENDIF( ENABLE_LOCK_BACKTRACE ) # Deployment folder should come from spec file or command line: SET( PREFIX ${CMAKE_INSTALL_PREFIX}) SET( EXEC_PREFIX ${CMAKE_INSTALL_PREFIX}) # from root/build/tizen, get back to root SET(ROOT_SRC_DIR ${CMAKE_SOURCE_DIR}/../..) # Requires the following variables to be setup # @PREFIX@ @EXEC_PREFIX@ @DALI_VERSION@ @LIBDIR@ @DEV_INCLUDE_PATH@ SET(INCLUDE_DIR $ENV{includedir}) SET(DEV_INCLUDE_PATH ${INCLUDE_DIR}) SET(LIB_DIR $ENV{libdir}) CONFIGURE_FILE( dali-core.pc.in dali-core.pc ) MESSAGE( STATUS "CMAKE_BUILD_TYPE: " ${CMAKE_BUILD_TYPE} ) if(CMAKE_BUILD_TYPE MATCHES Debug) MESSAGE("Setting variable: DEBUG_ENABLED") SET(DEBUG_ENABLED "1") ENDIF() # Set up compiler flags and warnings #ADD_COMPILE_OPTIONS( -std=c++11 -ggdb ) ADD_COMPILE_OPTIONS( -std=c++11 -gdwarf-4 ) ADD_COMPILE_OPTIONS( -Wnon-virtual-dtor -Woverloaded-virtual -Wold-style-cast ) ADD_COMPILE_OPTIONS( -Werror -Wall -Wextra -Wno-unused-parameter -Wfloat-equal ) IF( ENABLE_DEBUG ) ADD_COMPILE_OPTIONS( -O0 ) ELSE( ENABLE_DEBUG ) ADD_COMPILE_OPTIONS( -Os ) ENDIF( ENABLE_DEBUG ) IF( ENABLE_COVERAGE OR CXXFLAGS MATCHES --coverage) ADD_COMPILE_OPTIONS( --coverage ) SET(COVERAGE --coverage) ENDIF() INCLUDE_DIRECTORIES( ${ROOT_SRC_DIR} ) SET(SOURCE_DIR "${ROOT_SRC_DIR}/dali") SET(SOURCES "") # could use INCLUDE to get the source lists a different way; # would then need to specify a build folder somehow... ADD_SUBDIRECTORY( ${SOURCE_DIR}/internal dali/internal ) ADD_SUBDIRECTORY( ${SOURCE_DIR}/integration-api dali/integration-api ) ADD_SUBDIRECTORY( ${SOURCE_DIR}/public-api dali/public-api ) ADD_SUBDIRECTORY( ${SOURCE_DIR}/devel-api dali/devel-api ) ADD_LIBRARY( ${name} SHARED ${SOURCES} ) TARGET_LINK_LIBRARIES( ${name} -lpthread ${COVERAGE} ) SET_TARGET_PROPERTIES( ${name} PROPERTIES VERSION ${DALI_VERSION} SOVERSION ${${name}_VERSION_MAJOR} CLEAN_DIRECT_OUPUT 1 ) # Install the library so file and symlinks INSTALL( TARGETS ${name} DESTINATION ${PREFIX}/lib ) # macro for installing headers by replacing prefix. (TODO, investigate # if there is a CMAKE way of doing this automatically) MACRO(INSTALL_HEADERS_WITH_DIRECTORY HEADER_LIST STRIP_PREFIX REPLACE_PREFIX) GET_FILENAME_COMPONENT( SPREFIX ${STRIP_PREFIX} ABSOLUTE ) FOREACH(HEADER ${${HEADER_LIST}}) STRING(REGEX MATCH "(.*)[/]" DIR ${HEADER}) STRING(REPLACE ${SPREFIX} ${REPLACE_PREFIX} NEWDIR ${DIR}) INSTALL(FILES ${HEADER} DESTINATION ${PREFIX}/include/${NEWDIR}) ENDFOREACH(HEADER) ENDMACRO(INSTALL_HEADERS_WITH_DIRECTORY) # Install headers using lists defined by ADD_SUBDIRECTORY INSTALL_HEADERS_WITH_DIRECTORY(PUBLIC_API_HEADERS ${SOURCE_DIR} "dali") INSTALL_HEADERS_WITH_DIRECTORY(DEVEL_API_HEADERS ${SOURCE_DIR} "dali") INSTALL_HEADERS_WITH_DIRECTORY(INTEGRATION_API_HEADERS ${SOURCE_DIR} "dali") IF(UNIX) # Define custom rules for coverage SET(COVERAGE_DIR .cov) SET(COVERAGE_OUTPUT_DIR doc/coverage) # lcov prior to 1.10 doesn't have -rc option; this and subsequent version don't output # branch coverage. Determine the lcov version, and enable branch coverage accordingly. EXECUTE_PROCESS( COMMAND bash -c "lcov --version | cut -d' ' -f4" OUTPUT_VARIABLE LCOV_VERSION ) STRING( REPLACE "." ";" LCOV_VLIST ${LCOV_VERSION}) IF( NOT $ ) SET(LCOV_OPTS --rc lcov_branch_coverage=1) ENDIF() ADD_CUSTOM_TARGET( cov_data lcov ${LCOV_OPTS} --base-directory dali --directory . -c -o dali.info COMMAND lcov ${LCOV_OPTS} --remove dali.info \"*/dali-env/*\" \"/usr/include/*\" \"public-api/shader-effects/*\" \"*/image-actor*\" -o dali.info ) ADD_CUSTOM_TARGET( coverage genhtml ${LCOV_OPTS} -o ${COVERAGE_OUTPUT_DIR} dali.info DEPENDS cov_data ) ADD_CUSTOM_TARGET( reset_coverage @lcov -z --directory `pwd` ) # Define custom rule for distclean ADD_CUSTOM_TARGET( distclean @echo cleaning for source distribution ) ADD_CUSTOM_COMMAND( DEPENDS clean COMMENT "distribution clean" COMMAND find ARGS . -not -name config.cmake -and \( -name tester.c -or -name Testing -or -name CMakeFiles -or -name cmake.depends -or -name cmake.check_depends -or -name CMakeCache.txt -or -name cmake.check_cache -or -name *.cmake -or -name Makefile -or -name core -or -name core.* -or -name gmon.out -or -name install_manifest.txt -or -name *.pc -or -name *.gcov -or -name *.gcno -or -name *.gcda -or -name *~ \) | grep -v TC | xargs rm -rf TARGET distclean VERBATIM ) ENDIF(UNIX) MESSAGE( STATUS "Configuration:\n" ) MESSAGE( STATUS "Prefix: " ${PREFIX} ) MESSAGE( STATUS "Debug build: " ${ENABLE_DEBUG} ) MESSAGE( STATUS "Backtrace: " ${ENABLE_BACKTRACE} ) MESSAGE( STATUS "Scoped Lock backtrace: " ${ENABLE_LOCK_BACKTRACE} ) MESSAGE( STATUS "Coverage: " ${ENABLE_COVERAGE} )