Added the ability for template files to be found side by side the original file

which allows template flavor suffix to be added to package lists as well as most
any other file type now.

- created a new function to check if a file exists that was refactored out od
  the templateFile function
- Added elementIn function which checks if an element exists within an array
This commit is contained in:
Jason Mehring 2015-03-15 14:56:08 -04:00
parent f1b1258631
commit 87aad36262
No known key found for this signature in database
GPG Key ID: 1BB9B1FB5A4C6DAD

View File

@ -164,6 +164,19 @@ setArrayAsGlobal() {
} }
# ------------------------------------------------------------------------------
# Checks if the passed element exists in passed array
# $1: Element to check for
# $2: Array to check for element in
#
# Returns 0 if True, or 1 if False
# ------------------------------------------------------------------------------
elementIn () {
local element
for element in "${@:2}"; do [[ "$element" == "$1" ]] && return 0; done
return 1
}
# ------------------------------------------------------------------------------ # ------------------------------------------------------------------------------
# Spilts the path and returns an array of parts # Spilts the path and returns an array of parts
# #
@ -231,6 +244,15 @@ templateDir() {
echo "${dir}" echo "${dir}"
} }
exists() {
filename="${1}"
if [ -e "${filename}" ]; then
echo "${filename}"
return 0
fi
return 1
}
templateFile() { templateFile() {
local file="$1" local file="$1"
local suffix="$2" local suffix="$2"
@ -239,15 +261,35 @@ templateFile() {
splitPath "${file}" path_parts splitPath "${file}" path_parts
# Append suffix to filename (before extension) # No template flavor
if [ "${suffix}" ]; then if [ "X{template_flavor}" == "X" ]; then
file="${template_dir}/${path_parts[base]}_${suffix}${path_parts[dotext]}" if [ -e "${file}" ]; then
else echo "${file}"
file="${template_dir}/${path_parts[base]}${path_parts[dotext]}" fi
return
fi fi
if [ -f "${file}" ]; then # Locate file in directory named after flavor
echo "${file}" if [ "${suffix}" ]; then
# Append suffix to filename (before extension)
# (../SCRIPTSDIR/minimal/packages_qubes_suffix.list)
exists "${template_dir}/${path_parts[base]}_${suffix}${path_parts[dotext]}" || true
# (../SCRIPTSDIR/minimal/packages_qubes_minimal_suffix.list)
exists "${template_dir}/${path_parts[base]}_${suffix}_${template_flavor}${path_parts[dotext]}" || true
# (../SCRIPTSDIR/packages_qubes_minimal_suffix.list)
exists "${SCRIPTSDIR}/${path_parts[base]}_${suffix}_${template_flavor}${path_parts[dotext]}" || true
else
# (../SCRIPTSDIR/minimal/packages_qubes.list)
exists "${template_dir}/${path_parts[base]}${path_parts[dotext]}" || true
# (../SCRIPTSDIR/minimal/packages_qubes_minimal.list)
exists "${template_dir}/${path_parts[base]}_${template_flavor}${path_parts[dotext]}" || true
# (../SCRIPTSDIR/packages_qubes_minimal.list)
exists "${SCRIPTSDIR}/${path_parts[base]}_${template_flavor}${path_parts[dotext]}" || true
fi fi
} }