mirror of
git://sourceware.org/git/lvm2.git
synced 2024-12-21 13:34:40 +03:00
lvmconfig: fix lvmconfig --type diff to display complete diff if config cascade used
If configuration consists of several sources in config cascade ("config cascade" defined in man lvmconfig(8)), lvmconfig displayed only difference from defaults of the topmost config in the cascade. Fix lvmconfig to display complete difference, considering all the configuration in the cascade. For example, before this patch: (use_lvmetad=0 set in lvm.conf which differs from defaults) $ lvmconfig --type diff global { use_lvmetad=0 } (compact_output=1 set on cmd line) $ lvmconfig --type diff --config report/compact_output=1 report { compact_output=1 } (headings=0 set in profile) $ lvmconfig --type diff --commandprofile test report { headings=0 } (difference in topmost configuration source is displayed) $ lvmconfig --type diff --commandprofile test --config report/compact_output=1 report { compact_output=1 } With this patch applied (the config cascade is merged before looking for difference from defaults in configuration): $ lvmconfig --type diff global { use_lvmetad=0 } $ lvmconfig --type diff --config report/compact_output=1 report { compact_output=1 } global { use_lvmetad=0 } $ lvmconfig --type diff --profile test report { headings=0 } global { use_lvmetad=0 } $ lvmconfig --type diff --profile test --config report/compact_output=1 report { headings=0 compact_output=1 } global { use_lvmetad=0 }
This commit is contained in:
parent
fc37ee63c0
commit
687bc5cecf
@ -1,5 +1,6 @@
|
||||
Version 2.02.155 -
|
||||
================================
|
||||
Fix lvmconfig --type diff to display complete diff if config cascade used.
|
||||
Automatically filter out partitioned loop devices with partscan (losetup -P).
|
||||
Fix lvm devtypes internal error if -S used with field name from pvs/vgs/lvs.
|
||||
When reporting Data%,Snap%,Meta%,Cpy%Sync use single ioctl per LV.
|
||||
|
@ -210,7 +210,7 @@ int dumpconfig(struct cmd_context *cmd, int argc, char **argv)
|
||||
* Set the 'cft' to work with based on whether we need the plain
|
||||
* config tree or merged config tree cascade if --mergedconfig is used.
|
||||
*/
|
||||
if ((arg_count(cmd, mergedconfig_ARG) || !strcmp(type, "full")) && cmd->cft->cascade) {
|
||||
if ((arg_count(cmd, mergedconfig_ARG) || !strcmp(type, "full") || !strcmp(type, "diff")) && cmd->cft->cascade) {
|
||||
if (!_merge_config_cascade(cmd, cmd->cft, &cft)) {
|
||||
log_error("Failed to merge configuration.");
|
||||
r = ECMD_FAILED;
|
||||
|
Loading…
Reference in New Issue
Block a user