blob: b44e79aa3dcad568877b595821c2f8376b42007f [file] [log] [blame]
Dean Troyer893e6632013-09-13 15:05:51 -05001# lib/config - Configuration file manipulation functions
2
3# These functions have no external dependencies and the following side-effects:
4#
5# CONFIG_AWK_CMD is defined, default is ``awk``
6
7# Meta-config files contain multiple INI-style configuration files
8# using a specific new section header to delimit them:
9#
10# [[group-name|file-name]]
11#
12# group-name refers to the group of configuration file changes to be processed
Sean Dague537d4022013-10-22 07:43:22 -040013# at a particular time. These are called phases in ``stack.sh`` but
Dean Troyer893e6632013-09-13 15:05:51 -050014# group here as these functions are not DevStack-specific.
15#
16# file-name is the destination of the config file
17
18# Save trace setting
19C_XTRACE=$(set +o | grep xtrace)
20set +o xtrace
21
22
23# Allow the awk command to be overridden on legacy platforms
24CONFIG_AWK_CMD=${CONFIG_AWK_CMD:-awk}
25
26# Get the section for the specific group and config file
27# get_meta_section infile group configfile
Ian Wienandaee18c72014-02-21 15:35:08 +110028function get_meta_section {
Dean Troyer893e6632013-09-13 15:05:51 -050029 local file=$1
30 local matchgroup=$2
31 local configfile=$3
32
33 [[ -r $file ]] || return 0
34 [[ -z $configfile ]] && return 0
35
36 $CONFIG_AWK_CMD -v matchgroup=$matchgroup -v configfile=$configfile '
37 BEGIN { group = "" }
Isaku Yamahatabff00142013-12-20 11:55:08 +090038 /^\[\[.+\|.*\]\]/ {
Dean Troyer893e6632013-09-13 15:05:51 -050039 if (group == "") {
40 gsub("[][]", "", $1);
41 split($1, a, "|");
42 if (a[1] == matchgroup && a[2] == configfile) {
43 group=a[1]
44 }
45 } else {
46 group=""
47 }
48 next
49 }
50 {
51 if (group != "")
52 print $0
53 }
54 ' $file
55}
56
57
58# Get a list of config files for a specific group
59# get_meta_section_files infile group
Ian Wienandaee18c72014-02-21 15:35:08 +110060function get_meta_section_files {
Dean Troyer893e6632013-09-13 15:05:51 -050061 local file=$1
62 local matchgroup=$2
63
64 [[ -r $file ]] || return 0
65
66 $CONFIG_AWK_CMD -v matchgroup=$matchgroup '
Sean Dague537d4022013-10-22 07:43:22 -040067 /^\[\[.+\|.*\]\]/ {
68 gsub("[][]", "", $1);
69 split($1, a, "|");
70 if (a[1] == matchgroup)
71 print a[2]
72 }
Dean Troyer893e6632013-09-13 15:05:51 -050073 ' $file
74}
75
76
77# Merge the contents of a meta-config file into its destination config file
78# If configfile does not exist it will be created.
79# merge_config_file infile group configfile
Ian Wienandaee18c72014-02-21 15:35:08 +110080function merge_config_file {
Dean Troyer893e6632013-09-13 15:05:51 -050081 local file=$1
82 local matchgroup=$2
83 local configfile=$3
84
Ian Wienande2c9fee2014-09-26 09:42:11 +100085 # note in the awk below, \x27 is ascii for ' -- this avoids
86 # having to do nasty quoting games
Dean Troyer893e6632013-09-13 15:05:51 -050087 get_meta_section $file $matchgroup $configfile | \
88 $CONFIG_AWK_CMD -v configfile=$configfile '
89 BEGIN { section = "" }
90 /^\[.+\]/ {
91 gsub("[][]", "", $1);
92 section=$1
93 next
94 }
95 /^ *\#/ {
96 next
97 }
Dean Troyer2ac8b3f2013-12-04 17:20:28 -060098 /^[^ \t]+/ {
Fergal Mc Carthycc87c282014-10-09 16:16:42 -040099 # get offset of first '=' in $0
100 eq_idx = index($0, "=")
101 # extract attr & value from $0
102 attr = substr($0, 1, eq_idx - 1)
103 value = substr($0, eq_idx + 1)
104 # only need to strip trailing whitespace from attr
105 sub(/[ \t]*$/, "", attr)
106 # need to strip leading & trailing whitespace from value
107 sub(/^[ \t]*/, "", value)
108 sub(/[ \t]*$/, "", value)
109 print "iniset " configfile " " section " " attr " \x27" value "\x27"
Dean Troyer893e6632013-09-13 15:05:51 -0500110 }
111 ' | while read a; do eval "$a"; done
112
113}
114
115
116# Merge all of the files specified by group
117# merge_config_group infile group [group ...]
Ian Wienandaee18c72014-02-21 15:35:08 +1100118function merge_config_group {
Dean Troyer893e6632013-09-13 15:05:51 -0500119 local localfile=$1; shift
120 local matchgroups=$@
121
122 [[ -r $localfile ]] || return 0
123
Dean Troyerb1e3d0f2014-07-25 14:57:54 -0500124 local configfile group
Dean Troyer893e6632013-09-13 15:05:51 -0500125 for group in $matchgroups; do
126 for configfile in $(get_meta_section_files $localfile $group); do
Ryota MIBU410f5c02014-04-04 02:00:31 +0900127 if [[ -d $(dirname $(eval "echo $configfile")) ]]; then
Dean Troyer893e6632013-09-13 15:05:51 -0500128 merge_config_file $localfile $group $configfile
129 fi
130 done
131 done
132}
133
134
135# Restore xtrace
136$C_XTRACE
137
138# Local variables:
139# mode: shell-script
140# End: