2020-08-25 16:05:56 +02:00
|
|
|
# === This file is part of Calamares - <https://calamares.io> ===
|
2018-03-09 17:13:42 +01:00
|
|
|
#
|
2020-08-26 00:24:40 +02:00
|
|
|
# SPDX-FileCopyrightText: 2014 Teo Mrnjavac <teo@kde.org>
|
|
|
|
# SPDX-FileCopyrightText: 2019 Adriaan de Groot <groot@kde.org>
|
|
|
|
# SPDX-License-Identifier: BSD-2-Clause
|
|
|
|
#
|
2020-08-25 16:05:56 +02:00
|
|
|
# Calamares is Free Software: see the License-Identifier above.
|
2018-03-09 17:13:42 +01:00
|
|
|
#
|
|
|
|
#
|
|
|
|
###
|
|
|
|
#
|
2017-08-02 14:53:00 +02:00
|
|
|
# Convenience function for creating a C++ (qtplugin) module for Calamares.
|
|
|
|
# This function provides cmake-time feedback about the plugin, adds
|
|
|
|
# targets for compilation and boilerplate information, and creates
|
2018-08-07 11:57:26 +02:00
|
|
|
# a module.desc with standard values (if the module.desc file exists,
|
|
|
|
# that one is used instead, which happens only for unusual plugins).
|
2017-08-02 14:53:00 +02:00
|
|
|
#
|
|
|
|
# Usage:
|
|
|
|
#
|
2017-08-03 02:03:14 +02:00
|
|
|
# calamares_add_plugin(
|
2017-08-02 14:53:00 +02:00
|
|
|
# module-name
|
2023-12-31 00:18:05 +01:00
|
|
|
# TYPE <viewmodule|job>
|
2017-08-02 14:53:00 +02:00
|
|
|
# EXPORT_MACRO macro-name
|
|
|
|
# SOURCES source-file...
|
|
|
|
# UI ui-file...
|
|
|
|
# LINK_LIBRARIES lib...
|
|
|
|
# LINK_PRIVATE_LIBRARIES lib...
|
2018-08-07 11:57:26 +02:00
|
|
|
# [COMPILE_DEFINITIONS def...]
|
|
|
|
# [RESOURCES resource-file]
|
|
|
|
# [REQUIRES module-name...]
|
2017-08-02 14:53:00 +02:00
|
|
|
# [NO_INSTALL]
|
2020-01-20 19:27:34 +01:00
|
|
|
# [NO_CONFIG]
|
2017-08-02 14:53:00 +02:00
|
|
|
# [SHARED_LIB]
|
2018-06-15 13:11:17 +02:00
|
|
|
# [EMERGENCY]
|
2020-08-12 15:59:42 +02:00
|
|
|
# [WEIGHT w]
|
2017-08-02 14:53:00 +02:00
|
|
|
# )
|
2019-03-17 16:07:07 +01:00
|
|
|
#
|
2023-12-31 00:18:05 +01:00
|
|
|
# Function optional parameters:
|
2018-08-07 11:57:26 +02:00
|
|
|
# - COMPILE_DEFINITIONS
|
|
|
|
# Definitions are set on the resulting module with a suitable
|
|
|
|
# flag (i.e. `-D`) so only state the name (optionally, also the value)
|
|
|
|
# without a `-D` prefixed to it.
|
|
|
|
# - RESOURCES
|
|
|
|
# One (single!) filename for the RCC file for the plugin.
|
|
|
|
# - REQUIRES
|
|
|
|
# One or more names of modules which are added to the *requiredModules*
|
|
|
|
# key in the descriptor. See *Module Requirements* in the module
|
|
|
|
# documentation.
|
|
|
|
# - NO_INSTALL
|
|
|
|
# If this is set, the module is not installed by default; use this to
|
|
|
|
# build testing modules or unit-testing modules.
|
|
|
|
# - SHARED_LIB
|
|
|
|
# In unusual circumstances, this function is used to add a library
|
|
|
|
# rather than a normal Calamares module / plugin.
|
|
|
|
# - EMERGENCY
|
|
|
|
# If this is set, the module is marked as an *emergency* module in the
|
|
|
|
# descriptor. See *Emergency Modules* in the module documentation.
|
2020-08-12 15:59:42 +02:00
|
|
|
# - WEIGHT
|
|
|
|
# If this is set, writes an explicit weight into the module.desc;
|
|
|
|
# module weights are used in progress reporting.
|
2018-08-07 11:57:26 +02:00
|
|
|
#
|
2021-03-22 15:55:30 +01:00
|
|
|
#
|
|
|
|
# This function follows the global SKIP_MODULES and USE_* settings, so
|
|
|
|
# a plugin may be skipped -- then nothing will be built. In that case,
|
|
|
|
# SKIPPED_MODULES is set in the parent (i.e. caller's) scope with the
|
|
|
|
# reason why. This should rarely be a concern as AddModuleSubdirectory
|
|
|
|
# already handles skip-reasons and collects them for reporting.
|
2023-12-31 00:18:05 +01:00
|
|
|
#
|
|
|
|
# The target defined this way is called "calamares_<TYPE>_<module-name>",
|
2024-02-18 23:30:50 +01:00
|
|
|
# e.g. "calamares_viewmodule_packagechooserq". The function sets a variable
|
|
|
|
# in its **calling** scope, `<module-name>_TARGET` with the full name
|
|
|
|
# of the target.
|
2017-08-02 14:53:00 +02:00
|
|
|
|
2014-06-11 13:37:10 +02:00
|
|
|
include( CMakeParseArguments )
|
2021-03-22 15:55:30 +01:00
|
|
|
|
2017-07-05 17:17:39 +02:00
|
|
|
include( CalamaresAddLibrary )
|
2021-03-22 15:55:30 +01:00
|
|
|
include( CalamaresCheckModuleSelection )
|
2017-07-05 17:17:39 +02:00
|
|
|
include( CMakeColors )
|
2014-06-11 13:37:10 +02:00
|
|
|
|
2014-07-14 16:21:42 +02:00
|
|
|
function( calamares_add_plugin )
|
|
|
|
# parse arguments ( name needs to be saved before passing ARGN into the macro )
|
|
|
|
set( NAME ${ARGV0} )
|
2020-01-20 19:27:34 +01:00
|
|
|
set( options NO_CONFIG NO_INSTALL SHARED_LIB EMERGENCY )
|
2020-08-12 15:59:42 +02:00
|
|
|
set( oneValueArgs NAME TYPE EXPORT_MACRO RESOURCES WEIGHT )
|
2018-08-07 11:57:26 +02:00
|
|
|
set( multiValueArgs SOURCES UI LINK_LIBRARIES LINK_PRIVATE_LIBRARIES COMPILE_DEFINITIONS REQUIRES )
|
2014-07-14 16:21:42 +02:00
|
|
|
cmake_parse_arguments( PLUGIN "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN} )
|
|
|
|
set( PLUGIN_NAME ${NAME} )
|
|
|
|
set( PLUGIN_DESTINATION ${CMAKE_INSTALL_LIBDIR}/calamares/modules/${PLUGIN_NAME} )
|
2014-08-05 18:18:57 +02:00
|
|
|
set( PLUGIN_DESC_FILE module.desc )
|
2015-09-09 18:55:08 +02:00
|
|
|
file( GLOB PLUGIN_CONFIG_FILES RELATIVE ${CMAKE_CURRENT_SOURCE_DIR} "*.conf" )
|
2014-08-08 10:37:53 +02:00
|
|
|
set( PLUGIN_DATA_DESTINATION share/calamares/modules )
|
2014-07-14 16:21:42 +02:00
|
|
|
set( CMAKE_RUNTIME_OUTPUT_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}" )
|
|
|
|
set( CMAKE_LIBRARY_OUTPUT_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}" )
|
|
|
|
set( CMAKE_ARCHIVE_OUTPUT_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}" )
|
2014-06-11 13:37:10 +02:00
|
|
|
|
2021-03-22 15:55:30 +01:00
|
|
|
calamares_check_skip( ${NAME} _skip)
|
|
|
|
if ( _skip )
|
|
|
|
set( SKIPPED_MODULES "${_skip}" PARENT_SCOPE )
|
|
|
|
return()
|
|
|
|
endif()
|
|
|
|
|
2014-07-14 16:21:42 +02:00
|
|
|
message( "-- ${BoldYellow}Found ${CALAMARES_APPLICATION_NAME} module: ${BoldRed}${PLUGIN_NAME}${ColorReset}" )
|
2018-09-14 11:33:04 +02:00
|
|
|
message( " ${Green}TYPE:${ColorReset} ${PLUGIN_TYPE}" )
|
|
|
|
message( " ${Green}LINK_LIBRARIES:${ColorReset} ${PLUGIN_LINK_LIBRARIES}" )
|
|
|
|
message( " ${Green}LINK_PRIVATE_LIBRARIES:${ColorReset} ${PLUGIN_LINK_PRIVATE_LIBRARIES}" )
|
|
|
|
message( " ${Green}PLUGIN_DESTINATION:${ColorReset} ${PLUGIN_DESTINATION}" )
|
|
|
|
if( PLUGIN_CONFIG_FILES )
|
2020-01-20 19:27:34 +01:00
|
|
|
if( PLUGIN_NO_CONFIG )
|
|
|
|
message( FATAL_ERROR "${Red}NO_CONFIG${ColorReset} is set, with configuration ${Red}${PLUGIN_CONFIG_FILES}${ColorReset}" )
|
|
|
|
endif()
|
2018-09-14 11:33:04 +02:00
|
|
|
set( _destination "(unknown)" )
|
2023-11-09 21:52:12 +01:00
|
|
|
if(INSTALL_CONFIG AND NOT PLUGIN_NO_INSTALL)
|
|
|
|
set(_destination "${PLUGIN_DATA_DESTINATION}")
|
|
|
|
elseif( NOT PLUGIN_NO_INSTALL )
|
2018-09-14 11:33:04 +02:00
|
|
|
set( _destination "[Build directory only]" )
|
|
|
|
else()
|
|
|
|
set( _destination "[Skipping installation]" )
|
2014-08-08 10:37:53 +02:00
|
|
|
endif()
|
2018-09-14 11:33:04 +02:00
|
|
|
message( " ${Green}CONFIGURATION_FILES:${ColorReset} ${PLUGIN_CONFIG_FILES} => ${_destination}" )
|
2020-01-20 19:27:34 +01:00
|
|
|
else()
|
|
|
|
if( NOT PLUGIN_NO_CONFIG )
|
|
|
|
message( " ${Red}NO_CONFIG${ColorReset} should be set." )
|
|
|
|
endif()
|
2018-09-14 11:33:04 +02:00
|
|
|
endif()
|
|
|
|
if( PLUGIN_RESOURCES )
|
|
|
|
message( " ${Green}RESOURCES:${ColorReset} ${PLUGIN_RESOURCES}" )
|
2014-07-02 11:59:55 +02:00
|
|
|
endif()
|
2018-09-14 11:33:04 +02:00
|
|
|
message( "" )
|
|
|
|
|
2014-06-11 13:37:10 +02:00
|
|
|
# create target name once for convenience
|
2014-07-14 16:21:42 +02:00
|
|
|
set( target "calamares_${PLUGIN_TYPE}_${PLUGIN_NAME}" )
|
2014-06-11 13:37:10 +02:00
|
|
|
|
2021-07-26 14:27:52 +02:00
|
|
|
# automatic library linkage
|
2023-12-31 00:18:05 +01:00
|
|
|
if(PLUGIN_TYPE STREQUAL "viewmodule")
|
2021-07-26 14:27:52 +02:00
|
|
|
list(APPEND PLUGIN_LINK_PRIVATE_LIBRARIES Calamares::calamaresui)
|
|
|
|
elseif(PLUGIN_TYPE STREQUAL "job")
|
|
|
|
list(APPEND PLUGIN_LINK_PRIVATE_LIBRARIES Calamares::calamares)
|
|
|
|
else()
|
|
|
|
message(FATAL_ERROR "Unknown plugin type ${PLUGIN_TYPE}")
|
|
|
|
endif()
|
|
|
|
|
2014-06-11 13:37:10 +02:00
|
|
|
# determine target type
|
2014-07-14 16:21:42 +02:00
|
|
|
if( NOT ${PLUGIN_SHARED_LIB} )
|
|
|
|
set( target_type "MODULE" )
|
2014-06-11 13:37:10 +02:00
|
|
|
else()
|
2014-07-14 16:21:42 +02:00
|
|
|
set( target_type "SHARED" )
|
2014-06-11 13:37:10 +02:00
|
|
|
endif()
|
|
|
|
|
2018-06-15 13:19:02 +02:00
|
|
|
set( calamares_add_library_args
|
2014-06-24 12:40:12 +02:00
|
|
|
"${target}"
|
|
|
|
"EXPORT_MACRO" "${PLUGIN_EXPORT_MACRO}"
|
|
|
|
"TARGET_TYPE" "${target_type}"
|
|
|
|
"SOURCES" "${PLUGIN_SOURCES}"
|
2014-06-11 13:37:10 +02:00
|
|
|
)
|
|
|
|
|
2014-07-14 16:21:42 +02:00
|
|
|
if( PLUGIN_UI )
|
|
|
|
list( APPEND calamares_add_library_args "UI" "${PLUGIN_UI}" )
|
2014-06-11 13:37:10 +02:00
|
|
|
endif()
|
|
|
|
|
2014-07-14 16:21:42 +02:00
|
|
|
if( PLUGIN_LINK_LIBRARIES )
|
|
|
|
list( APPEND calamares_add_library_args "LINK_LIBRARIES" "${PLUGIN_LINK_LIBRARIES}" )
|
2014-06-11 13:37:10 +02:00
|
|
|
endif()
|
|
|
|
|
2016-12-07 16:36:31 +01:00
|
|
|
if( PLUGIN_LINK_PRIVATE_LIBRARIES )
|
|
|
|
list( APPEND calamares_add_library_args "LINK_PRIVATE_LIBRARIES" "${PLUGIN_LINK_PRIVATE_LIBRARIES}" )
|
|
|
|
endif()
|
|
|
|
|
2014-07-14 16:21:42 +02:00
|
|
|
if( PLUGIN_COMPILE_DEFINITIONS )
|
|
|
|
list( APPEND calamares_add_library_args "COMPILE_DEFINITIONS" ${PLUGIN_COMPILE_DEFINITIONS} )
|
2014-06-11 13:37:10 +02:00
|
|
|
endif()
|
|
|
|
|
2018-06-15 13:19:02 +02:00
|
|
|
if ( PLUGIN_NO_INSTALL )
|
|
|
|
list( APPEND calamares_add_library_args "NO_INSTALL" )
|
|
|
|
endif()
|
2014-06-11 13:37:10 +02:00
|
|
|
|
2018-06-15 13:19:02 +02:00
|
|
|
list( APPEND calamares_add_library_args
|
|
|
|
"NO_VERSION"
|
|
|
|
"INSTALL_BINDIR" "${PLUGIN_DESTINATION}"
|
|
|
|
)
|
2014-06-23 17:14:08 +02:00
|
|
|
|
2014-08-26 15:18:30 +02:00
|
|
|
if( PLUGIN_RESOURCES )
|
|
|
|
list( APPEND calamares_add_library_args "RESOURCES" "${PLUGIN_RESOURCES}" )
|
|
|
|
endif()
|
|
|
|
|
2014-07-14 16:21:42 +02:00
|
|
|
calamares_add_library( ${calamares_add_library_args} )
|
2014-06-23 17:14:08 +02:00
|
|
|
|
2017-07-05 17:51:43 +02:00
|
|
|
if ( EXISTS ${CMAKE_CURRENT_SOURCE_DIR}/${PLUGIN_DESC_FILE} )
|
|
|
|
configure_file( ${PLUGIN_DESC_FILE} ${PLUGIN_DESC_FILE} COPYONLY )
|
|
|
|
else()
|
|
|
|
set( _file ${CMAKE_CURRENT_BINARY_DIR}/${PLUGIN_DESC_FILE} )
|
2017-07-05 18:04:46 +02:00
|
|
|
set( _type ${PLUGIN_TYPE} )
|
2017-07-05 17:51:43 +02:00
|
|
|
file( WRITE ${_file} "# AUTO-GENERATED metadata file\n# Syntax is YAML 1.2\n---\n" )
|
2017-07-05 18:04:46 +02:00
|
|
|
file( APPEND ${_file} "type: \"${_type}\"\nname: \"${PLUGIN_NAME}\"\ninterface: \"qtplugin\"\nload: \"lib${target}.so\"\n" )
|
2018-08-07 11:57:26 +02:00
|
|
|
if ( PLUGIN_REQUIRES )
|
|
|
|
file( APPEND ${_file} "requiredModules:\n" )
|
|
|
|
foreach( _r ${PLUGIN_REQUIRES} )
|
|
|
|
file( APPEND ${_file} " - ${_r}\n" )
|
|
|
|
endforeach()
|
|
|
|
endif()
|
2018-06-15 13:11:17 +02:00
|
|
|
if ( PLUGIN_EMERGENCY )
|
|
|
|
file( APPEND ${_file} "emergency: true\n" )
|
|
|
|
endif()
|
2020-01-24 20:58:23 +01:00
|
|
|
if ( PLUGIN_NO_CONFIG )
|
2020-01-20 19:27:34 +01:00
|
|
|
file( APPEND ${_file} "noconfig: true\n" )
|
|
|
|
endif()
|
2020-08-12 15:59:42 +02:00
|
|
|
if ( PLUGIN_WEIGHT )
|
|
|
|
file( APPEND ${_file} "weight: ${PLUGIN_WEIGHT}\n" )
|
|
|
|
endif()
|
2017-07-05 17:51:43 +02:00
|
|
|
endif()
|
|
|
|
|
2018-06-15 13:19:02 +02:00
|
|
|
if ( NOT PLUGIN_NO_INSTALL )
|
|
|
|
install( FILES ${CMAKE_CURRENT_BINARY_DIR}/${PLUGIN_DESC_FILE}
|
|
|
|
DESTINATION ${PLUGIN_DESTINATION} )
|
2014-08-05 18:18:57 +02:00
|
|
|
|
2020-08-05 00:51:08 +02:00
|
|
|
set( _warned_config OFF )
|
2018-06-27 19:20:52 +02:00
|
|
|
foreach( PLUGIN_CONFIG_FILE ${PLUGIN_CONFIG_FILES} )
|
2022-09-09 22:26:27 +02:00
|
|
|
if( ${CMAKE_CURRENT_SOURCE_DIR}/${PLUGIN_CONFIG_FILE} IS_NEWER_THAN ${CMAKE_CURRENT_BINARY_DIR}/${PLUGIN_CONFIG_FILE} )
|
2020-08-05 00:51:08 +02:00
|
|
|
configure_file( ${PLUGIN_CONFIG_FILE} ${PLUGIN_CONFIG_FILE} COPYONLY )
|
|
|
|
else()
|
|
|
|
message( " ${BoldYellow}Not updating${ColorReset} ${PLUGIN_CONFIG_FILE}" )
|
|
|
|
set( _warned_config ON )
|
|
|
|
endif()
|
2023-11-09 21:52:12 +01:00
|
|
|
if(INSTALL_CONFIG)
|
|
|
|
install(FILES ${CMAKE_CURRENT_BINARY_DIR}/${PLUGIN_CONFIG_FILE} DESTINATION ${PLUGIN_DATA_DESTINATION})
|
|
|
|
endif()
|
2018-06-27 19:20:52 +02:00
|
|
|
endforeach()
|
2020-08-05 00:51:08 +02:00
|
|
|
if ( _warned_config )
|
|
|
|
message( "" )
|
|
|
|
endif()
|
2016-11-21 01:32:04 +01:00
|
|
|
endif()
|
2024-02-18 23:30:50 +01:00
|
|
|
|
|
|
|
set(${NAME}_TARGET ${target} PARENT_SCOPE)
|
2014-06-11 13:37:10 +02:00
|
|
|
endfunction()
|