EflMacros: major improvements towards usability.

Stick to one target per directory and remove prefix from variables,
makes it cleaner and easier to use.

Document variables used and use a more consistent name that matches
CMake properties.
This commit is contained in:
Gustavo Sverzut Barbieri 2017-01-20 12:58:21 -02:00 committed by Marcel Hollerbach
parent e1b98ca4f2
commit 3d5abc081f
4 changed files with 429 additions and 190 deletions

View File

@ -1,18 +1,18 @@
set(EINA_SAFETY_CHECKS 1) SET_GLOBAL(EINA_SAFETY_CHECKS 1)
set(EINA_DEBUG_THREADS OFF) SET_GLOBAL(EINA_DEBUG_THREADS OFF)
set(VALGRIND OFF) SET_GLOBAL(VALGRIND OFF)
if("${BUILD_PROFILE}" STREQUAL "dev") if("${BUILD_PROFILE}" STREQUAL "dev")
set(EINA_STRINGSHARE_USAGE ON) SET_GLOBAL(EINA_STRINGSHARE_USAGE ON)
set(CHECK_VALGRIND ON) SET_GLOBAL(CHECK_VALGRIND ON)
elseif("${BUILD_PROFILE}" STREQUAL "debug") elseif("${BUILD_PROFILE}" STREQUAL "debug")
set(EINA_DEBUG_MALLOC ON) SET_GLOBAL(EINA_DEBUG_MALLOC ON)
set(EINA_COW_MAGIC_ON ON) SET_GLOBAL(EINA_COW_MAGIC_ON ON)
set(EINA_DEFAULT_MEMPOOL ON) SET_GLOBAL(EINA_DEFAULT_MEMPOOL ON)
set(EINA_DEBUG_MALLOC ON) SET_GLOBAL(EINA_DEBUG_MALLOC ON)
set(EINA_DEBUG_THREADS ON) SET_GLOBAL(EINA_DEBUG_THREADS ON)
set(VALGRIND ON) SET_GLOBAL(VALGRIND ON)
elseif("${BUILD_PROFILE}" STREQUAL "release") elseif("${BUILD_PROFILE}" STREQUAL "release")
set(EINA_LOG_LEVEL_MAXIMUM 3) SET_GLOBAL(EINA_LOG_LEVEL_MAXIMUM 3)
endif() endif()
EFL_OPTION(EINA_MAGIC_DEBUG "magic debug of eina structure" ON) EFL_OPTION(EINA_MAGIC_DEBUG "magic debug of eina structure" ON)
@ -24,19 +24,19 @@ EFL_OPTION(EINA_BUILD_ONE_BIG "Build Eina's one-big mempool" "ON" CHOICE ON;OFF;
EFL_OPTION(EINA_BUILD_PASS_THROUGH "Build Eina's pass-through mempool" "STATIC" CHOICE ON;OFF;STATIC) EFL_OPTION(EINA_BUILD_PASS_THROUGH "Build Eina's pass-through mempool" "STATIC" CHOICE ON;OFF;STATIC)
if(EINA_BUILD_CHAINED STREQUAL "STATIC") if(EINA_BUILD_CHAINED STREQUAL "STATIC")
set(EINA_STATIC_BUILD_CHAINED_POOL 1) SET_GLOBAL(EINA_STATIC_BUILD_CHAINED_POOL 1)
endif() endif()
if(EINA_BUILD_ONE_BIG STREQUAL "STATIC") if(EINA_BUILD_ONE_BIG STREQUAL "STATIC")
set(EINA_STATIC_BUILD_ONE_BIG 1) SET_GLOBAL(EINA_STATIC_BUILD_ONE_BIG 1)
endif() endif()
if(EINA_BUILD_PASS_THROUGH STREQUAL "STATIC") if(EINA_BUILD_PASS_THROUGH STREQUAL "STATIC")
set(EINA_STATIC_BUILD_PASS_THROUGH 1) SET_GLOBAL(EINA_STATIC_BUILD_PASS_THROUGH 1)
endif() endif()
#check for symbols in pthread #check for symbols in pthread
#TODO Make the definitions depending on the platform #TODO Make the definitions depending on the platform
set(CMAKE_REQUIRED_FLAGS "${CMAKE_THREAD_LIBS_INIT}") SET_GLOBAL(CMAKE_REQUIRED_FLAGS "${CMAKE_THREAD_LIBS_INIT}")
set(CMAKE_REQUIRED_DEFINITIONS "-D_GNU_SOURCE=1") SET_GLOBAL(CMAKE_REQUIRED_DEFINITIONS "-D_GNU_SOURCE=1")
CHECK_SYMBOL_EXISTS(pthread_barrier_init pthread.h EINA_HAVE_PTHREAD_BARRIER) CHECK_SYMBOL_EXISTS(pthread_barrier_init pthread.h EINA_HAVE_PTHREAD_BARRIER)
CHECK_SYMBOL_EXISTS(pthread_attr_setaffinity_np pthread.h EINA_HAVE_PTHREAD_AFFINITY) CHECK_SYMBOL_EXISTS(pthread_attr_setaffinity_np pthread.h EINA_HAVE_PTHREAD_AFFINITY)
CHECK_SYMBOL_EXISTS(pthread_setname_np pthread.h EINA_HAVE_PTHREAD_SETNAME) CHECK_SYMBOL_EXISTS(pthread_setname_np pthread.h EINA_HAVE_PTHREAD_SETNAME)
@ -48,7 +48,7 @@ CHECK_INCLUDE_FILE(byteswap.h EINA_HAVE_BYTESWAP_H)
CHECK_INCLUDE_FILE(fnmatch.h EINA_HAVE_FNMATCH_H) CHECK_INCLUDE_FILE(fnmatch.h EINA_HAVE_FNMATCH_H)
#only enable log when fnmatch is there #only enable log when fnmatch is there
if (EINA_HAVE_FNMATCH_H) if (EINA_HAVE_FNMATCH_H)
set(EINA_ENABLE_LOG 1) SET_GLOBAL(EINA_ENABLE_LOG 1)
endif (EINA_HAVE_FNMATCH_H) endif (EINA_HAVE_FNMATCH_H)
CHECK_INCLUDE_FILE(dirent.h EINA_HAVE_DIRENT_H) CHECK_INCLUDE_FILE(dirent.h EINA_HAVE_DIRENT_H)
@ -65,9 +65,9 @@ CHECK_SYMBOL_EXISTS(clock_gettime time.h HAVE_CLOCK_GETTIME)
if(VALGRIND) if(VALGRIND)
pkg_check_modules(VG REQUIRED valgrind) pkg_check_modules(VG REQUIRED valgrind)
set(NVALGRIND OFF) SET_GLOBAL(NVALGRIND OFF)
else() else()
set(NVALGRIND ON) SET_GLOBAL(NVALGRIND ON)
endif() endif()
#Check if there is the alloca header #Check if there is the alloca header

View File

@ -119,20 +119,155 @@ function(EFL_FINALIZE)
add_custom_target(all-tests DEPENDS ${EFL_ALL_TESTS}) add_custom_target(all-tests DEPENDS ${EFL_ALL_TESTS})
endfunction() endfunction()
# EFL_FILES_TO_ABSOLUTE(Var Source_Dir Binary_Dir [file1 ... fileN])
#
# Convert list of files to absolute path. If not absolute, then
# check inside Source_Dir and if it fails assumes it's inside Binary_Dir
function(EFL_FILES_TO_ABSOLUTE _var _srcdir _bindir)
set(_lst "")
foreach(f ${ARGN})
if(EXISTS "${f}")
list(APPEND _lst "${f}")
elseif(EXISTS "${_srcdir}/${f}")
list(APPEND _lst "${_srcdir}/${f}")
else()
list(APPEND _lst "${_bindir}/${f}")
endif()
endforeach()
set(${_var} "${_lst}" PARENT_SCOPE)
endfunction()
# _EFL_LIB_PROCESS_MODULES_INTERNAL()
#
# Internal function to process modules of current EFL_LIB()
function(_EFL_LIB_PROCESS_MODULES_INTERNAL)
if(EXISTS ${EFL_MODULES_SOURCE_DIR}/CMakeLists.txt)
message(FATAL_ERROR "${EFL_MODULES_SOURCE_DIR}/CMakeLists.txt shouldn't exist. Modules are expected to be defined in their own directory.")
else()
file(GLOB modules RELATIVE ${EFL_MODULES_SOURCE_DIR} ${EFL_MODULES_SOURCE_DIR}/*)
foreach(module ${modules})
if(IS_DIRECTORY ${EFL_MODULES_SOURCE_DIR}/${module})
set(EFL_MODULE_SCOPE ${module})
include(${EFL_MODULES_SOURCE_DIR}/${module}/CMakeLists.txt OPTIONAL)
file(GLOB submodules RELATIVE ${EFL_MODULES_SOURCE_DIR}/${EFL_MODULE_SCOPE} ${EFL_MODULES_SOURCE_DIR}/${EFL_MODULE_SCOPE}/*)
foreach(submodule ${submodules})
if(IS_DIRECTORY ${EFL_MODULES_SOURCE_DIR}/${EFL_MODULE_SCOPE}/${submodule})
EFL_MODULE(${submodule})
endif()
unset(submodule)
unset(submodules)
endforeach()
else()
set(EFL_MODULE_SCOPE)
EFL_MODULE(${module})
endif()
unset(EFL_MODULE_SCOPE)
endforeach()
endif()
if(${EFL_LIB_CURRENT}_MODULES)
add_custom_target(${EFL_LIB_CURRENT}-modules DEPENDS ${${EFL_LIB_CURRENT}_MODULES})
endif()
endfunction()
# _EFL_LIB_PROCESS_BINS_INTERNAL()
#
# Internal function to process bins of current EFL_LIB()
function(_EFL_LIB_PROCESS_BINS_INTERNAL)
if(EXISTS ${EFL_BIN_SOURCE_DIR}/CMakeLists.txt)
EFL_BIN(${EFL_LIB_CURRENT})
else()
file(GLOB bins RELATIVE ${EFL_BIN_SOURCE_DIR} ${EFL_BIN_SOURCE_DIR}/*)
foreach(bin ${bins})
if(IS_DIRECTORY ${EFL_BIN_SOURCE_DIR}/${bin})
EFL_BIN(${bin})
endif()
endforeach()
endif()
if(${EFL_LIB_CURRENT}_BINS)
add_custom_target(${EFL_LIB_CURRENT}-bins DEPENDS ${${EFL_LIB_CURRENT}_BINS})
endif()
endfunction()
# _EFL_LIB_PROCESS_TESTS_INTERNAL()
#
# Internal function to process tests of current EFL_LIB()
function(_EFL_LIB_PROCESS_TESTS_INTERNAL)
if(EXISTS ${EFL_TESTS_SOURCE_DIR}/CMakeLists.txt)
EFL_TEST(${EFL_LIB_CURRENT})
else()
file(GLOB tests RELATIVE ${EFL_TESTS_SOURCE_DIR} ${EFL_TESTS_SOURCE_DIR}/*)
foreach(test ${tests})
if(IS_DIRECTORY ${EFL_TESTS_SOURCE_DIR}/${test})
EFL_TEST(${test})
endif()
endforeach()
endif()
if(${EFL_LIB_CURRENT}_TESTS)
add_custom_target(${EFL_LIB_CURRENT}-tests DEPENDS ${${EFL_LIB_CURRENT}_TESTS})
LIST_APPEND_GLOBAL(EFL_ALL_TESTS ${EFL_LIB_CURRENT}-tests)
endif()
endfunction()
# EFL_LIB(Name) # EFL_LIB(Name)
# #
# adds a library ${Name} automatically setting: # adds a library ${Name} automatically setting object/target
# - target_include_directories to ${Name}_INCLUDE_DIRECTORIES # properties based on script-modifiable variables:
# - target_include_directories(SYSTEM) to ${Name}_SYSTEM_INCLUDE_DIRECTORIES # - INCLUDE_DIRECTORIES: results in target_include_directories
# - OUTPUT_NAME to ${Name}_OUTPUT_NAME # - SYSTEM_INCLUDE_DIRECTORIES: results in target_include_directories(SYSTEM)
# - SOURCES to ${Name}_SOURCES # - OUTPUT_NAME
# - HEADER to ${Name}_HEADERS (to be installed) # - SOURCES
# - VERSION to ${Name}_VERSION (defaults to project version) # - PUBLIC_HEADERS
# - SOVERSION to ${Name}_SOURCES (defaults to project major version) # - VERSION (defaults to project version)
# - OBJECT_DEPENDS to ${Name}_DEPENDENCIES # - SOVERSION (defaults to project major version)
# - target_link_libraries() to ${Name}_LIBRARIES # - LIBRARY_TYPE: SHARED or STATIC, defaults to SHARED
# - target_compile_definitions() to ${Name}_DEFINITIONS # - OBJECT_DEPENDS: say this object depends on other files (ie: includes)
# - compile tests in ${Name}_TESTS using EFL_TEST() # - DEPENDENCIES: results in add_dependencies()
# - LIBRARIES: results in target_link_libraries()
# - DEFINITIONS: target_compile_definitions()
#
# Defines the following variables that can be used within the included files:
# - EFL_LIB_CURRENT to ${Name}
# - EFL_LIB_SOURCE_DIR to source dir of ${Name} libraries
# - EFL_LIB_BINARY_DIR to binary dir of ${Name} libraries
# - EFL_BIN_SOURCE_DIR to source dir of ${Name} executables
# - EFL_BIN_BINARY_DIR to binary dir of ${Name} executables
# - EFL_MODULES_SOURCE_DIR to source dir of ${Name} modules
# - EFL_MODULES_BINARY_DIR to binary dir of ${Name} modules
# - EFL_TESTS_SOURCE_DIR to source dir of ${Name} tests
# - EFL_TESTS_BINARY_DIR to binary dir of ${Name} tests
#
# Modules are processed like:
# - loop for directories in src/modules/${EFL_LIB_CURRENT}:
# - if a src/modules/${EFL_LIB_CURRENT}/${Module}/CMakeLists.txt
# use variables as documented in EFL_MODULE()
# - otherwise loop for scoped-modules in
# src/modules/${EFL_LIB_CURRENT}/${EFL_MODULE_SCOPE}/CMakeLists.txt
# and use variables as documented in EFL_MODULE()
#
# EFL_MODULE() will handle MODULE_TYPE=ON;OFF;STATIC, handling
# dependencies and installation in the proper path, considering
# ${EFL_MODULE_SCOPE} whenever it's set.
#
# Binaries and tests are processed similarly:
# - if src/bin/${EFL_LIB_CURRENT}/CMakeLists.txt exist, then use
# variables as documented in EFL_BIN() or EFL_TEST(). The target
# will be called ${EFL_LIB_CURRENT}-bin or ${EFL_LIB_CURRENT}-test
# and the test OUTPUT_NAME defaults to ${EFL_LIB_CURRENT}_suite.
# - otherwise loop for directories in src/bin/${EFL_LIB_CURRENT} and
# for each src/bin/${EFL_LIB_CURRENT}/${Entry}/CMakeLists.txt use
# variables as documented in EFL_BIN() or EFL_TEST(). Binaries
# must provide an unique name that will be used as both target and
# OUTPUT_NAME. Tests will generate targets
# ${EFL_LIB_CURRENT}-test-${Entry}, while OUTPUT_NAME is ${Entry}.
#
# NOTE: src/modules/${EFL_LIB_CURRENT}/CMakeLists.txt is not
# allowed as it makes no sense to have a single module named
# after the library.
# #
function(EFL_LIB _target) function(EFL_LIB _target)
set(EFL_LIB_CURRENT ${_target}) set(EFL_LIB_CURRENT ${_target})
@ -145,73 +280,67 @@ function(EFL_LIB _target)
set(EFL_TESTS_SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/src/tests/${_target}) set(EFL_TESTS_SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/src/tests/${_target})
set(EFL_TESTS_BINARY_DIR ${CMAKE_CURRENT_BINARY_DIR}/src/tests/${_target}) set(EFL_TESTS_BINARY_DIR ${CMAKE_CURRENT_BINARY_DIR}/src/tests/${_target})
set(${_target}_VERSION ${PROJECT_VERSION_MAJOR}.${PROJECT_VERSION_MINOR}.${PROJECT_VERSION_PATCH}) set(INCLUDE_DIRECTORIES)
set(${_target}_SOVERSION ${PROJECT_VERSION_MAJOR}) set(SYSTEM_INCLUDE_DIRECTORIES)
set(${_target}_LIBRARY_TYPE SHARED) set(OUTPUT_NAME)
set(SOURCES)
set(PUBLIC_HEADERS)
set(VERSION ${PROJECT_VERSION_MAJOR}.${PROJECT_VERSION_MINOR}.${PROJECT_VERSION_PATCH})
set(SOVERSION ${PROJECT_VERSION_MAJOR})
set(LIBRARY_TYPE SHARED)
set(OBJECT_DEPENDS)
set(DEPENDENCIES)
set(LIBRARIES)
set(DEFINITIONS)
include(${CMAKE_CURRENT_SOURCE_DIR}/cmake/config/${_target}.cmake OPTIONAL) include(${CMAKE_CURRENT_SOURCE_DIR}/cmake/config/${_target}.cmake OPTIONAL)
include(${EFL_LIB_SOURCE_DIR}/CMakeLists.txt OPTIONAL) include(${EFL_LIB_SOURCE_DIR}/CMakeLists.txt OPTIONAL)
include(${EFL_BIN_SOURCE_DIR}/CMakeLists.txt OPTIONAL) if(LIBRARY_TYPE STREQUAL SHARED AND NOT PUBLIC_HEADERS)
include(${EFL_MODULES_SOURCE_DIR}/CMakeLists.txt OPTIONAL) message(FATAL_ERROR "Shared libraries must install public headers!")
include(${EFL_TESTS_SOURCE_DIR}/CMakeLists.txt OPTIONAL) endif()
set(_headers "") EFL_FILES_TO_ABSOLUTE(_headers ${EFL_LIB_SOURCE_DIR} ${EFL_LIB_BINARY_DIR}
foreach(f ${${_target}_HEADERS}) ${PUBLIC_HEADERS})
if(EXISTS "${EFL_LIB_SOURCE_DIR}/${f}") EFL_FILES_TO_ABSOLUTE(_sources ${EFL_LIB_SOURCE_DIR} ${EFL_LIB_BINARY_DIR}
list(APPEND _headers "${EFL_LIB_SOURCE_DIR}/${f}") ${SOURCES})
else() EFL_FILES_TO_ABSOLUTE(_obj_deps ${EFL_LIB_SOURCE_DIR} ${EFL_LIB_BINARY_DIR}
list(APPEND _headers "${EFL_LIB_BINARY_DIR}/${f}") ${OBJECT_DEPENDS})
endif()
endforeach()
set(_sources "") add_library(${_target} ${LIBRARY_TYPE} ${_sources} ${_headers})
foreach(f ${${_target}_SOURCES})
if(EXISTS "${EFL_LIB_SOURCE_DIR}/${f}")
list(APPEND _sources "${EFL_LIB_SOURCE_DIR}/${f}")
else()
list(APPEND _sources "${EFL_LIB_BINARY_DIR}/${f}")
endif()
endforeach()
set(_deps "")
foreach(f ${${_target}_DEPENDENCIES})
if(EXISTS "${EFL_LIB_SOURCE_DIR}/${f}")
list(APPEND _deps "${EFL_LIB_SOURCE_DIR}/${f}")
else()
list(APPEND _deps "${EFL_LIB_BINARY_DIR}/${f}")
endif()
endforeach()
add_library(${_target} ${${_target}_LIBRARY_TYPE} ${_sources} ${_headers})
set_target_properties(${_target} PROPERTIES set_target_properties(${_target} PROPERTIES
FRAMEWORK TRUE FRAMEWORK TRUE
PUBLIC_HEADER "${_headers}" PUBLIC_HEADER "${_headers}"
OBJECT_DEPENDS "${_deps}") OBJECT_DEPENDS "${_obj_deps}")
if(${_target}_LIBRARIES) if(DEPENDENCIES)
target_link_libraries(${_target} ${${_target}_LIBRARIES}) add_dependencies(${_target} ${DEPENDENCIES})
endif()
if(LIBRARIES)
target_link_libraries(${_target} ${LIBRARIES})
endif() endif()
target_include_directories(${_target} PUBLIC target_include_directories(${_target} PUBLIC
${${_target}_INCLUDE_DIRECTORIES} ${INCLUDE_DIRECTORIES}
${EFL_LIB_SOURCE_DIR} ${EFL_LIB_SOURCE_DIR}
${EFL_LIB_BINARY_DIR}
) )
if(${_target}_SYSTEM_INCLUDE_DIRECTORIES) if(SYSTEM_INCLUDE_DIRECTORIES)
target_include_directories(${_target} SYSTEM PUBLIC ${${_target}_SYSTEM_INCLUDE_DIRECTORIES}) target_include_directories(${_target} SYSTEM PUBLIC ${SYSTEM_INCLUDE_DIRECTORIES})
endif() endif()
if(${_target}_DEFINITIONS) if(DEFINITIONS)
target_compile_definitions(${_target} PRIVATE ${${_target}_DEFINITIONS}) target_compile_definitions(${_target} PRIVATE ${DEFINITIONS})
endif() endif()
if(${_target}_OUTPUT_NAME) if(OUTPUT_NAME)
set_target_properties(${_target} PROPERTIES OUTPUT_NAME ${${_target}_OUTPUT_NAME}) set_target_properties(${_target} PROPERTIES OUTPUT_NAME ${OUTPUT_NAME})
endif() endif()
if(${_target}_VERSION AND ${_target}_SOVERSION) if(VERSION AND SOVERSION)
set_target_properties(${_target} PROPERTIES set_target_properties(${_target} PROPERTIES
VERSION ${${_target}_VERSION} VERSION ${VERSION}
SOVERSION ${${_target}_SOVERSION}) SOVERSION ${SOVERSION})
endif() endif()
install(TARGETS ${_target} install(TARGETS ${_target}
@ -220,40 +349,125 @@ function(EFL_LIB _target)
ARCHIVE DESTINATION lib ARCHIVE DESTINATION lib
LIBRARY DESTINATION lib) LIBRARY DESTINATION lib)
file(GLOB modules RELATIVE ${EFL_MODULES_SOURCE_DIR} ${EFL_MODULES_SOURCE_DIR}/*) # do not leak those into binaries, modules or tests
foreach(module ${modules}) unset(_sources)
if(IS_DIRECTORY ${EFL_MODULES_SOURCE_DIR}/${module}) unset(_headers)
set(EFL_MODULE_SCOPE ${module}) unset(_obj_deps)
unset(INCLUDE_DIRECTORIES)
unset(SYSTEM_INCLUDE_DIRECTORIES)
unset(OUTPUT_NAME)
unset(SOURCES)
unset(PUBLIC_HEADERS)
unset(VERSION)
unset(SOVERSION)
unset(LIBRARY_TYPE)
unset(OBJECT_DEPENDS)
unset(DEPENDENCIES)
unset(LIBRARIES)
unset(DEFINITIONS)
include(${EFL_MODULES_SOURCE_DIR}/${module}/CMakeLists.txt OPTIONAL) include(${EFL_BIN_SOURCE_DIR}/CMakeLists.txt OPTIONAL)
file(GLOB submodules RELATIVE ${EFL_MODULES_SOURCE_DIR}/${EFL_MODULE_SCOPE} ${EFL_MODULES_SOURCE_DIR}/${EFL_MODULE_SCOPE}/*) _EFL_LIB_PROCESS_BINS_INTERNAL()
foreach(submodule ${submodules}) _EFL_LIB_PROCESS_MODULES_INTERNAL()
if(IS_DIRECTORY ${EFL_MODULES_SOURCE_DIR}/${EFL_MODULE_SCOPE}/${submodule}) _EFL_LIB_PROCESS_TESTS_INTERNAL()
EFL_MODULE(${submodule})
endif()
unset(submodule)
unset(submodules)
endforeach()
else()
set(EFL_MODULE_SCOPE)
EFL_MODULE(${module})
endif()
unset(EFL_MODULE_SCOPE)
endforeach()
unset(module)
unset(modules)
foreach(t ${${_target}_TESTS})
EFL_TEST(${t})
endforeach()
unset(t)
add_custom_target(${_target}-tests DEPENDS ${${_target}_TESTS})
add_custom_target(${_target}-modules DEPENDS ${${_target}_MODULES})
LIST_APPEND_GLOBAL(EFL_ALL_LIBS ${_target}) LIST_APPEND_GLOBAL(EFL_ALL_LIBS ${_target})
LIST_APPEND_GLOBAL(EFL_ALL_TESTS ${_target}-tests)
endfunction() endfunction()
# EFL_BIN(Name)
#
# Adds a binary (executable) for ${EFL_LIB_CURRENT} using
# ${EFL_BIN_SOURCE_DIR} and ${EFL_BIN_BINARY_DIR}
#
# Settings:
# - INCLUDE_DIRECTORIES: results in target_include_directories
# - SYSTEM_INCLUDE_DIRECTORIES: results in target_include_directories(SYSTEM)
# - OUTPUT_NAME
# - SOURCES
# - OBJECT_DEPENDS: say this object depends on other files (ie: includes)
# - DEPENDENCIES: results in add_dependencies(), defaults to
# ${EFL_LIB_CURRENT}-modules
# - LIBRARIES: results in target_link_libraries()
# - DEFINITIONS: target_compile_definitions()
# - INSTALL_DIR: defaults to bin. If empty, won't install.
#
# NOTE: it's meant to be called by files included by EFL_LIB() or similar,
# otherwise you need to prepare the environment yourself.
function(EFL_BIN _binname)
set(INCLUDE_DIRECTORIES)
set(SYSTEM_INCLUDE_DIRECTORIES)
set(OUTPUT_NAME ${_binname})
set(SOURCES)
set(OBJECT_DEPENDS)
if(TARGET ${EFL_LIB_CURRENT}-modules)
set(DEPENDENCIES ${EFL_LIB_CURRENT}-modules)
else()
set(DEPENDENCIES)
endif()
set(LIBRARIES)
set(DEFINITIONS)
set(INSTALL ON)
set(INSTALL_DIR bin)
if(_binname STREQUAL ${EFL_LIB_CURRENT})
set(_binsrcdir "${EFL_BIN_SOURCE_DIR}")
set(_binbindir "${EFL_BIN_BINARY_DIR}")
set(_bintarget "${EFL_LIB_CURRENT}-bin") # otherwise target would exist
else()
set(_binsrcdir "${EFL_BIN_SOURCE_DIR}/${_binname}")
set(_binbindir "${EFL_BIN_BINARY_DIR}/${_binname}")
set(_bintarget "${_binname}")
endif()
include(${_binsrcdir}/CMakeLists.txt)
if(NOT SOURCES)
message(WARNING "${_binsrcdir}/CMakeLists.txt defines no SOURCES")
return()
endif()
if(PUBLIC_HEADERS)
message(WARNING "${_binsrcdir}/CMakeLists.txt should not define PUBLIC_HEADERS, it's not to be installed.")
endif()
EFL_FILES_TO_ABSOLUTE(_sources ${_binsrcdir} ${_binbindir} ${SOURCES})
EFL_FILES_TO_ABSOLUTE(_obj_deps ${_binsrcdir} ${_binbindir} ${OBJECT_DEPENDS})
add_executable(${_bintarget} ${_sources})
if(_obj_deps)
set_target_properties(${_bintarget} PROPERTIES
OBJECT_DEPENDS "${_obj_deps}")
endif()
if(DEPENDENCIES)
add_dependencies(${_bintarget} ${DEPENDENCIES})
endif()
target_include_directories(${_bintarget} PRIVATE
${_binrcdir}
${_binbindir}
${INCLUDE_DIRECTORIES})
if(SYSTEM_INCLUDE_DIRECTORIES)
target_include_directories(${_bintarget} SYSTEM PRIVATE
${SYSTEM_INCLUDE_DIRECTORIES})
endif()
target_link_libraries(${_bintarget}
${EFL_LIB_CURRENT}
${LIBRARIES})
if(DEFINITIONS)
target_compile_definitions(${_bintarget} PRIVATE ${DEFINITIONS})
endif()
if(OUTPUT_NAME)
set_target_properties(${_bintarget} PROPERTIES OUTPUT_NAME ${OUTPUT_NAME})
endif()
if(INSTALL_DIR)
install(TARGETS ${_bintarget} RUNTIME DESTINATION ${INSTALL_DIR})
endif()
endfunction()
# EFL_TEST(Name) # EFL_TEST(Name)
# #
@ -261,13 +475,15 @@ endfunction()
# ${EFL_TESTS_SOURCE_DIR} and ${EFL_TESTS_BINARY_DIR} # ${EFL_TESTS_SOURCE_DIR} and ${EFL_TESTS_BINARY_DIR}
# #
# Settings: # Settings:
# - include_directories to ${Name}_INCLUDE_DIRECTORIES # - INCLUDE_DIRECTORIES: results in target_include_directories
# - include_directories(SYSTEM) to ${Name}_SYSTEM_INCLUDE_DIRECTORIES # - SYSTEM_INCLUDE_DIRECTORIES: results in target_include_directories(SYSTEM)
# - OUTPUT_NAME to ${Name}_OUTPUT_NAME # - OUTPUT_NAME
# - SOURCES to ${Name}_SOURCES # - SOURCES
# - target_link_libraries() to ${Name}_LIBRARIES (${EFL_LIB_CURRENT} # - OBJECT_DEPENDS: say this object depends on other files (ie: includes)
# is automatic) # - DEPENDENCIES: results in add_dependencies(), defaults to
# - target_compile_definitions() to ${Name}_DEFINITIONS # ${EFL_LIB_CURRENT}-modules
# - LIBRARIES: results in target_link_libraries()
# - DEFINITIONS: target_compile_definitions()
# #
# NOTE: it's meant to be called by files included by EFL_LIB() or similar, # NOTE: it's meant to be called by files included by EFL_LIB() or similar,
# otherwise you need to prepare the environment yourself. # otherwise you need to prepare the environment yourself.
@ -276,56 +492,85 @@ function(EFL_TEST _testname)
message(STATUS "${EFL_LIB_CURRENT} test ${_testname} ignored since no 'check' library was found.") message(STATUS "${EFL_LIB_CURRENT} test ${_testname} ignored since no 'check' library was found.")
return() return()
endif() endif()
set(_sources "")
foreach(f ${${_testname}_SOURCES})
if(EXISTS "${EFL_TESTS_SOURCE_DIR}/${f}")
list(APPEND _sources "${EFL_TESTS_SOURCE_DIR}/${f}")
else()
list(APPEND _sources "${EFL_TESTS_BINARY_DIR}/${f}")
endif()
endforeach()
add_executable(${_testname} EXCLUDE_FROM_ALL ${_sources})
set(_deps "") set(INCLUDE_DIRECTORIES)
foreach(f ${${_testname}_DEPENDENCIES}) set(SYSTEM_INCLUDE_DIRECTORIES)
if(EXISTS "${EFL_TESTS_SOURCE_DIR}/${f}") set(OUTPUT_NAME ${_testname})
list(APPEND _deps "${EFL_TESTS_SOURCE_DIR}/${f}") set(SOURCES)
else() set(OBJECT_DEPENDS)
list(APPEND _deps "${EFL_TESTS_BINARY_DIR}/${f}") if(TARGET ${EFL_LIB_CURRENT}-modules)
endif() set(DEPENDENCIES ${EFL_LIB_CURRENT}-modules)
endforeach() else()
add_dependencies(${_testname} ${EFL_LIB_CURRENT}-modules) set(DEPENDENCIES)
set_target_properties(${_testname} PROPERTIES OBJECT_DEPENDS "${_deps}") endif()
set(LIBRARIES)
set(DEFINITIONS)
target_include_directories(${_testname} PRIVATE if(_testname STREQUAL ${EFL_LIB_CURRENT})
${EFL_TESTS_SOURCE_DIR} set(_testsrcdir "${EFL_TESTS_SOURCE_DIR}")
${EFL_TESTS_BINARY_DIR} set(_testbindir "${EFL_TESTS_BINARY_DIR}")
${${_testname}_INCLUDE_DIRECTORIES}) set(_testtarget "${EFL_LIB_CURRENT}-test") # otherwise target would exist
target_include_directories(${_testname} SYSTEM PRIVATE set(OUTPUT_NAME "${EFL_LIB_CURRENT}_suite") # backward compatible
${${_testname}_SYSTEM_INCLUDE_DIRECTORIES} else()
${CHECK_INCLUDE_DIRS}) set(_testsrcdir "${EFL_TESTS_SOURCE_DIR}/${_testname}")
target_link_libraries(${_testname} set(_testbindir "${EFL_TESTS_BINARY_DIR}/${_testname}")
${EFL_LIB_CURRENT} set(_testtarget "${EFL_LIB_CURRENT}-test-${_testname}")
${${_testname}_LIBRARIES}
${CHECK_LIBRARIES})
target_compile_definitions(${_testname} PRIVATE
"-DTESTS_SRC_DIR=\"${EFL_TESTS_SOURCE_DIR}\""
"-DTESTS_BUILD_DIR=\"${EFL_TESTS_BINARY_DIR}\""
"-DTESTS_WD=\"${PROJECT_BINARY_DIR}\""
"-DPACKAGE_BUILD_DIR=\"1\""
${${_testname}_DEFINITIONS}
)
if(${_testname}_OUTPUT_NAME)
set_target_properties(${_testname} PROPERTIES OUTPUT_NAME ${${_testname}_OUTPUT_NAME})
endif() endif()
set_target_properties(${_testname} PROPERTIES include(${_testsrcdir}/CMakeLists.txt)
LIBRARY_OUTPUT_DIRECTORY "${EFL_TESTS_BINARY_DIR}"
RUNTIME_OUTPUT_DIRECTORY "${EFL_TESTS_BINARY_DIR}")
add_test(NAME ${_testname} COMMAND ${_testname}) if(NOT SOURCES)
message(WARNING "${_testsrcdir}/CMakeLists.txt defines no SOURCES")
return()
endif()
if(PUBLIC_HEADERS)
message(WARNING "${_testsrcdir}/CMakeLists.txt should not define PUBLIC_HEADERS, it's not to be installed.")
endif()
EFL_FILES_TO_ABSOLUTE(_sources ${_testsrcdir} ${_testbindir} ${SOURCES})
EFL_FILES_TO_ABSOLUTE(_obj_deps ${_testsrcdir} ${_testbindir} ${OBJECT_DEPENDS})
add_executable(${_testtarget} EXCLUDE_FROM_ALL ${_sources})
if(_obj_deps)
set_target_properties(${_testtarget} PROPERTIES
OBJECT_DEPENDS "${_obj_deps}")
endif()
if(DEPENDENCIES)
add_dependencies(${_testtarget} ${DEPENDENCIES})
endif()
target_include_directories(${_testtarget} PRIVATE
${_testrcdir}
${_testbindir}
${INCLUDE_DIRECTORIES})
target_include_directories(${_testtarget} SYSTEM PRIVATE
${SYSTEM_INCLUDE_DIRECTORIES}
${CHECK_INCLUDE_DIRS})
target_link_libraries(${_testtarget}
${EFL_LIB_CURRENT}
${LIBRARIES}
${CHECK_LIBRARIES})
target_compile_definitions(${_testtarget} PRIVATE
"-DTESTS_SRC_DIR=\"${_testrcdir}\""
"-DTESTS_BUILD_DIR=\"${_testbindir}\""
"-DTESTS_WD=\"${PROJECT_BINARY_DIR}\""
"-DPACKAGE_BUILD_DIR=\"1\""
${DEFINITIONS}
)
if(OUTPUT_NAME)
set_target_properties(${_testtarget} PROPERTIES OUTPUT_NAME ${OUTPUT_NAME})
endif()
set_target_properties(${_testtarget} PROPERTIES
LIBRARY_OUTPUT_DIRECTORY "${_testbindir}"
RUNTIME_OUTPUT_DIRECTORY "${_testbindir}")
add_test(NAME ${_testname} COMMAND ${_testtarget})
LIST_APPEND_GLOBAL(${EFL_LIB_CURRENT}_TESTS ${_testtarget})
endfunction() endfunction()
# EFL_MODULE(Name) # EFL_MODULE(Name)
@ -337,27 +582,34 @@ endfunction()
# #
# To keep it simple to use, user is only expected to define variables: # To keep it simple to use, user is only expected to define variables:
# - SOURCES # - SOURCES
# - DEPENDENCIES # - OBJECT_DEPENDS
# - LIBRARIES # - LIBRARIES
# - INCLUDE_DIRECTORIES # - INCLUDE_DIRECTORIES
# - SYSTEM_INCLUDE_DIRECTORIES # - SYSTEM_INCLUDE_DIRECTORIES
# - DEFINITIONS # - DEFINITIONS
# - MODULE_TYPE: one of ON;OFF;STATIC, defaults to ON
# - INSTALL_DIR: defaults to
# lib/${EFL_LIB_CURRENT}/modules/${EFL_MODULE_SCOPE}/${Name}/v-${PROJECT_VERSION_MAJOR}.${PROJECT_VERSION_MINOR}/.
# If empty, won't install.
# #
# NOTE: since the file will be included it shouldn't mess with global variables! # NOTE: since the file will be included it shouldn't mess with global variables!
function(EFL_MODULE _modname) function(EFL_MODULE _modname)
if(EFL_MODULE_SCOPE) if(EFL_MODULE_SCOPE)
set(_modsrcdir ${EFL_MODULES_SOURCE_DIR}/${EFL_MODULE_SCOPE}/${_modname}) set(_modsrcdir ${EFL_MODULES_SOURCE_DIR}/${EFL_MODULE_SCOPE}/${_modname})
set(_modoutdir lib/${EFL_LIB_CURRENT}/modules/${EFL_MODULE_SCOPE}/${_modname}/v-${PROJECT_VERSION_MAJOR}.${PROJECT_VERSION_MINOR})
else() else()
set(_modsrcdir ${EFL_MODULES_SOURCE_DIR}/${_modname}) set(_modsrcdir ${EFL_MODULES_SOURCE_DIR}/${_modname})
set(_modoutdir lib/${EFL_LIB_CURRENT}/modules/${_modname}/v-${PROJECT_VERSION_MAJOR}.${PROJECT_VERSION_MINOR})
endif() endif()
set(SOURCES) set(SOURCES)
set(DEPENDENCIES) set(OBJECT_DEPENDS)
set(LIBRARIES) set(LIBRARIES)
set(INCLUDE_DIRECTORIES) set(INCLUDE_DIRECTORIES)
set(SYSTEM_INCLUDE_DIRECTORIES) set(SYSTEM_INCLUDE_DIRECTORIES)
set(DEFINITIONS) set(DEFINITIONS)
set(MODULE_TYPE "ON") set(MODULE_TYPE "ON")
set(INSTALL_DIR ${_modoutdir})
include(${_modsrcdir}/CMakeLists.txt) include(${_modsrcdir}/CMakeLists.txt)
@ -365,19 +617,19 @@ function(EFL_MODULE _modname)
message(WARNING "${_modsrcdir}/CMakeLists.txt defines no SOURCES") message(WARNING "${_modsrcdir}/CMakeLists.txt defines no SOURCES")
return() return()
endif() endif()
if(PUBLIC_HEADERS)
message(WARNING "${_modsrcdir}/CMakeLists.txt should not define PUBLIC_HEADERS, it's not to be installed.")
endif()
if(EFL_MODULE_SCOPE) if(EFL_MODULE_SCOPE)
set(_modbindir ${EFL_MODULES_BINARY_DIR}/${EFL_MODULE_SCOPE}/${_modname}) set(_modbindir ${EFL_MODULES_BINARY_DIR}/${EFL_MODULE_SCOPE}/${_modname})
set(_modtarget ${EFL_LIB_CURRENT}-module-${EFL_MODULE_SCOPE}-${_modname}) set(_modtarget ${EFL_LIB_CURRENT}-module-${EFL_MODULE_SCOPE}-${_modname})
set(_modoutdir ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}/${EFL_LIB_CURRENT}/modules/${EFL_MODULE_SCOPE}/${_modname}/v-${PROJECT_VERSION_MAJOR}.${PROJECT_VERSION_MINOR})
else() else()
set(_modbindir ${EFL_MODULES_BINARY_DIR}/${_modname}) set(_modbindir ${EFL_MODULES_BINARY_DIR}/${_modname})
set(_modtarget ${EFL_LIB_CURRENT}-module-${_modname}) set(_modtarget ${EFL_LIB_CURRENT}-module-${_modname})
set(_modoutdir ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}/${EFL_LIB_CURRENT}/modules/${_modname}/v-${PROJECT_VERSION_MAJOR}.${PROJECT_VERSION_MINOR})
endif() endif()
if("${MODULE_TYPE}" STREQUAL "OFF") if("${MODULE_TYPE}" STREQUAL "OFF")
message(WARNING "${_modsrcdir} disabled")
return() return()
elseif("${MODULE_TYPE}" STREQUAL "STATIC") elseif("${MODULE_TYPE}" STREQUAL "STATIC")
set(_modtype STATIC) set(_modtype STATIC)
@ -385,27 +637,12 @@ function(EFL_MODULE _modname)
set(_modtype MODULE) set(_modtype MODULE)
endif() endif()
set(_sources "") EFL_FILES_TO_ABSOLUTE(_sources ${_modsrcdir} ${_modbindir} ${SOURCES})
foreach(f ${SOURCES}) EFL_FILES_TO_ABSOLUTE(_obj_deps ${_modsrcdir} ${_modbindir} ${OBJECT_DEPENDS})
if(EXISTS "${_modsrcdir}/${f}")
list(APPEND _sources "${_modsrcdir}/${f}")
else()
list(APPEND _sources "${_modbindir}/${f}")
endif()
endforeach()
set(_deps "")
foreach(f ${DEPENDENCIES})
if(EXISTS "${_modsrcdir}/${f}")
list(APPEND _deps "${_modsrcdir}/${f}")
else()
list(APPEND _deps "${_modbindir}/${f}")
endif()
endforeach()
add_library(${_modtarget} ${_modtype} ${_sources}) add_library(${_modtarget} ${_modtype} ${_sources})
set_target_properties(${_modtarget} PROPERTIES set_target_properties(${_modtarget} PROPERTIES
OBJECT_DEPENDS "${_deps}" OBJECT_DEPENDS "${_obj_deps}"
PREFIX "" PREFIX ""
OUTPUT_NAME "module") OUTPUT_NAME "module")
@ -436,5 +673,8 @@ function(EFL_MODULE _modname)
else() else()
target_link_libraries(${_modtarget} ${EFL_LIB_CURRENT}) target_link_libraries(${_modtarget} ${EFL_LIB_CURRENT})
LIST_APPEND_GLOBAL(${EFL_LIB_CURRENT}_MODULES ${_modtarget}) LIST_APPEND_GLOBAL(${EFL_LIB_CURRENT}_MODULES ${_modtarget})
if(INSTALL_DIR)
install(TARGETS ${_modtarget} LIBRARY DESTINATION "${INSTALL_DIR}")
endif()
endif() endif()
endfunction() endfunction()

View File

@ -1,11 +1,12 @@
set(eina_INCLUDE_DIRECTORIES ${VG_INCLUDE_DIRS}) set(INCLUDE_DIRECTORIES
${VG_INCLUDE_DIRS})
set(eina_LIBRARIES set(LIBRARIES
${VG_LIBRARIES} ${VG_LIBRARIES}
pthread) pthread)
set(eina_HEADERS set(PUBLIC_HEADERS
Eina.h Eina.h
eina_accessor.h eina_accessor.h
eina_alloca.h eina_alloca.h
@ -81,7 +82,7 @@ set(eina_HEADERS
eina_xattr.h eina_xattr.h
) )
LIST(APPEND eina_SOURCES set(SOURCES
eina_abi.c eina_abi.c
eina_accessor.c eina_accessor.c
eina_array.c eina_array.c

View File

@ -1,8 +1,6 @@
set(eina_TESTS eina_suite) set(LIBRARIES m)
set(eina_suite_LIBRARIES m) set(SOURCES
set(eina_suite_SOURCES
eina_suite.c eina_suite.c
eina_suite.h eina_suite.h
eina_suite.x eina_suite.x
@ -60,7 +58,7 @@ set(eina_suite_SOURCES
eina_test_xattr.c eina_test_xattr.c
) )
set(eina_suite_DEPENDS set(DEPENDS
eina_test_stringshare.c eina_test_stringshare.c
eina_test_util.c eina_test_util.c
) )