mirror of
https://github.com/awesomeWM/awesome
synced 2024-11-16 07:47:22 +01:00
63b712e247
This meta-lua script takes the "raw" awesomerc.lua and turn it into the final file and generate a documentation page from its parsed content. It support * Turn {{{ into markdown categories * Turn top level comments into documentation * Add custom documentation sections * Parse the code to add links for each API calls This helps generate a good entry point for new users wanting to understand the content of rc.lua without searching the API by hand. Over time, this will also become the basis of the documentation. If `rc.lua` is separated into several files, this will be easy to fix this script. It could even do the separation itself from a monolitic file using the already implemented {{{ parser.
381 lines
11 KiB
CMake
381 lines
11 KiB
CMake
set(PROJECT_AWE_NAME awesome)
|
|
|
|
# If ${SOURCE_DIR} is a git repository VERSION is set to
|
|
# `git describe` later.
|
|
set(VERSION devel)
|
|
|
|
set(CODENAME "The Fox")
|
|
|
|
project(${PROJECT_AWE_NAME} C)
|
|
|
|
set(CMAKE_BUILD_TYPE RELEASE)
|
|
|
|
option(WITH_DBUS "build with D-BUS" ON)
|
|
option(GENERATE_MANPAGES "generate manpages" ON)
|
|
option(COMPRESS_MANPAGES "compress manpages" ON)
|
|
option(GENERATE_DOC "generate API documentation" ON)
|
|
|
|
# {{{ Endianness
|
|
include(TestBigEndian)
|
|
TEST_BIG_ENDIAN(AWESOME_IS_BIG_ENDIAN)
|
|
# }}}
|
|
|
|
# {{{ Find external utilities
|
|
macro(a_find_program var prg req)
|
|
set(required ${req})
|
|
find_program(${var} ${prg})
|
|
if(NOT ${var})
|
|
message(STATUS "${prg} not found.")
|
|
if(required)
|
|
message(FATAL_ERROR "${prg} is required to build awesome")
|
|
endif()
|
|
else()
|
|
message(STATUS "${prg} -> ${${var}}")
|
|
endif()
|
|
endmacro()
|
|
|
|
a_find_program(GIT_EXECUTABLE git FALSE)
|
|
# programs needed for man pages
|
|
a_find_program(ASCIIDOC_EXECUTABLE asciidoc FALSE)
|
|
a_find_program(XMLTO_EXECUTABLE xmlto FALSE)
|
|
a_find_program(GZIP_EXECUTABLE gzip FALSE)
|
|
# lua documentation
|
|
a_find_program(LDOC_EXECUTABLE ldoc FALSE)
|
|
if(NOT LDOC_EXECUTABLE)
|
|
a_find_program(LDOC_EXECUTABLE ldoc.lua FALSE)
|
|
endif()
|
|
# theme graphics
|
|
a_find_program(CONVERT_EXECUTABLE convert TRUE)
|
|
# pkg-config
|
|
include(FindPkgConfig)
|
|
# lua
|
|
include(FindLua)
|
|
# }}}
|
|
|
|
# {{{ Check if documentation can be build
|
|
if(GENERATE_MANPAGES)
|
|
if(NOT ASCIIDOC_EXECUTABLE OR NOT XMLTO_EXECUTABLE OR (COMPRESS_MANPAGES AND NOT GZIP_EXECUTABLE))
|
|
if(NOT ASCIIDOC_EXECUTABLE)
|
|
SET(missing "asciidoc")
|
|
endif()
|
|
if(NOT XMLTO_EXECUTABLE)
|
|
SET(missing ${missing} " xmlto")
|
|
endif()
|
|
if(COMPRESS_MANPAGES AND NOT GZIP_EXECUTABLE)
|
|
SET(missing ${missing} " gzip")
|
|
endif()
|
|
|
|
message(STATUS "Not generating manpages. Missing: " ${missing})
|
|
set(GENERATE_MANPAGES OFF)
|
|
endif()
|
|
endif()
|
|
|
|
if(GENERATE_DOC)
|
|
if(NOT LDOC_EXECUTABLE)
|
|
message(STATUS "Not generating API documentation. Missing: ldoc")
|
|
set(GENERATE_DOC OFF)
|
|
endif()
|
|
endif()
|
|
# }}}
|
|
|
|
# {{{ Version stamp
|
|
if(OVERRIDE_VERSION)
|
|
set(VERSION ${OVERRIDE_VERSION})
|
|
elseif(EXISTS ${SOURCE_DIR}/.git/HEAD AND GIT_EXECUTABLE)
|
|
# get current version
|
|
execute_process(
|
|
COMMAND ${GIT_EXECUTABLE} describe --dirty
|
|
WORKING_DIRECTORY ${SOURCE_DIR}
|
|
OUTPUT_VARIABLE VERSION
|
|
OUTPUT_STRIP_TRAILING_WHITESPACE)
|
|
# File the build-utils/git-version-stamp.sh script will look into.
|
|
set(VERSION_STAMP_FILE ${BUILD_DIR}/.version_stamp)
|
|
file(WRITE ${VERSION_STAMP_FILE} ${VERSION})
|
|
# create a version_stamp target later
|
|
set(BUILD_FROM_GIT TRUE)
|
|
elseif( EXISTS ${SOURCE_DIR}/.version_stamp )
|
|
# get version from version stamp
|
|
file(READ ${SOURCE_DIR}/.version_stamp VERSION)
|
|
endif()
|
|
# }}}
|
|
|
|
# {{{ Required libraries
|
|
#
|
|
# this sets up:
|
|
# AWESOME_REQUIRED_LDFLAGS
|
|
# AWESOME_REQUIRED_INCLUDE_DIRS
|
|
|
|
# Use pkgconfig to get most of the libraries
|
|
pkg_check_modules(AWESOME_COMMON_REQUIRED REQUIRED
|
|
xcb>=1.6)
|
|
|
|
pkg_check_modules(AWESOME_REQUIRED REQUIRED
|
|
glib-2.0
|
|
gdk-pixbuf-2.0
|
|
cairo
|
|
x11
|
|
x11-xcb
|
|
xcb-cursor
|
|
xcb-randr
|
|
xcb-xtest
|
|
xcb-xinerama
|
|
xcb-shape
|
|
xcb-util>=0.3.8
|
|
xcb-keysyms>=0.3.4
|
|
xcb-icccm>=0.3.8
|
|
# NOTE: it's not clear what version is required, but 1.10 works at least.
|
|
# See https://github.com/awesomeWM/awesome/pull/149#issuecomment-94208356.
|
|
xcb-xkb
|
|
xkbcommon
|
|
xkbcommon-x11
|
|
cairo-xcb
|
|
libstartup-notification-1.0>=0.10
|
|
xproto>=7.0.15
|
|
libxdg-basedir>=1.0.0)
|
|
|
|
if(NOT AWESOME_REQUIRED_FOUND OR NOT AWESOME_COMMON_REQUIRED_FOUND)
|
|
message(FATAL_ERROR)
|
|
endif()
|
|
|
|
# On Mac OS X, the executable of Awesome has to be linked against libiconv
|
|
# explicitly. Unfortunately, libiconv doesn't have its pkg-config file,
|
|
# and CMake doesn't provide a module for looking up the library. Thus, we
|
|
# have to do everything for ourselves...
|
|
if(APPLE)
|
|
if(NOT DEFINED AWESOME_ICONV_SEARCH_PATHS)
|
|
set(AWESOME_ICONV_SEARCH_PATHS /opt/local /opt /usr/local /usr)
|
|
endif()
|
|
|
|
if(NOT DEFINED AWESOME_ICONV_INCLUDE_DIR)
|
|
find_path(AWESOME_ICONV_INCLUDE_DIR
|
|
iconv.h
|
|
PATHS ${AWESOME_ICONV_SEARCH_PATHS}
|
|
PATH_SUFFIXES include
|
|
NO_CMAKE_SYSTEM_PATH)
|
|
endif()
|
|
|
|
if(NOT DEFINED AWESOME_ICONV_LIBRARY_PATH)
|
|
get_filename_component(AWESOME_ICONV_BASE_DIRECTORY ${AWESOME_ICONV_INCLUDE_DIR} DIRECTORY)
|
|
find_library(AWESOME_ICONV_LIBRARY_PATH
|
|
NAMES iconv
|
|
HINTS ${AWESOME_ICONV_BASE_DIRECTORY}
|
|
PATH_SUFFIXES lib)
|
|
endif()
|
|
|
|
if(NOT DEFINED AWESOME_ICONV_LIBRARY_PATH)
|
|
message(FATAL_ERROR "Looking for iconv library - not found.")
|
|
else()
|
|
message(STATUS "Looking for iconv library - found: ${AWESOME_ICONV_LIBRARY_PATH}")
|
|
endif()
|
|
|
|
set(AWESOME_REQUIRED_LDFLAGS
|
|
${AWESOME_REQUIRED_LDFLAGS} ${AWESOME_ICONV_LIBRARY_PATH})
|
|
set(AWESOME_REQUIRED_INCLUDE_DIRS
|
|
${AWESOME_REQUIRED_INCLUDE_DIRS} ${AWESOME_ICONV_INCLUDE_DIR})
|
|
endif(APPLE)
|
|
|
|
macro(a_find_library variable library)
|
|
find_library(${variable} ${library})
|
|
if(NOT ${variable})
|
|
message(FATAL_ERROR ${library} " library not found.")
|
|
endif()
|
|
endmacro()
|
|
|
|
# Check for backtrace_symbols()
|
|
include(CheckFunctionExists)
|
|
check_function_exists(backtrace_symbols HAS_EXECINFO)
|
|
if(NOT HAS_EXECINFO)
|
|
find_library(LIB_EXECINFO execinfo)
|
|
if(LIB_EXECINFO)
|
|
set(HAS_EXECINFO 1)
|
|
set(AWESOME_REQUIRED_LDFLAGS
|
|
${AWESOME_REQUIRED_LDFLAGS}
|
|
${LIB_EXECINFO})
|
|
endif()
|
|
endif()
|
|
if(HAS_EXECINFO)
|
|
message(STATUS "checking for execinfo -- found")
|
|
else()
|
|
message(STATUS "checking for execinfo -- not found")
|
|
endif()
|
|
|
|
# Do we need libm for round()?
|
|
check_function_exists(round HAS_ROUND_WITHOUT_LIBM)
|
|
if(NOT HAS_ROUND_WITHOUT_LIBM)
|
|
SET(CMAKE_REQUIRED_LIBRARIES ${CMAKE_REQUIRED_LIBRARIES} m)
|
|
set(AWESOME_REQUIRED_LDFLAGS ${AWESOME_REQUIRED_LDFLAGS} m)
|
|
check_function_exists(round HAS_ROUND_WITH_LIBM)
|
|
if(NOT HAS_ROUND_WITH_LIBM)
|
|
message(FATAL_ERROR "Did not find round()")
|
|
endif()
|
|
message(STATUS "checking for round -- in libm")
|
|
else()
|
|
message(STATUS "checking for round -- builtin")
|
|
endif()
|
|
|
|
set(AWESOME_REQUIRED_LDFLAGS
|
|
${AWESOME_COMMON_REQUIRED_LDFLAGS}
|
|
${AWESOME_REQUIRED_LDFLAGS}
|
|
${LUA_LIBRARIES}
|
|
)
|
|
|
|
set(AWESOME_REQUIRED_INCLUDE_DIRS
|
|
${AWESOME_COMMON_REQUIRED_INCLUDE_DIRS}
|
|
${AWESOME_REQUIRED_INCLUDE_DIRS}
|
|
${LUA_INCLUDE_DIR})
|
|
# }}}
|
|
|
|
# {{{ Optional libraries
|
|
#
|
|
# this sets up:
|
|
# AWESOME_OPTIONAL_LDFLAGS
|
|
# AWESOME_OPTIONAL_INCLUDE_DIRS
|
|
|
|
if(WITH_DBUS)
|
|
pkg_check_modules(DBUS dbus-1)
|
|
if(DBUS_FOUND)
|
|
set(AWESOME_OPTIONAL_LDFLAGS ${AWESOME_OPTIONAL_LDFLAGS} ${DBUS_LDFLAGS})
|
|
set(AWESOME_OPTIONAL_INCLUDE_DIRS ${AWESOME_OPTIONAL_INCLUDE_DIRS} ${DBUS_INCLUDE_DIRS})
|
|
else()
|
|
set(WITH_DBUS OFF)
|
|
message(STATUS "DBUS not found. Disabled.")
|
|
endif()
|
|
endif()
|
|
# }}}
|
|
|
|
# {{{ Install path and configuration variables
|
|
#If a sysconfdir is specified, use it instead
|
|
#of the default configuration dir.
|
|
if(DEFINED SYSCONFDIR)
|
|
set(SYSCONFDIR ${SYSCONFDIR} CACHE PATH "config directory")
|
|
else()
|
|
set(SYSCONFDIR ${CMAKE_INSTALL_PREFIX}/etc CACHE PATH "config directory")
|
|
endif()
|
|
|
|
#If an XDG Config Dir is specificed, use it instead
|
|
#of the default XDG configuration dir.
|
|
if(DEFINED XDG_CONFIG_DIR)
|
|
set(XDG_CONFIG_DIR ${XDG_CONFIG_DIR} CACHE PATH "xdg config directory")
|
|
else()
|
|
set(XDG_CONFIG_DIR ${SYSCONFDIR}/xdg CACHE PATH "xdg config directory")
|
|
endif()
|
|
|
|
# setting AWESOME_DATA_PATH
|
|
if(DEFINED AWESOME_DATA_PATH)
|
|
set(AWESOME_DATA_PATH ${AWESOME_DATA_PATH} CACHE PATH "awesome share directory")
|
|
else()
|
|
set(AWESOME_DATA_PATH ${CMAKE_INSTALL_PREFIX}/share/${PROJECT_AWE_NAME} CACHE PATH "awesome share directory")
|
|
endif()
|
|
|
|
# setting AWESOME_DOC_PATH
|
|
if(DEFINED AWESOME_DOC_PATH)
|
|
set(AWESOME_DOC_PATH ${AWESOME_DOC_PATH} CACHE PATH "awesome docs directory")
|
|
else()
|
|
set(AWESOME_DOC_PATH ${CMAKE_INSTALL_PREFIX}/share/doc/${PROJECT_AWE_NAME} CACHE PATH "awesome docs directory")
|
|
endif()
|
|
|
|
# setting AWESOME_XSESSION_PATH
|
|
if(DEFINED AWESOME_XSESSION_PATH)
|
|
set(AWESOME_XSESSION_PATH ${AWESOME_XSESSION_PATH} CACHE PATH "awesome xsessions directory")
|
|
else()
|
|
set(AWESOME_XSESSION_PATH ${CMAKE_INSTALL_PREFIX}/share/xsessions CACHE PATH "awesome xsessions directory")
|
|
endif()
|
|
|
|
# set man path
|
|
if(DEFINED AWESOME_MAN_PATH)
|
|
set(AWESOME_MAN_PATH ${AWESOME_MAN_PATH} CACHE PATH "awesome manpage directory")
|
|
else()
|
|
set(AWESOME_MAN_PATH ${CMAKE_INSTALL_PREFIX}/share/man CACHE PATH "awesome manpage directory")
|
|
endif()
|
|
|
|
# Hide to avoid confusion
|
|
mark_as_advanced(CMAKE_INSTALL_CMAKE_INSTALL_PREFIX)
|
|
|
|
set(AWESOME_VERSION ${VERSION})
|
|
set(AWESOME_RELEASE ${CODENAME})
|
|
set(AWESOME_SYSCONFDIR ${XDG_CONFIG_DIR}/${PROJECT_AWE_NAME})
|
|
set(AWESOME_LUA_LIB_PATH ${AWESOME_DATA_PATH}/lib)
|
|
set(AWESOME_ICON_PATH ${AWESOME_DATA_PATH}/icons)
|
|
set(AWESOME_THEMES_PATH ${AWESOME_DATA_PATH}/themes)
|
|
# }}}
|
|
|
|
|
|
if(GENERATE_DOC)
|
|
# Load the common documentation
|
|
include(docs/load_ldoc.cmake)
|
|
|
|
# Use `include`, rather than `add_subdirectory`, to keep the variables
|
|
# The file is a valid CMakeLists.txt and can be executed directly if only
|
|
# the image artefacts are needed.
|
|
include(tests/examples/CMakeLists.txt)
|
|
|
|
# Generate the widget lists
|
|
include(docs/widget_lists.cmake)
|
|
endif()
|
|
|
|
# {{{ Configure files
|
|
file(GLOB awesome_c_configure_files RELATIVE ${SOURCE_DIR}
|
|
${SOURCE_DIR}/*.c
|
|
${SOURCE_DIR}/*.h
|
|
${SOURCE_DIR}/common/*.c
|
|
${SOURCE_DIR}/common/*.h
|
|
${SOURCE_DIR}/objects/*.c
|
|
${SOURCE_DIR}/objects/*.h)
|
|
file(GLOB_RECURSE awesome_lua_configure_files RELATIVE ${SOURCE_DIR}
|
|
${SOURCE_DIR}/lib/*.lua
|
|
${SOURCE_DIR}/themes/*/*.lua)
|
|
set(AWESOME_CONFIGURE_FILES
|
|
${awesome_c_configure_files}
|
|
${awesome_lua_configure_files}
|
|
config.h
|
|
docs/config.ld
|
|
awesome-version-internal.h)
|
|
|
|
foreach(file ${AWESOME_CONFIGURE_FILES})
|
|
configure_file(${SOURCE_DIR}/${file}
|
|
${BUILD_DIR}/${file}
|
|
ESCAPE_QUOTES
|
|
@ONLY)
|
|
endforeach()
|
|
#}}}
|
|
|
|
# {{{ Generate some aggregated documentation from lua script
|
|
add_custom_command(
|
|
OUTPUT ${BUILD_DIR}/docs/06-appearance.md
|
|
COMMAND lua ${SOURCE_DIR}/docs/06-appearance.md.lua
|
|
${BUILD_DIR}/docs/06-appearance.md
|
|
)
|
|
|
|
add_custom_command(
|
|
OUTPUT ${BUILD_DIR}/awesomerc.lua ${BUILD_DIR}/docs/05-awesomerc.md
|
|
COMMAND lua ${SOURCE_DIR}/docs/05-awesomerc.md.lua
|
|
${BUILD_DIR}/docs/05-awesomerc.md ${SOURCE_DIR}/awesomerc.lua
|
|
${BUILD_DIR}/awesomerc.lua
|
|
)
|
|
|
|
#}}}
|
|
|
|
# {{{ Copy additional files
|
|
file(GLOB awesome_md_docs RELATIVE ${SOURCE_DIR}
|
|
${SOURCE_DIR}/docs/*.md)
|
|
set(AWESOME_ADDITIONAL_FILES
|
|
${awesome_md_docs})
|
|
|
|
foreach(file ${AWESOME_ADDITIONAL_FILES})
|
|
configure_file(${SOURCE_DIR}/${file}
|
|
${BUILD_DIR}/${file}
|
|
@ONLY)
|
|
endforeach()
|
|
#}}}
|
|
|
|
# The examples coverage need to be done again after the configure_file has
|
|
# inserted the additional code. Otherwise, the result will be off, rendering
|
|
# the coverage useless as a tool to track untested code.
|
|
if(GENERATE_DOC AND DO_COVERAGE)
|
|
message(STATUS "Running tests again with coverage")
|
|
set(USE_LCOV 1)
|
|
|
|
include(tests/examples/CMakeLists.txt)
|
|
endif()
|
|
|
|
# vim: filetype=cmake:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:textwidth=80:foldmethod=marker
|