Merge pull request #285 from christophgysin/cmake
cmake configuration cleanup
This commit is contained in:
commit
1fbabc6c74
|
@ -4,39 +4,44 @@ project(sway C)
|
||||||
|
|
||||||
set(FALLBACK_CONFIG_DIR "/etc/sway" CACHE PATH
|
set(FALLBACK_CONFIG_DIR "/etc/sway" CACHE PATH
|
||||||
"Fallback config directory defaults to /etc/sway")
|
"Fallback config directory defaults to /etc/sway")
|
||||||
add_definitions('-DFALLBACK_CONFIG_DIR=\"${FALLBACK_CONFIG_DIR}\"')
|
add_definitions(-DFALLBACK_CONFIG_DIR=\"${FALLBACK_CONFIG_DIR}\")
|
||||||
|
|
||||||
set(CMAKE_C_FLAGS "-g")
|
set(CMAKE_C_FLAGS "-g")
|
||||||
set(CMAKE_C_STANDARD 99)
|
set(CMAKE_C_STANDARD 99)
|
||||||
SET(CMAKE_C_EXTENSIONS OFF)
|
set(CMAKE_C_EXTENSIONS OFF)
|
||||||
set(CMAKE_CURRENT_BINARY_DIR "${CMAKE_CURRENT_BINARY_DIR}/bin")
|
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/bin)
|
||||||
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}")
|
add_definitions(
|
||||||
add_definitions("-Wall -Wextra -Wno-unused-parameter -D_GNU_SOURCE")
|
-D_GNU_SOURCE
|
||||||
list(INSERT CMAKE_MODULE_PATH 0
|
)
|
||||||
"${CMAKE_CURRENT_SOURCE_DIR}/CMake")
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wall")
|
||||||
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wextra")
|
||||||
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-parameter")
|
||||||
|
|
||||||
if(EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/.git")
|
list(INSERT CMAKE_MODULE_PATH 0
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}/CMake
|
||||||
|
)
|
||||||
|
if(EXISTS ${CMAKE_CURRENT_SOURCE_DIR}/.git)
|
||||||
execute_process(
|
execute_process(
|
||||||
COMMAND git describe --always
|
COMMAND git describe --always
|
||||||
OUTPUT_VARIABLE GIT_COMMIT_HASH
|
OUTPUT_VARIABLE GIT_COMMIT_HASH
|
||||||
OUTPUT_STRIP_TRAILING_WHITESPACE
|
OUTPUT_STRIP_TRAILING_WHITESPACE
|
||||||
WORKING_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}"
|
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
||||||
)
|
)
|
||||||
execute_process(
|
execute_process(
|
||||||
COMMAND git rev-parse --abbrev-ref HEAD
|
COMMAND git rev-parse --abbrev-ref HEAD
|
||||||
OUTPUT_VARIABLE GIT_BRANCH
|
OUTPUT_VARIABLE GIT_BRANCH
|
||||||
OUTPUT_STRIP_TRAILING_WHITESPACE
|
OUTPUT_STRIP_TRAILING_WHITESPACE
|
||||||
WORKING_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}"
|
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
||||||
)
|
)
|
||||||
endif(EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/.git")
|
endif()
|
||||||
|
|
||||||
add_definitions("-DSWAY_GIT_VERSION=\"g${GIT_COMMIT_HASH}\"")
|
add_definitions(-DSWAY_GIT_VERSION=\"${GIT_COMMIT_HASH}\")
|
||||||
add_definitions("-DSWAY_GIT_BRANCH=\"${GIT_BRANCH}\"")
|
add_definitions(-DSWAY_GIT_BRANCH=\"${GIT_BRANCH}\")
|
||||||
|
|
||||||
string(TIMESTAMP CURRENT_DATE "%Y-%m-%d" UTC)
|
string(TIMESTAMP CURRENT_DATE "%Y-%m-%d" UTC)
|
||||||
add_definitions('-DSWAY_VERSION_DATE="${CURRENT_DATE}"')
|
add_definitions(-DSWAY_VERSION_DATE=\"${CURRENT_DATE}\")
|
||||||
|
|
||||||
include_directories("${CMAKE_CURRENT_SOURCE_DIR}/include")
|
include_directories(${CMAKE_CURRENT_SOURCE_DIR}/include)
|
||||||
|
|
||||||
add_subdirectory(swaybg)
|
add_subdirectory(swaybg)
|
||||||
add_subdirectory(swaymsg)
|
add_subdirectory(swaymsg)
|
||||||
|
@ -50,11 +55,14 @@ find_package(PCRE REQUIRED)
|
||||||
find_package(Wayland REQUIRED)
|
find_package(Wayland REQUIRED)
|
||||||
find_package(JsonC REQUIRED)
|
find_package(JsonC REQUIRED)
|
||||||
|
|
||||||
FILE(GLOB sources ${PROJECT_SOURCE_DIR}/sway/*.c)
|
file(GLOB sources ${PROJECT_SOURCE_DIR}/sway/*.c)
|
||||||
FILE(GLOB common ${PROJECT_SOURCE_DIR}/common/*.c)
|
file(GLOB common ${PROJECT_SOURCE_DIR}/common/*.c)
|
||||||
|
|
||||||
include(Wayland)
|
include(Wayland)
|
||||||
WAYLAND_ADD_PROTOCOL_SERVER(proto-desktop-shell "${PROJECT_SOURCE_DIR}/protocols/desktop-shell.xml" desktop-shell)
|
WAYLAND_ADD_PROTOCOL_SERVER(proto-desktop-shell
|
||||||
|
${PROJECT_SOURCE_DIR}/protocols/desktop-shell.xml
|
||||||
|
desktop-shell
|
||||||
|
)
|
||||||
|
|
||||||
include_directories(
|
include_directories(
|
||||||
${WLC_INCLUDE_DIRS}
|
${WLC_INCLUDE_DIRS}
|
||||||
|
@ -80,37 +88,44 @@ target_link_libraries(sway
|
||||||
|
|
||||||
install(
|
install(
|
||||||
TARGETS sway
|
TARGETS sway
|
||||||
RUNTIME DESTINATION bin
|
RUNTIME
|
||||||
COMPONENT runtime)
|
DESTINATION bin
|
||||||
|
COMPONENT runtime
|
||||||
|
)
|
||||||
install(
|
install(
|
||||||
FILES "${CMAKE_CURRENT_SOURCE_DIR}/config"
|
FILES ${CMAKE_CURRENT_SOURCE_DIR}/config
|
||||||
DESTINATION "${FALLBACK_CONFIG_DIR}"
|
DESTINATION ${FALLBACK_CONFIG_DIR}
|
||||||
COMPONENT configuration)
|
COMPONENT configuration
|
||||||
|
)
|
||||||
|
|
||||||
add_custom_target(man ALL)
|
add_custom_target(man ALL)
|
||||||
|
|
||||||
function(add_manpage name section)
|
function(add_manpage name section)
|
||||||
add_custom_command(
|
add_custom_command(
|
||||||
OUTPUT "${CMAKE_CURRENT_BINARY_DIR}/${name}.${section}"
|
OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/${name}.${section}
|
||||||
COMMAND "${A2X_COMMAND}"
|
COMMAND ${A2X_COMMAND}
|
||||||
--no-xmllint
|
--no-xmllint
|
||||||
--doctype manpage
|
--doctype manpage
|
||||||
--format manpage
|
--format manpage
|
||||||
-D "${CMAKE_RUNTIME_OUTPUT_DIRECTORY}"
|
-D ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}
|
||||||
"${CMAKE_CURRENT_SOURCE_DIR}/${name}.${section}.txt"
|
${CMAKE_CURRENT_SOURCE_DIR}/${name}.${section}.txt
|
||||||
DEPENDS "${CMAKE_CURRENT_SOURCE_DIR}/${name}.${section}.txt"
|
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${name}.${section}.txt
|
||||||
COMMENT "Generating manpage for ${name}.${section}")
|
COMMENT Generating manpage for ${name}.${section}
|
||||||
|
)
|
||||||
|
|
||||||
add_custom_target("man-${name}.${section}"
|
add_custom_target(man-${name}.${section}
|
||||||
DEPENDS
|
DEPENDS
|
||||||
"${CMAKE_CURRENT_BINARY_DIR}/${name}.${section}")
|
${CMAKE_CURRENT_BINARY_DIR}/${name}.${section}
|
||||||
|
)
|
||||||
add_dependencies(man
|
add_dependencies(man
|
||||||
"man-${name}.${section}")
|
man-${name}.${section}
|
||||||
|
)
|
||||||
|
|
||||||
install(
|
install(
|
||||||
FILES "${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/${name}.${section}"
|
FILES ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/${name}.${section}
|
||||||
DESTINATION "share/man/man${section}"
|
DESTINATION share/man/man${section}
|
||||||
COMPONENT documentation)
|
COMPONENT documentation
|
||||||
|
)
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
add_manpage(sway 1)
|
add_manpage(sway 1)
|
||||||
|
@ -119,10 +134,12 @@ add_manpage(swaymsg 1)
|
||||||
add_manpage(swaygrab 1)
|
add_manpage(swaygrab 1)
|
||||||
|
|
||||||
install(
|
install(
|
||||||
FILES "${CMAKE_CURRENT_SOURCE_DIR}/sway.desktop"
|
FILES ${CMAKE_CURRENT_SOURCE_DIR}/sway.desktop
|
||||||
DESTINATION share/wayland-sessions
|
DESTINATION share/wayland-sessions
|
||||||
COMPONENT data)
|
COMPONENT data
|
||||||
|
)
|
||||||
install(
|
install(
|
||||||
FILES "${CMAKE_CURRENT_SOURCE_DIR}/sway-xorg.desktop"
|
FILES ${CMAKE_CURRENT_SOURCE_DIR}/sway-xorg.desktop
|
||||||
DESTINATION share/xsessions
|
DESTINATION share/xsessions
|
||||||
COMPONENT data)
|
COMPONENT data
|
||||||
|
)
|
||||||
|
|
|
@ -46,7 +46,9 @@ Install dependencies:
|
||||||
|
|
||||||
Run these commands:
|
Run these commands:
|
||||||
|
|
||||||
cmake .
|
mkdir build
|
||||||
|
cd build
|
||||||
|
cmake ..
|
||||||
make
|
make
|
||||||
sudo make install
|
sudo make install
|
||||||
|
|
||||||
|
|
|
@ -5,9 +5,14 @@ find_package(Cairo REQUIRED)
|
||||||
find_package(Pango REQUIRED)
|
find_package(Pango REQUIRED)
|
||||||
|
|
||||||
include(Wayland)
|
include(Wayland)
|
||||||
set(CMAKE_CURRENT_BINARY_DIR ${CMAKE_CURRENT_BINARY_DIR}/../bin/)
|
WAYLAND_ADD_PROTOCOL_CLIENT(proto-xdg-shell
|
||||||
WAYLAND_ADD_PROTOCOL_CLIENT(proto-xdg-shell "${PROJECT_SOURCE_DIR}/../protocols/xdg-shell.xml" xdg-shell)
|
${PROJECT_SOURCE_DIR}/../protocols/xdg-shell.xml
|
||||||
WAYLAND_ADD_PROTOCOL_CLIENT(proto-desktop-shell "${PROJECT_SOURCE_DIR}/../protocols/desktop-shell.xml" desktop-shell)
|
xdg-shell
|
||||||
|
)
|
||||||
|
WAYLAND_ADD_PROTOCOL_CLIENT(proto-desktop-shell
|
||||||
|
${PROJECT_SOURCE_DIR}/../protocols/desktop-shell.xml
|
||||||
|
desktop-shell
|
||||||
|
)
|
||||||
|
|
||||||
include_directories(
|
include_directories(
|
||||||
${WAYLAND_CLIENT_INCLUDE_DIR}
|
${WAYLAND_CLIENT_INCLUDE_DIR}
|
||||||
|
@ -16,9 +21,9 @@ include_directories(
|
||||||
${CMAKE_CURRENT_BINARY_DIR}
|
${CMAKE_CURRENT_BINARY_DIR}
|
||||||
)
|
)
|
||||||
|
|
||||||
FILE(GLOB sources ${PROJECT_SOURCE_DIR}/*.c)
|
file(GLOB sources ${PROJECT_SOURCE_DIR}/*.c)
|
||||||
FILE(GLOB common ${PROJECT_SOURCE_DIR}/../common/*.c)
|
file(GLOB common ${PROJECT_SOURCE_DIR}/../common/*.c)
|
||||||
FILE(GLOB wl_sources ${PROJECT_SOURCE_DIR}/../wayland/*.c)
|
file(GLOB wl_sources ${PROJECT_SOURCE_DIR}/../wayland/*.c)
|
||||||
|
|
||||||
add_executable(swaybar
|
add_executable(swaybar
|
||||||
${sources}
|
${sources}
|
||||||
|
@ -28,9 +33,17 @@ add_executable(swaybar
|
||||||
${proto-desktop-shell}
|
${proto-desktop-shell}
|
||||||
)
|
)
|
||||||
|
|
||||||
TARGET_LINK_LIBRARIES(swaybar ${WAYLAND_CLIENT_LIBRARIES} ${WAYLAND_CURSOR_LIBRARIES} ${CAIRO_LIBRARIES} ${PANGO_LIBRARIES} m)
|
target_link_libraries(swaybar
|
||||||
|
${WAYLAND_CLIENT_LIBRARIES}
|
||||||
|
${WAYLAND_CURSOR_LIBRARIES}
|
||||||
|
${CAIRO_LIBRARIES}
|
||||||
|
${PANGO_LIBRARIES}
|
||||||
|
m
|
||||||
|
)
|
||||||
|
|
||||||
install(
|
install(
|
||||||
TARGETS swaybar
|
TARGETS swaybar
|
||||||
RUNTIME DESTINATION bin
|
RUNTIME
|
||||||
COMPONENT runtime)
|
DESTINATION bin
|
||||||
|
COMPONENT runtime
|
||||||
|
)
|
||||||
|
|
|
@ -5,9 +5,14 @@ find_package(Cairo REQUIRED)
|
||||||
find_package(Pango REQUIRED)
|
find_package(Pango REQUIRED)
|
||||||
|
|
||||||
include(Wayland)
|
include(Wayland)
|
||||||
set(CMAKE_CURRENT_BINARY_DIR ${CMAKE_CURRENT_BINARY_DIR}/../bin/)
|
WAYLAND_ADD_PROTOCOL_CLIENT(proto-xdg-shell
|
||||||
WAYLAND_ADD_PROTOCOL_CLIENT(proto-xdg-shell "${PROJECT_SOURCE_DIR}/../protocols/xdg-shell.xml" xdg-shell)
|
${PROJECT_SOURCE_DIR}/../protocols/xdg-shell.xml
|
||||||
WAYLAND_ADD_PROTOCOL_CLIENT(proto-desktop-shell "${PROJECT_SOURCE_DIR}/../protocols/desktop-shell.xml" desktop-shell)
|
xdg-shell
|
||||||
|
)
|
||||||
|
WAYLAND_ADD_PROTOCOL_CLIENT(proto-desktop-shell
|
||||||
|
${PROJECT_SOURCE_DIR}/../protocols/desktop-shell.xml
|
||||||
|
desktop-shell
|
||||||
|
)
|
||||||
|
|
||||||
include_directories(
|
include_directories(
|
||||||
${WAYLAND_CLIENT_INCLUDE_DIR}
|
${WAYLAND_CLIENT_INCLUDE_DIR}
|
||||||
|
@ -16,9 +21,9 @@ include_directories(
|
||||||
${CMAKE_CURRENT_BINARY_DIR}
|
${CMAKE_CURRENT_BINARY_DIR}
|
||||||
)
|
)
|
||||||
|
|
||||||
FILE(GLOB sources ${PROJECT_SOURCE_DIR}/*.c)
|
file(GLOB sources ${PROJECT_SOURCE_DIR}/*.c)
|
||||||
FILE(GLOB common ${PROJECT_SOURCE_DIR}/../common/*.c)
|
file(GLOB common ${PROJECT_SOURCE_DIR}/../common/*.c)
|
||||||
FILE(GLOB wl_sources ${PROJECT_SOURCE_DIR}/../wayland/*.c)
|
file(GLOB wl_sources ${PROJECT_SOURCE_DIR}/../wayland/*.c)
|
||||||
|
|
||||||
add_executable(swaybg
|
add_executable(swaybg
|
||||||
${sources}
|
${sources}
|
||||||
|
@ -28,9 +33,17 @@ add_executable(swaybg
|
||||||
${proto-desktop-shell}
|
${proto-desktop-shell}
|
||||||
)
|
)
|
||||||
|
|
||||||
TARGET_LINK_LIBRARIES(swaybg ${WAYLAND_CLIENT_LIBRARIES} ${WAYLAND_CURSOR_LIBRARIES} ${CAIRO_LIBRARIES} ${PANGO_LIBRARIES} m)
|
target_link_libraries(swaybg
|
||||||
|
${WAYLAND_CLIENT_LIBRARIES}
|
||||||
|
${WAYLAND_CURSOR_LIBRARIES}
|
||||||
|
${CAIRO_LIBRARIES}
|
||||||
|
${PANGO_LIBRARIES}
|
||||||
|
m
|
||||||
|
)
|
||||||
|
|
||||||
install(
|
install(
|
||||||
TARGETS swaybg
|
TARGETS swaybg
|
||||||
RUNTIME DESTINATION bin
|
RUNTIME
|
||||||
COMPONENT runtime)
|
DESTINATION bin
|
||||||
|
COMPONENT runtime
|
||||||
|
)
|
||||||
|
|
|
@ -1,18 +1,20 @@
|
||||||
project(swaygrab)
|
project(swaygrab)
|
||||||
|
|
||||||
set(CMAKE_CURRENT_BINARY_DIR ${CMAKE_CURRENT_BINARY_DIR}/../bin/)
|
file(GLOB sources ${PROJECT_SOURCE_DIR}/*.c)
|
||||||
|
file(GLOB common ${PROJECT_SOURCE_DIR}/../common/*.c)
|
||||||
FILE(GLOB sources ${PROJECT_SOURCE_DIR}/*.c)
|
|
||||||
FILE(GLOB common ${PROJECT_SOURCE_DIR}/../common/*.c)
|
|
||||||
|
|
||||||
add_executable(swaygrab
|
add_executable(swaygrab
|
||||||
${sources}
|
${sources}
|
||||||
${common}
|
${common}
|
||||||
)
|
)
|
||||||
|
|
||||||
TARGET_LINK_LIBRARIES(swaygrab rt)
|
target_link_libraries(swaygrab
|
||||||
|
rt
|
||||||
|
)
|
||||||
|
|
||||||
install(
|
install(
|
||||||
TARGETS swaygrab
|
TARGETS swaygrab
|
||||||
RUNTIME DESTINATION bin
|
RUNTIME
|
||||||
COMPONENT runtime)
|
DESTINATION bin
|
||||||
|
COMPONENT runtime
|
||||||
|
)
|
||||||
|
|
|
@ -1,9 +1,7 @@
|
||||||
project(swaymsg)
|
project(swaymsg)
|
||||||
|
|
||||||
set(CMAKE_CURRENT_BINARY_DIR ${CMAKE_CURRENT_BINARY_DIR}/../bin/)
|
file(GLOB sources ${PROJECT_SOURCE_DIR}/*.c)
|
||||||
|
file(GLOB common ${PROJECT_SOURCE_DIR}/../common/*.c)
|
||||||
FILE(GLOB sources ${PROJECT_SOURCE_DIR}/*.c)
|
|
||||||
FILE(GLOB common ${PROJECT_SOURCE_DIR}/../common/*.c)
|
|
||||||
|
|
||||||
add_executable(swaymsg
|
add_executable(swaymsg
|
||||||
${sources}
|
${sources}
|
||||||
|
@ -12,5 +10,7 @@ add_executable(swaymsg
|
||||||
|
|
||||||
install(
|
install(
|
||||||
TARGETS swaymsg
|
TARGETS swaymsg
|
||||||
RUNTIME DESTINATION bin
|
RUNTIME
|
||||||
COMPONENT runtime)
|
DESTINATION bin
|
||||||
|
COMPONENT runtime
|
||||||
|
)
|
||||||
|
|
Loading…
Reference in a new issue