sculpt: integration of optional presets

With the new 'presets:' tag, .sculpt files can now refer to deploy
configurations to be integrated in the presets/ subdirectory of the
config file system. Those files can thereby be used as preconfigured
system scenarios. Such a preconfigured scenario can be loaded at
runtime by copying the preset file to config/deploy.

Issue #4731
This commit is contained in:
Norman Feske 2023-01-10 13:42:47 +01:00 committed by Christian Helmuth
parent a7a5c5ce54
commit 88becbe29d

View File

@ -656,6 +656,9 @@ install_config {
foreach subdir { launcher depot managed keyboard } { foreach subdir { launcher depot managed keyboard } {
file mkdir [file join [initial_config_dir] $subdir] } file mkdir [file join [initial_config_dir] $subdir] }
if {[llength [ingredients_of_type presets]] > 0} {
file mkdir [file join [initial_config_dir] presets] }
# configs that are managed by the sculpt manager if absent # configs that are managed by the sculpt manager if absent
set optional_configs { set optional_configs {
fonts fonts
@ -696,16 +699,24 @@ foreach config $required_configs {
copy_file $from $to copy_file $from $to
} }
# selection of depot users (pubkey and download files) and launchers # selection of depot users (pubkey and download files), launchers, and presets
foreach ingredient [ingredients_of_type launcher] { foreach ingredient [ingredients_of_type launcher] {
check_xml_syntax [ingredient_path launcher $ingredient] } check_xml_syntax [ingredient_path launcher $ingredient] }
foreach ingredient [ingredients_of_type presets] {
check_xml_syntax [ingredient_path deploy $ingredient] }
foreach type { depot launcher } { foreach type { depot launcher } {
foreach ingredient [ingredients_of_type $type] { foreach ingredient [ingredients_of_type $type] {
set from [ingredient_path $type $ingredient] set from [ingredient_path $type $ingredient]
set to [file join [initial_config_dir] $type $ingredient] set to [file join [initial_config_dir] $type $ingredient]
file copy $from $to } } file copy $from $to } }
foreach ingredient [ingredients_of_type presets] {
set from [ingredient_path deploy $ingredient]
set to [file join [initial_config_dir] presets $ingredient]
file copy $from $to }
copy_file [genode_dir]/repos/gems/recipes/pkg/sculpt/README [initial_config_file README] copy_file [genode_dir]/repos/gems/recipes/pkg/sculpt/README [initial_config_file README]
copy_file [genode_dir]/repos/gems/run/sculpt/vimrc [initial_config_file vimrc] copy_file [genode_dir]/repos/gems/run/sculpt/vimrc [initial_config_file vimrc]
@ -792,6 +803,12 @@ proc referenced_pkg_values { } {
lappend values {*}[pkg_attribute_values $path launcher] lappend values {*}[pkg_attribute_values $path launcher]
} }
# scan presets
foreach preset [ingredients_of_type presets] {
set path [file join [initial_config_dir] presets $preset]
lappend values {*}[pkg_attribute_values $path config/start]
}
# scan deploy config # scan deploy config
lappend values {*}[pkg_attribute_values [initial_config_file deploy] config/start] lappend values {*}[pkg_attribute_values [initial_config_file deploy] config/start]
@ -863,7 +880,7 @@ proc current_pkg { pkg } { return $pkg/[_current_depot_archive_version pkg $pkg]
# #
# Supplement file with versioned pkg archive paths # Supplement file with versioned pkg archive paths
# #
# \path deploy config or launcher to augment # \path deploy config, or launcher, or preset to augment
# \node XML node type containing the 'pkg' attribute to modify # \node XML node type containing the 'pkg' attribute to modify
# #
# Each matching XML node is inspected regarding its 'pkg' attribute. If its # Each matching XML node is inspected regarding its 'pkg' attribute. If its
@ -884,7 +901,7 @@ proc augment_pkg_versions { path node } {
regsub $pattern $content "$head$pkg_path$tail" content regsub $pattern $content "$head$pkg_path$tail" content
} }
# write back the filtered launcher snippet # write back the filtered launcher snippet, deploy config, or preset
set fd [open $path w] set fd [open $path w]
puts $fd $content puts $fd $content
close $fd close $fd
@ -895,13 +912,21 @@ proc augment_pkg_versions { path node } {
foreach launcher [ingredients_of_type launcher] { foreach launcher [ingredients_of_type launcher] {
augment_pkg_versions [file join [initial_config_dir] launcher $launcher] "launcher" } augment_pkg_versions [file join [initial_config_dir] launcher $launcher] "launcher" }
# presets
foreach preset [ingredients_of_type presets] {
augment_pkg_versions [file join [initial_config_dir] presets $preset] "start" }
# deploy config # deploy config
augment_pkg_versions [initial_config_file deploy] "start" augment_pkg_versions [initial_config_file deploy] "start"
# update arch attribute of deploy config and presets
proc augment_arch_attribute { file } {
exec sed -i "/config/s/arch=\"\"/arch=\"[depot_spec]\"/" $file }
# update arch attribute of deploy config foreach preset [ingredients_of_type presets] {
exec sed -i "/config/s/arch=\"\"/arch=\"[depot_spec]\"/" [initial_config_file deploy] augment_arch_attribute [file join [initial_config_dir] presets $preset] }
augment_arch_attribute [initial_config_file deploy]
## ##