source: common/func_validate_configs.sh@ c58f330

experimental
Last change on this file since c58f330 was c58f330, checked in by Manuel Canales Esparcia <manuel@…>, 19 years ago

Merged r2597 from trunk.

  • Property mode set to 100644
File size: 11.3 KB
RevLine 
[c0aeabe]1# $Id$
[3bbf6d5]2
[b1c7734]3#----------------------------#
4validate_target() { #
5#----------------------------#
[3c61617]6 local -r ERROR_MSG_pt1='The variable \"${L_arrow}TARGET${R_arrow}\" value ${L_arrow}${BOLD}${TARGET}${R_arrow} is invalid for the ${L_arrow}${BOLD}${ARCH}${R_arrow} architecture'
7 local -r ERROR_MSG_pt2=' check the config file ${BOLD}${GREEN}\<$(echo $PROGNAME | tr [a-z] [A-Z])/config\> or \<common/config\>${OFF}'
8
9 local -r PARAM_VALS='TARGET: ${L_arrow}${BOLD}${TARGET}${OFF}${R_arrow}'
10 local -r PARAM_VALS2='TARGET32: ${L_arrow}${BOLD}${TARGET32}${OFF}${R_arrow}'
11
12 write_error_and_die() {
13 echo -e "\n${DD_BORDER}"
14 echo -e "`eval echo ${ERROR_MSG_pt1}`" >&2
15 echo -e "`eval echo ${ERROR_MSG_pt2}`" >&2
16 echo -e "${DD_BORDER}\n"
17 exit 1
18 }
19
20 if [[ ! "${TARGET32}" = "" ]]; then
[3051f95]21 echo -e "`eval echo $PARAM_VALS2`"
[3c61617]22 fi
[3051f95]23 echo -e "`eval echo $PARAM_VALS`"
[3c61617]24
25 case "${ARCH}" in
[3e0594f]26 "x86") [[ "${TARGET}" = "i486-pc-linux-gnu" ]] && return
27 [[ "${TARGET}" = "i586-pc-linux-gnu" ]] && return
28 [[ "${TARGET}" = "i686-pc-linux-gnu" ]] && return
[3c61617]29 ;;
[3e0594f]30 "ppc") [[ "${TARGET}" = "powerpc-unknown-linux-gnu" ]] && return
[3c61617]31 ;;
[3e0594f]32 "mips") [[ "${TARGET}" = "mipsel-unknown-linux-gnu" ]] && return
33 [[ "${TARGET}" = "mips-unknown-linux-gnu" ]] && return
[3c61617]34 ;;
[3e0594f]35 "sparc") [[ "${TARGET}" = "sparcv9-unknown-linux-gnu" ]] && return
[3c61617]36 ;;
[3e0594f]37 "x86_64-64") [[ "${TARGET}" = "x86_64-unknown-linux-gnu" ]] && return
[3c61617]38 ;;
39 "mips64-64") [[ "${TARGET}" = "mipsel-unknown-linux-gnu" ]] && return
40 [[ "${TARGET}" = "mips-unknown-linux-gnu" ]] && return
41 ;;
42 "sparc64-64") [[ "${TARGET}" = "sparc64-unknown-linux-gnu" ]] && return
43 ;;
44 "alpha") [[ "${TARGET}" = "alpha-unknown-linux-gnu" ]] && return
45 ;;
46 "x86_64") [[ "${TARGET}" = "x86_64-unknown-linux-gnu" ]] &&
47 [[ "${TARGET32}" = "i686-pc-linux-gnu" ]] && return
48 ;;
49 "mips64") [[ "${TARGET}" = "mipsel-unknown-linux-gnu" ]] &&
50 [[ "${TARGET32}" = "mipsel-unknown-linux-gnu" ]] && return
[ffd482f]51
[3c61617]52 [[ "${TARGET}" = "mips-unknown-linux-gnu" ]] &&
53 [[ "${TARGET32}" = "mips-unknown-linux-gnu" ]] && return
54 ;;
[3e0594f]55 "sparc64") [[ "${TARGET}" = "sparc64-unknown-linux-gnu" ]] &&
56 [[ "${TARGET32}" = "sparcv9-unknown-linux-gnu" ]] && return
[3c61617]57 ;;
[3e0594f]58 "ppc64") [[ "${TARGET}" = "powerpc64-unknown-linux-gnu" ]] &&
59 [[ "${TARGET32}" = "powerpc-unknown-linux-gnu" ]] && return
[3c61617]60 ;;
61 *) write_error_and_die
[ffd482f]62 ;;
[3c61617]63 esac
[3e0594f]64
65 # If you end up here then there was an error SO...
66 write_error_and_die
[3c61617]67}
68
69
[22670f4]70#----------------------------#
[b1c7734]71validate_config() { # Are the config values sane (within reason)
[22670f4]72#----------------------------#
73: <<inline_doc
[3bbf6d5]74 Validates the configuration parameters. The global var PROGNAME selects the
[22670f4]75 parameter list.
[3bbf6d5]76
[3051f95]77 input vars: none
[22670f4]78 externals: color constants
79 PROGNAME (lfs,clfs,hlfs,blfs)
80 modifies: none
81 returns: nothing
[4612459]82 on error: write text to console and dies
[22670f4]83 on success: write text to console and returns
84inline_doc
85
[51a0bb1]86 # First internal variables, then the ones that change the book's flavour, and lastly system configuration variables
[2f0a537]87 local -r blfs_PARAM_LIST="BOOK BUILDDIR SRC_ARCHIVE HPKG DEPEND TEST"
[9e4b9a1]88 local -r hlfs_PARAM_LIST="BOOK BUILDDIR SRC_ARCHIVE HPKG RUNMAKE MODEL GRSECURITY_HOST TEST REPORT COMPARE RUN_ICA RUN_FARCE ITERATIONS STRIP FSTAB CONFIG KEYMAP PAGE TIMEZONE LANG LC_ALL"
89 local -r clfs_PARAM_LIST="BOOK BUILDDIR SRC_ARCHIVE HPKG RUNMAKE METHOD ARCH TARGET TEST REPORT COMPARE RUN_ICA RUN_FARCE ITERATIONS STRIP FSTAB BOOT_CONFIG CONFIG KEYMAP VIMLANG PAGE TIMEZONE LANG"
90 local -r lfs_PARAM_LIST="BOOK BUILDDIR SRC_ARCHIVE HPKG RUNMAKE TEST REPORT COMPARE RUN_ICA RUN_FARCE ITERATIONS STRIP FSTAB CONFIG VIMLANG PAGE TIMEZONE LANG"
[22670f4]91
[3c61617]92 local -r ERROR_MSG_pt1='The variable \"${L_arrow}${config_param}${R_arrow}\" value ${L_arrow}${BOLD}${!config_param}${R_arrow} is invalid,'
93 local -r ERROR_MSG_pt2=' check the config file ${BOLD}${GREEN}\<$(echo $PROGNAME | tr [a-z] [A-Z])/config\> or \<common/config\>${OFF}'
[22670f4]94 local -r PARAM_VALS='${config_param}: ${L_arrow}${BOLD}${!config_param}${OFF}${R_arrow}'
95
96 local PARAM_LIST=
97 local config_param
98 local validation_str
[7a755b9]99 local save_param
[9e4b9a1]100
[22670f4]101 write_error_and_die() {
102 echo -e "\n${DD_BORDER}"
[3c61617]103 echo -e "`eval echo ${ERROR_MSG_pt1}`" >&2
104 echo -e "`eval echo ${ERROR_MSG_pt2}`" >&2
[22670f4]105 echo -e "${DD_BORDER}\n"
106 exit 1
107 }
108
[b1c7734]109 validate_against_str() {
[cc82e37]110 # This is the 'regexp' test available in bash-3.0..
111 # using it as a poor man's test for substring
[3051f95]112 echo -e "`eval echo $PARAM_VALS`"
[b1c7734]113 if [[ ! "$1" =~ "x${!config_param}x" ]] ; then
[cc82e37]114 # parameter value entered is no good
115 write_error_and_die
116 fi
117 }
[ffd482f]118
[b1c7734]119 validate_file() {
120 # For parameters ending with a '+' failure causes a warning message only
121 echo -n "`eval echo $PARAM_VALS`"
122 while test $# -gt 0 ; do
123 case $1 in
124 # Failures caused program exit
125 "-z") [[ -z "${!config_param}" ]] && echo "${tab_}<-- NO file name given" && write_error_and_die ;;
126 "-e") [[ ! -e "${!config_param}" ]] && echo "${tab_}<-- file does not exist" && write_error_and_die ;;
127 "-s") [[ ! -s "${!config_param}" ]] && echo "${tab_}<-- file has zero bytes" && write_error_and_die ;;
128 "-r") [[ ! -r "${!config_param}" ]] && echo "${tab_}<-- no read permission " && write_error_and_die ;;
129 "-w") [[ ! -w "${!config_param}" ]] && echo "${tab_}<-- no write permission" && write_error_and_die ;;
130 "-x") [[ ! -x "${!config_param}" ]] && echo "${tab_}<-- file cannot be executed" && write_error_and_die ;;
131 # Warning messages only
132 "-z+") [[ -z "${!config_param}" ]] && echo && return ;;
133 esac
134 shift 1
135 done
136 echo
137 }
[cc82e37]138
[b1c7734]139 validate_dir() {
140 # For parameters ending with a '+' failure causes a warning message only
141 echo -n "`eval echo $PARAM_VALS`"
142 while test $# -gt 0 ; do
143 case $1 in
144 "-z") [[ -z "${!config_param}" ]] && echo "${tab_}NO directory name given" && write_error_and_die ;;
145 "-d") [[ ! -d "${!config_param}" ]] && echo "${tab_}This is NOT a directory" && write_error_and_die ;;
146 "-w") if [[ ! -w "${!config_param}" ]]; then
147 echo "${nl_}${DD_BORDER}"
148 echo "${tab_}${RED}You do not have ${L_arrow}write${R_arrow}${RED} access to the directory${OFF}"
149 echo "${tab_}${BOLD}${!config_param}${OFF}"
150 echo "${DD_BORDER}${nl_}"
151 exit 1
152 fi ;;
153 # Warnings only
154 "-w+") if [[ ! -w "${!config_param}" ]]; then
155 echo "${nl_}${DD_BORDER}"
156 echo "${tab_}WARNING-- You do not have ${L_arrow}write${R_arrow} access to the directory${OFF}"
157 echo "${tab_} -- ${BOLD}${!config_param}${OFF}"
158 echo "${DD_BORDER}"
159 fi ;;
160 "-z+") [[ -z "${!config_param}" ]] && echo "${tab_}<-- NO directory name given" && return
161 esac
162 shift 1
163 done
164 echo
165 }
[cc82e37]166
[b1c7734]167 set +e
168 PARAM_GROUP=${PROGNAME}_PARAM_LIST
169 for config_param in ${!PARAM_GROUP}; do
170 # This is a tricky little piece of code.. executes a cmd string.
171 case $config_param in
172 BUILDDIR) # We cannot have an <empty> or </> root mount point
173 echo -e "`eval echo $PARAM_VALS`"
174 [[ "xx x/x" =~ "x${!config_param}x" ]] &&
175 write_error_and_die
176 ;;
[c58f330]177 TIMEZONE) echo -e "`eval echo $PARAM_VALS`" ;;
[b1c7734]178
179 # Validate general parameters..
180 HPKG) validate_against_str "x0x x1x" ;;
181 RUNMAKE) validate_against_str "x0x x1x" ;;
[9e4b9a1]182 REPORT) validate_against_str "x0x x1x"
[2f109c6]183 if [[ "${!config_param}" = "1" ]]; then
184 if [[ `type -p bc` ]]; then
185 continue
186 else
187 echo -e " ${BOLD}The bc binary was not found${OFF}"
188 echo -e " The SBU and disk usage report creation will be skiped"
189 REPORT=0
190 continue
191 fi
[9e4b9a1]192 fi ;;
[b1c7734]193 COMPARE) if [[ ! "$COMPARE" = "1" ]]; then
194 validate_against_str "x0x x1x"
195 else
196 if [[ ! "${RUN_ICA}" = "1" ]] && [[ ! "${RUN_FARCE}" = "1" ]]; then
197 echo "${nl_}${DD_BORDER}"
198 echo "You have elected to analyse your build but have failed to select a tool." >&2
199 echo "Edit /common/config and set ${L_arrow}${BOLD}RUN_ICA${R_arrow} and/or ${L_arrow}${BOLD}RUN_FARCE${R_arrow} to the required values" >&2
200 echo "${DD_BORDER}${nl_}"
201 exit 1
202 fi
203 fi ;;
204 RUN_ICA) [[ "$COMPARE" = "1" ]] && validate_against_str "x0x x1x" ;;
205 RUN_FARCE) [[ "$COMPARE" = "1" ]] && validate_against_str "x0x x1x" ;;
206 ITERATIONS) [[ "$COMPARE" = "1" ]] && validate_against_str "x2x x3x x4x x5x" ;;
207 TEST) validate_against_str "x0x x1x x2x x3x" ;;
208 STRIP) validate_against_str "x0x x1x" ;;
209 VIMLANG) validate_against_str "x0x x1x" ;;
210 DEPEND) validate_against_str "x0x x1x x2x" ;;
211 MODEL) validate_against_str "xglibcx xuclibcx" ;;
212 PAGE) validate_against_str "xletterx xA4x" ;;
213 METHOD) validate_against_str "xchrootx xbootx" ;;
[fe187bf]214 ARCH) validate_against_str "xx86x xx86_64x xx86_64-64x xsparcx xsparc64x xsparc64-64x xmipsx xmips64x xmips64-64x xppcx xppc64x xalphax" ;;
[b1c7734]215 TARGET) validate_target ;;
216 GRSECURITY_HOST) validate_against_str "x0x x1x" ;;
217
[760c2f1]218 # BOOK validation. Very ugly, need be fixed
219 BOOK) if [[ "${WC}" = "1" ]] ; then
220 validate_dir -z -d
221 else
[c58f330]222 validate_against_str "x${PROGNAME}-developmentx"
223 fi ;;
[760c2f1]224
[b1c7734]225 # Validate directories, testable states:
226 # fatal -z -d -w,
227 # warning -z+ -w+
228 SRC_ARCHIVE) validate_dir -z+ -d -w+ ;;
229
230 # Validate files, testable states:
231 # fatal -z -e -s -w -x -r,
232 # warning -z+
233 FSTAB) validate_file -z+ -e -s ;;
234 CONFIG) validate_file -z+ -e -s ;;
235 BOOT_CONFIG) [[ "${METHOD}" = "boot" ]] && validate_file -z -e -s ;;
236
237 # Treatment of 'special' parameters
238 LANG | \
239 LC_ALL) # See it the locale values exist on this machine
240 echo -n "`eval echo $PARAM_VALS`"
241 [[ -z "${!config_param}" ]] &&
242 echo " -- Variable $config_param cannot be empty!" &&
243 write_error_and_die
244 [[ ! "`locale -a | grep -c ${!config_param}`" > 0 ]] &&
245 write_error_and_die
246 echo
247 ;;
[b12abe1]248 KEYMAP) echo "`eval echo $PARAM_VALS`"
249 save_param=${KEYMAP}
[7a755b9]250 [[ ! "${!config_param}" = "none" ]] &&
[b1c7734]251 KEYMAP="/usr/share/kbd/keymaps/${KEYMAP}" &&
252 validate_file -z -e -s
[7a755b9]253 KEYMAP=${save_param}
[b1c7734]254 ;;
255 esac
[22670f4]256 done
257 set -e
[cc82e37]258 echo "$tab_***${BOLD}${GREEN} ${PARAM_GROUP%%_*T} config parameters look good${OFF} ***"
[22670f4]259}
Note: See TracBrowser for help on using the repository browser.