cmake: make out-of-source build work with readonly source dir

This commit is contained in:
Michael Gehring 2008-06-22 03:00:42 +02:00
parent 000e69729a
commit e1dd1344fc
2 changed files with 28 additions and 21 deletions

View File

@ -8,6 +8,7 @@ ENDIF()
INCLUDE(awesomeConfig.cmake) INCLUDE(awesomeConfig.cmake)
INCLUDE_DIRECTORIES(${CMAKE_CURRENT_SOURCE_DIR} INCLUDE_DIRECTORIES(${CMAKE_CURRENT_SOURCE_DIR}
${CMAKE_CURRENT_BINARY_DIR}
${AWESOME_REQUIRED_INCLUDE_DIRS} ${AWESOME_REQUIRED_INCLUDE_DIRS}
${AWESOME_OPTIONAL_INCLUDE_DIRS}) ${AWESOME_OPTIONAL_INCLUDE_DIRS})
@ -15,7 +16,7 @@ SET(AWE_LUA_FILES
${CMAKE_CURRENT_SOURCE_DIR}/lib/tabulous.lua ${CMAKE_CURRENT_SOURCE_DIR}/lib/tabulous.lua
${CMAKE_CURRENT_SOURCE_DIR}/lib/awful.lua) ${CMAKE_CURRENT_SOURCE_DIR}/lib/awful.lua)
SET(AWE_CONF_FILES ${CMAKE_CURRENT_SOURCE_DIR}/awesomerc.lua) SET(AWE_CONF_FILES ${CMAKE_CURRENT_BINARY_DIR}/awesomerc.lua)
SET(AWE_ICON_DIR ${CMAKE_CURRENT_SOURCE_DIR}/icons) SET(AWE_ICON_DIR ${CMAKE_CURRENT_SOURCE_DIR}/icons)
@ -81,9 +82,6 @@ SET(AWE_MAN_SRCS
${CMAKE_CURRENT_SOURCE_DIR}/awesome-client.1.txt ${CMAKE_CURRENT_SOURCE_DIR}/awesome-client.1.txt
${CMAKE_CURRENT_SOURCE_DIR}/awesomerc.5.txt) ${CMAKE_CURRENT_SOURCE_DIR}/awesomerc.5.txt)
SET(AWE_LUADOC_FILE ${CMAKE_CURRENT_SOURCE_DIR}/apidocgen.txt)
ADD_EXECUTABLE(${PROJECT_AWE_NAME} ${AWE_SRCS}) ADD_EXECUTABLE(${PROJECT_AWE_NAME} ${AWE_SRCS})
ADD_EXECUTABLE(${PROJECT_AWECLIENT_NAME} ${AWE_CLIENT_SRCS}) ADD_EXECUTABLE(${PROJECT_AWECLIENT_NAME} ${AWE_CLIENT_SRCS})
@ -98,24 +96,24 @@ TARGET_LINK_LIBRARIES(${PROJECT_AWECLIENT_NAME}
# {{{ Generated headers # {{{ Generated headers
FILE(GLOB LAYOUTGEN_DEPS ${CMAKE_CURRENT_SOURCE_DIR}/layouts/*.h) FILE(GLOB LAYOUTGEN_DEPS ${CMAKE_CURRENT_SOURCE_DIR}/layouts/*.h)
ADD_CUSTOM_COMMAND(COMMAND ${CMAKE_CURRENT_SOURCE_DIR}/build-utils/layoutgen.sh ADD_CUSTOM_COMMAND(COMMAND ${CMAKE_CURRENT_SOURCE_DIR}/build-utils/layoutgen.sh
ARGS > ${CMAKE_CURRENT_SOURCE_DIR}/layoutgen.h ARGS > ${CMAKE_CURRENT_BINARY_DIR}/layoutgen.h
OUTPUT ${CMAKE_CURRENT_SOURCE_DIR}/layoutgen.h OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/layoutgen.h
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
DEPENDS ${LAYOUTGEN_DEPS} DEPENDS ${LAYOUTGEN_DEPS}
COMMENT "Generating layoutgen.h." COMMENT "Generating layoutgen.h."
VERBATIM) VERBATIM)
ADD_CUSTOM_COMMAND(COMMAND ${CMAKE_CURRENT_SOURCE_DIR}/build-utils/widgetgen.sh ADD_CUSTOM_COMMAND(COMMAND ${CMAKE_CURRENT_SOURCE_DIR}/build-utils/widgetgen.sh
ARGS > ${CMAKE_CURRENT_SOURCE_DIR}/widgetgen.h ARGS > ${CMAKE_CURRENT_BINARY_DIR}/widgetgen.h
OUTPUT ${CMAKE_CURRENT_SOURCE_DIR}/widgetgen.h OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/widgetgen.h
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/widget.h DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/widget.h
COMMENT "Generating widgetgen.h." COMMENT "Generating widgetgen.h."
VERBATIM) VERBATIM)
ADD_CUSTOM_TARGET(generated_headers ADD_CUSTOM_TARGET(generated_headers
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/widgetgen.h DEPENDS ${CMAKE_CURRENT_BINARY_DIR}/widgetgen.h
${CMAKE_CURRENT_SOURCE_DIR}/layoutgen.h) ${CMAKE_CURRENT_BINARY_DIR}/layoutgen.h)
ADD_DEPENDENCIES(${PROJECT_AWE_NAME} generated_headers) ADD_DEPENDENCIES(${PROJECT_AWE_NAME} generated_headers)
# }}} # }}}
@ -124,6 +122,8 @@ ADD_DEPENDENCIES(${PROJECT_AWE_NAME} generated_headers)
IF(GENERATE_MANPAGES) IF(GENERATE_MANPAGES)
# {{{ Lua API documentation. # {{{ Lua API documentation.
SET(LUADOC_FILE ${CMAKE_CURRENT_BINARY_DIR}/apidocgen.txt)
MACRO(a_file_match infile regex result_var) MACRO(a_file_match infile regex result_var)
IF(CMAKE_MAJOR_VERSION EQUAL 2 AND CMAKE_MINOR_VERSION LESS 6) IF(CMAKE_MAJOR_VERSION EQUAL 2 AND CMAKE_MINOR_VERSION LESS 6)
# cmake < 2.6 doesn't know FILE(STRINGS ...) # cmake < 2.6 doesn't know FILE(STRINGS ...)
@ -156,28 +156,31 @@ IF(GENERATE_MANPAGES)
# luadoc target # luadoc target
ADD_CUSTOM_COMMAND(COMMAND ${CAT_EXECUTABLE} ${LUA_APIDOC_SRCS} ADD_CUSTOM_COMMAND(COMMAND ${CAT_EXECUTABLE} ${LUA_APIDOC_SRCS}
| ${LUA_EXECUTABL} ${CMAKE_CURRENT_SOURCE_DIR}/build-utils/gendoc.lua | ${LUA_EXECUTABL} ${CMAKE_CURRENT_SOURCE_DIR}/build-utils/gendoc.lua
> ${AWE_LUADOC_FILE} > ${LUADOC_FILE}
OUTPUT ${AWE_LUADOC_FILE} OUTPUT ${LUADOC_FILE}
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
DEPENDS ${LUA_APIDOC_SRCS} DEPENDS ${LUA_APIDOC_SRCS}
COMMENT "Generating Lua API documentation." COMMENT "Generating Lua API documentation."
VERBATIM) VERBATIM)
ADD_CUSTOM_TARGET(luadoc DEPENDS ${AWE_LUADOC_FILE}) ADD_CUSTOM_TARGET(luadoc DEPENDS ${LUADOC_FILE})
# }}} # }}}
FOREACH(txtfile ${AWE_MAN_SRCS}) FOREACH(txtfile ${AWE_MAN_SRCS})
STRING(REGEX REPLACE ".txt\$" ".xml" xmlfile ${txtfile}) STRING(REGEX REPLACE ".txt\$" ".xml" xmlfile ${txtfile})
STRING(REPLACE ${CMAKE_CURRENT_SOURCE_DIR}
${CMAKE_CURRENT_BINARY_DIR} xmlfile ${xmlfile})
STRING(REGEX REPLACE ".xml\$" ".gz" gzfile ${xmlfile}) STRING(REGEX REPLACE ".xml\$" ".gz" gzfile ${xmlfile})
STRING(REGEX REPLACE ".gz\$" "" manfile ${gzfile}) STRING(REGEX REPLACE ".gz\$" "" manfile ${gzfile})
STRING(REPLACE ${CMAKE_CURRENT_SOURCE_DIR}
${CMAKE_CURRENT_BINARY_DIR} gzfile ${gzfile})
# TODO: This is still not 100% right. Actually only # TODO: This is still not 100% right. Actually only
# awesomerc.5.xml should depend on ${AWE_LUADOC_FILE}. # awesomerc.5.xml should depend on ${LUADOC_FILE}.
ADD_CUSTOM_COMMAND(COMMAND ${ASCIIDOC_EXECUTABLE} -d manpage -b docbook -o ${xmlfile} ${txtfile} ADD_CUSTOM_COMMAND(COMMAND ${CAT_EXECUTABLE} ${txtfile}
| ${ASCIIDOC_EXECUTABLE} -d manpage -b docbook -o ${xmlfile} -
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
OUTPUT ${xmlfile} OUTPUT ${xmlfile}
DEPENDS ${txtfile} ${AWE_LUADOC_FILE}) DEPENDS ${txtfile} ${LUADOC_FILE}
VERBATIM)
ADD_CUSTOM_COMMAND(COMMAND ${XMLTO_EXECUTABLE} man ${xmlfile} ADD_CUSTOM_COMMAND(COMMAND ${XMLTO_EXECUTABLE} man ${xmlfile}
OUTPUT ${manfile} OUTPUT ${manfile}
DEPENDS ${xmlfile}) DEPENDS ${xmlfile})
@ -190,7 +193,7 @@ IF(GENERATE_MANPAGES)
SET(MAN_FILES ${MAN_FILES} ${gzfile}) SET(MAN_FILES ${MAN_FILES} ${gzfile})
# figure out in what section to install to rom filename # figure out in what section to install to from filename
STRING(REGEX REPLACE "^.*\\.([0-9])\\.gz\$" "\\1" section ${gzfile}) STRING(REGEX REPLACE "^.*\\.([0-9])\\.gz\$" "\\1" section ${gzfile})
SET(AWE_MAN${section}_FILES ${AWE_MAN${section}_FILES} ${gzfile}) SET(AWE_MAN${section}_FILES ${AWE_MAN${section}_FILES} ${gzfile})
ENDFOREACH() ENDFOREACH()
@ -199,9 +202,13 @@ IF(GENERATE_MANPAGES)
ENDIF() ENDIF()
# }}} # }}}
# {{{ Doxygen
IF(DOXYGEN_EXECUTABLE) IF(DOXYGEN_EXECUTABLE)
ADD_CUSTOM_TARGET(doc ${DOXYGEN_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/awesome.doxygen) ADD_CUSTOM_TARGET(doc
COMMAND ${DOXYGEN_EXECUTABLE} awesome.doxygen
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR})
ENDIF() ENDIF()
# }}}
# {{{ Installation. # {{{ Installation.
INSTALL(TARGETS ${PROJECT_AWE_NAME} ${PROJECT_AWECLIENT_NAME} RUNTIME DESTINATION bin) INSTALL(TARGETS ${PROJECT_AWE_NAME} ${PROJECT_AWECLIENT_NAME} RUNTIME DESTINATION bin)

View File

@ -189,7 +189,7 @@ MACRO(a_configure_file file)
STRING(REGEX REPLACE ".in\$" "" outfile ${file}) STRING(REGEX REPLACE ".in\$" "" outfile ${file})
MESSAGE(STATUS "Configuring ${outfile}") MESSAGE(STATUS "Configuring ${outfile}")
CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/${file} CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/${file}
${CMAKE_CURRENT_SOURCE_DIR}/${outfile} ${CMAKE_CURRENT_BINARY_DIR}/${outfile}
ESCAPE_QUOTE ESCAPE_QUOTE
@ONLY) @ONLY)
ENDMACRO() ENDMACRO()