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}"
local assertion="$@"
if ! ${assertion}; then
- error_log "Assertion '${assertion}' failed."
backtrace
- exit ${EXIT_ERROR_ASSERT}
+
+ # End the program here
+ abort "Assertion failed: ${assertion}"
fi
return ${EXIT_OK}
}
+# Ends the program immediately without cleaning up
+abort() {
+ local msg="$@"
+
+ # Print message
+ if isset msg; then
+ log ERROR "${msg}"
+ fi
+
+ exit ${EXIT_ERROR_ASSERT}
+}
+
# This function checks, if the given argument is an assert error
# exit code. If this is the case, the script will halt immediately.
assert_check_retval() {
}
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}