diff options
author | Ted Gould <ted@gould.cx> | 2013-08-27 12:55:22 -0500 |
---|---|---|
committer | Ted Gould <ted@gould.cx> | 2013-08-27 12:55:22 -0500 |
commit | c440b9d6a1737e3be03e205e32fec64ebdfcb2df (patch) | |
tree | b74867b600c41ff03ed87565eae38d2daaa47d5f /cmake/UseGSettings.cmake | |
parent | 4661ef2d0a834509194d069466e3905aece05183 (diff) | |
parent | b7a8f35077f950dc6dab640e759341c1c2476f5c (diff) | |
download | ayatana-indicator-session-c440b9d6a1737e3be03e205e32fec64ebdfcb2df.tar.gz ayatana-indicator-session-c440b9d6a1737e3be03e205e32fec64ebdfcb2df.tar.bz2 ayatana-indicator-session-c440b9d6a1737e3be03e205e32fec64ebdfcb2df.zip |
Merging trunk
Diffstat (limited to 'cmake/UseGSettings.cmake')
-rw-r--r-- | cmake/UseGSettings.cmake | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/cmake/UseGSettings.cmake b/cmake/UseGSettings.cmake new file mode 100644 index 0000000..3b61523 --- /dev/null +++ b/cmake/UseGSettings.cmake @@ -0,0 +1,23 @@ +# GSettings.cmake, CMake macros written for Marlin, feel free to re-use them. + +macro(add_schema SCHEMA_NAME) + + set(PKG_CONFIG_EXECUTABLE pkg-config) + set(GSETTINGS_DIR "${CMAKE_INSTALL_FULL_DATAROOTDIR}/glib-2.0/schemas") + + # Run the validator and error if it fails + execute_process (COMMAND ${PKG_CONFIG_EXECUTABLE} gio-2.0 --variable glib_compile_schemas OUTPUT_VARIABLE _glib_compile_schemas OUTPUT_STRIP_TRAILING_WHITESPACE) + execute_process (COMMAND ${_glib_compile_schemas} --dry-run --schema-file=${SCHEMA_NAME} ERROR_VARIABLE _schemas_invalid OUTPUT_STRIP_TRAILING_WHITESPACE) + + if (_schemas_invalid) + message (SEND_ERROR "Schema validation error: ${_schemas_invalid}") + endif (_schemas_invalid) + + # Actually install and recomple schemas + message (STATUS "${GSETTINGS_DIR} is the GSettings install dir") + install (FILES ${SCHEMA_NAME} DESTINATION ${GSETTINGS_DIR} OPTIONAL) + + install (CODE "message (STATUS \"Compiling GSettings schemas\")") + install (CODE "execute_process (COMMAND ${_glib_compile_schemas} ${GSETTINGS_DIR})") +endmacro() + |