diff options
author | Robert Tari <robert@tari.in> | 2021-07-14 17:28:31 +0200 |
---|---|---|
committer | Robert Tari <robert@tari.in> | 2021-07-14 17:28:31 +0200 |
commit | 68ca6a14c8ccff625957f1a8f4676789a3460ad7 (patch) | |
tree | 8a1092d4bd8d2e1f0ed88319c13510542c254a15 /cmake | |
parent | 4610e5bec01fd4a07e0867d7e84be0f3524b1cf0 (diff) | |
download | libayatana-common-68ca6a14c8ccff625957f1a8f4676789a3460ad7.tar.gz libayatana-common-68ca6a14c8ccff625957f1a8f4676789a3460ad7.tar.bz2 libayatana-common-68ca6a14c8ccff625957f1a8f4676789a3460ad7.zip |
Test
Diffstat (limited to '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() + |