return ${EXIT_ERROR}
}
+file_to_log() {
+ local level="${1}"
+ assert isset level
+
+ local file="${2}"
+ assert file_exists "${file}"
+
+ local line
+ while read line; do
+ log "${level}" "${line}"
+ done < "${file}"
+}
+
make_directory() {
local path="${1}"
- mkdir -p "${path}"
+ # Exit silently when directory already exists
+ if [ -d "${path}" ]; then
+ return ${EXIT_OK}
+ fi
+
+ if ! mkdir -p "${path}"; then
+ log ERROR "Could not create directory ${path}"
+ return ${EXIT_ERROR}
+ fi
+
+ log DEBUG "Created directory ${path}"
+ return ${EXIT_OK}
}
make_parent_directory() {
}
cmd_exec() {
- local cmd=$@
+ local cmd=( "$@" )
log DEBUG "Exec'ing command: ${cmd}"
- exec ${cmd}
+ exec "${cmd[@]}"
log ERROR "Could not exec-ute: ${cmd}"
exit ${EXIT_ERROR}
return ${EXIT_FALSE}
}
+contains_non_ascii_characters() {
+ local value="$@"
+
+ # Strip away all ASCII characters
+ local non_ascii="${value//[[:ascii:]]/}"
+
+ if isset non_ascii; then
+ return ${EXIT_TRUE}
+ fi
+
+ return ${EXIT_FALSE}
+}
+
string_match() {
local match=${1}
local string=${2}
return ${EXIT_ERROR}
fi
+ # Create destination directory if it doesn't exist, yet
+ if ! make_parent_directory "${dst}"; then
+ return ${EXIT_ERROR}
+ fi
+
if ! fread "${src}" > "${dst}"; then
log ERROR "Could not copy data from ${src} to ${dst}"
return ${EXIT_ERROR}
tr -sc [:alnum:] "-" < <(printf "%s" "${string,,}")
}
+
+get_driver_from_path() {
+ local path="${1}"
+
+ if file_exists "${path}"; then
+ # Resolve symlink
+ local driver="$(readlink "${path}")"
+
+ # Print module name
+ basename "${driver}"
+ return ${EXIT_OK}
+ fi
+
+ return ${EXIT_ERROR}
+}