summaryrefslogtreecommitdiff
path: root/cmake
diff options
context:
space:
mode:
authorGustavo Sverzut Barbieri <barbieri@profusion.mobi>2017-01-20 13:53:56 -0200
committerMarcel Hollerbach <marcel-hollerbach@t-online.de>2017-01-23 18:23:40 +0100
commitd9815a6837f1e06def0641da285863f87729683f (patch)
tree7ff20525c2876382bef6247108f823b0f3c82459 /cmake
parent3d5abc081f59dda9887dbacc8e8ab24c96d5ee65 (diff)
downloadefl-d9815a6837f1e06def0641da285863f87729683f.tar.gz
CMake: move eina binaries to single dir, add helper macros.
For one-source directories, be smart and just define SOURCES to that, will reduce the number of too-simplistic CMakeLists.txt in our tree. This also fixes problems with libraries, they should be private, not public. So specify both kinds as different variables.
Diffstat (limited to 'cmake')
-rw-r--r--cmake/helpers/EflMacros.cmake85
1 files changed, 63 insertions, 22 deletions
diff --git a/cmake/helpers/EflMacros.cmake b/cmake/helpers/EflMacros.cmake
index 4665a03a80..1c2c752107 100644
--- a/cmake/helpers/EflMacros.cmake
+++ b/cmake/helpers/EflMacros.cmake
@@ -137,6 +137,49 @@ function(EFL_FILES_TO_ABSOLUTE _var _srcdir _bindir)
set(${_var} "${_lst}" PARENT_SCOPE)
endfunction()
+# _EFL_INCLUDE_OR_DETECT(Name Source_Dir)
+#
+# Internal macro that will include(${Source_Dir}/CMakeLists.txt) if
+# that exists, otherwise will check if there is a single source file,
+# in that case it will automatically define SOURCES to that (including
+# extras such as headers and .eo)
+#
+# Name is only used to print out messages when it's auto-detected.
+macro(_EFL_INCLUDE_OR_DETECT _name _srcdir)
+ if(EXISTS ${_srcdir}/CMakeLists.txt)
+ include(${_srcdir}/CMakeLists.txt)
+ else()
+ # doc says it's not recommended because it can't know if more files
+ # were added, but we're doing this explicitly to handle one file.
+ file(GLOB _autodetect_files RELATIVE ${_srcdir}
+ ${_srcdir}/*.c
+ ${_srcdir}/*.h
+ ${_srcdir}/*.hh
+ ${_srcdir}/*.cxx
+ ${_srcdir}/*.cpp
+ ${_srcdir}/*.eo
+ )
+ list(LENGTH _autodetect_files _autodetect_files_count)
+ if(_autodetect_files_count GREATER 1)
+ message(WARNING "${_name}: ${_srcdir} contains no CMakeLists.txt and contains more than one source file. Don't know what to do, then ignored.")
+ elseif(_autodetect_files_count EQUAL 1)
+ file(GLOB SOURCES RELATIVE ${_srcdir}
+ ${_srcdir}/*.c
+ ${_srcdir}/*.h
+ ${_srcdir}/*.hh
+ ${_srcdir}/*.cxx
+ ${_srcdir}/*.cpp
+ ${_srcdir}/*.eo
+ )
+ message(STATUS "${_name} auto-detected as: ${SOURCES}")
+ else()
+ message(STATUS "${_name} contains no auto-detectable sources.")
+ endif()
+ unset(_autodetect_files_count)
+ unset(_autodetect_files)
+ endif()
+endmacro()
+
# _EFL_LIB_PROCESS_MODULES_INTERNAL()
#
# Internal function to process modules of current EFL_LIB()
@@ -149,8 +192,6 @@ function(_EFL_LIB_PROCESS_MODULES_INTERNAL)
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})
@@ -227,7 +268,8 @@ endfunction()
# - LIBRARY_TYPE: SHARED or STATIC, defaults to SHARED
# - OBJECT_DEPENDS: say this object depends on other files (ie: includes)
# - DEPENDENCIES: results in add_dependencies()
-# - LIBRARIES: results in target_link_libraries()
+# - LIBRARIES: results in target_link_libraries(LINK_PRIVATE)
+# - PUBLIC_LIBRARIES: results in target_link_libraries(LINK_PUBLIC)
# - DEFINITIONS: target_compile_definitions()
#
# Defines the following variables that can be used within the included files:
@@ -291,6 +333,7 @@ function(EFL_LIB _target)
set(OBJECT_DEPENDS)
set(DEPENDENCIES)
set(LIBRARIES)
+ set(PUBLIC_LIBRARIES)
set(DEFINITIONS)
include(${CMAKE_CURRENT_SOURCE_DIR}/cmake/config/${_target}.cmake OPTIONAL)
@@ -317,7 +360,10 @@ function(EFL_LIB _target)
endif()
if(LIBRARIES)
- target_link_libraries(${_target} ${LIBRARIES})
+ target_link_libraries(${_target} LINK_PRIVATE ${LIBRARIES})
+ endif()
+ if(PUBLIC_LIBRARIES)
+ target_link_libraries(${_target} LINK_PRIVATE ${PUBLIC_LIBRARIES})
endif()
target_include_directories(${_target} PUBLIC
@@ -364,10 +410,9 @@ function(EFL_LIB _target)
unset(OBJECT_DEPENDS)
unset(DEPENDENCIES)
unset(LIBRARIES)
+ unset(PUBLIC_LIBRARIES)
unset(DEFINITIONS)
- include(${EFL_BIN_SOURCE_DIR}/CMakeLists.txt OPTIONAL)
-
_EFL_LIB_PROCESS_BINS_INTERNAL()
_EFL_LIB_PROCESS_MODULES_INTERNAL()
_EFL_LIB_PROCESS_TESTS_INTERNAL()
@@ -420,7 +465,7 @@ function(EFL_BIN _binname)
set(_bintarget "${_binname}")
endif()
- include(${_binsrcdir}/CMakeLists.txt)
+ _EFL_INCLUDE_OR_DETECT("Binary ${_bintarget}" ${_binsrcdir})
if(NOT SOURCES)
message(WARNING "${_binsrcdir}/CMakeLists.txt defines no SOURCES")
@@ -452,7 +497,7 @@ function(EFL_BIN _binname)
target_include_directories(${_bintarget} SYSTEM PRIVATE
${SYSTEM_INCLUDE_DIRECTORIES})
endif()
- target_link_libraries(${_bintarget}
+ target_link_libraries(${_bintarget} LINK_PRIVATE
${EFL_LIB_CURRENT}
${LIBRARIES})
@@ -517,7 +562,7 @@ function(EFL_TEST _testname)
set(_testtarget "${EFL_LIB_CURRENT}-test-${_testname}")
endif()
- include(${_testsrcdir}/CMakeLists.txt)
+ _EFL_INCLUDE_OR_DETECT("Test ${_testtarget}" ${_testsrcdir})
if(NOT SOURCES)
message(WARNING "${_testsrcdir}/CMakeLists.txt defines no SOURCES")
@@ -548,7 +593,7 @@ function(EFL_TEST _testname)
target_include_directories(${_testtarget} SYSTEM PRIVATE
${SYSTEM_INCLUDE_DIRECTORIES}
${CHECK_INCLUDE_DIRS})
- target_link_libraries(${_testtarget}
+ target_link_libraries(${_testtarget} LINK_PRIVATE
${EFL_LIB_CURRENT}
${LIBRARIES}
${CHECK_LIBRARIES})
@@ -597,9 +642,13 @@ function(EFL_MODULE _modname)
if(EFL_MODULE_SCOPE)
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})
+ set(_modbindir ${EFL_MODULES_BINARY_DIR}/${EFL_MODULE_SCOPE}/${_modname})
+ set(_modtarget ${EFL_LIB_CURRENT}-module-${EFL_MODULE_SCOPE}-${_modname})
else()
set(_modsrcdir ${EFL_MODULES_SOURCE_DIR}/${_modname})
set(_modoutdir lib/${EFL_LIB_CURRENT}/modules/${_modname}/v-${PROJECT_VERSION_MAJOR}.${PROJECT_VERSION_MINOR})
+ set(_modbindir ${EFL_MODULES_BINARY_DIR}/${_modname})
+ set(_modtarget ${EFL_LIB_CURRENT}-module-${_modname})
endif()
set(SOURCES)
@@ -611,7 +660,7 @@ function(EFL_MODULE _modname)
set(MODULE_TYPE "ON")
set(INSTALL_DIR ${_modoutdir})
- include(${_modsrcdir}/CMakeLists.txt)
+ _EFL_INCLUDE_OR_DETECT("Module ${_modtarget}" ${_modsrcdir})
if(NOT SOURCES)
message(WARNING "${_modsrcdir}/CMakeLists.txt defines no SOURCES")
@@ -621,14 +670,6 @@ function(EFL_MODULE _modname)
message(WARNING "${_modsrcdir}/CMakeLists.txt should not define PUBLIC_HEADERS, it's not to be installed.")
endif()
- if(EFL_MODULE_SCOPE)
- set(_modbindir ${EFL_MODULES_BINARY_DIR}/${EFL_MODULE_SCOPE}/${_modname})
- set(_modtarget ${EFL_LIB_CURRENT}-module-${EFL_MODULE_SCOPE}-${_modname})
- else()
- set(_modbindir ${EFL_MODULES_BINARY_DIR}/${_modname})
- set(_modtarget ${EFL_LIB_CURRENT}-module-${_modname})
- endif()
-
if("${MODULE_TYPE}" STREQUAL "OFF")
return()
elseif("${MODULE_TYPE}" STREQUAL "STATIC")
@@ -652,7 +693,7 @@ function(EFL_MODULE _modname)
${INCLUDE_DIRECTORIES})
target_include_directories(${_modtarget} SYSTEM PUBLIC
${SYSTEM_INCLUDE_DIRECTORIES})
- target_link_libraries(${_modtarget} ${LIBRARIES})
+ target_link_libraries(${_modtarget} LINK_PRIVATE ${LIBRARIES})
target_compile_definitions(${_modtarget} PRIVATE ${DEFINITIONS})
@@ -662,7 +703,7 @@ function(EFL_MODULE _modname)
RUNTIME_OUTPUT_DIRECTORY "${_modoutdir}")
if("${MODULE_TYPE}" STREQUAL "STATIC")
- target_link_libraries(${EFL_LIB_CURRENT} ${_modtarget})
+ target_link_libraries(${EFL_LIB_CURRENT} LINK_PRIVATE ${_modtarget})
target_include_directories(${_modtarget} PRIVATE
${EFL_LIB_SOURCE_DIR}
${EFL_LIB_BINARY_DIR})
@@ -671,7 +712,7 @@ function(EFL_MODULE _modname)
LIST_APPEND_GLOBAL(${EFL_LIB_CURRENT}_STATIC_MODULES ${_modtarget})
else()
- target_link_libraries(${_modtarget} ${EFL_LIB_CURRENT})
+ target_link_libraries(${_modtarget} LINK_PRIVATE ${EFL_LIB_CURRENT})
LIST_APPEND_GLOBAL(${EFL_LIB_CURRENT}_MODULES ${_modtarget})
if(INSTALL_DIR)
install(TARGETS ${_modtarget} LIBRARY DESTINATION "${INSTALL_DIR}")