mirror of
https://github.com/Telecominfraproject/OpenCellular.git
synced 2025-12-07 16:35:44 +00:00
This makes the output easier to follow when multiple scripts are being run. BRANCH=None BUG=chromium:714598 TEST=signing images still works Change-Id: I072994dd07cf559a60e8a139eaeaf000cbbf72e3 Reviewed-on: https://chromium-review.googlesource.com/497301 Commit-Ready: Mike Frysinger <vapier@chromium.org> Tested-by: Mike Frysinger <vapier@chromium.org> Reviewed-by: David Riley <davidriley@chromium.org>
107 lines
2.8 KiB
Bash
107 lines
2.8 KiB
Bash
#!/bin/bash
|
|
#
|
|
# Copyright (c) 2011 The Chromium OS Authors. All rights reserved.
|
|
# Use of this source code is governed by a BSD-style license that can be
|
|
# found in the LICENSE file.
|
|
|
|
. "$(dirname "$0")/common_minimal.sh"
|
|
CROS_LOG_PREFIX="${PROG}: "
|
|
|
|
# Array of actions that are executed during the clean up process.
|
|
declare -a cleanup_actions
|
|
|
|
# Adds an action to be executed during the clean up process.
|
|
# Actions are executed in the reverse order of when they were added.
|
|
# ARGS: ACTION
|
|
add_cleanup_action() {
|
|
cleanup_actions[${#cleanup_actions[*]}]=$1
|
|
}
|
|
|
|
# Performs the latest clean up action and removes it from the list.
|
|
perform_latest_cleanup_action() {
|
|
local num_actions=${#cleanup_actions[*]}
|
|
if [ ${num_actions} -gt 0 ]; then
|
|
eval "${cleanup_actions[$num_actions-1]}" > /dev/null 2>&1
|
|
unset cleanup_actions[$num_actions-1]
|
|
fi
|
|
}
|
|
|
|
# Performs clean up by executing actions in the cleanup_actions array in
|
|
# reversed order.
|
|
cleanup() {
|
|
set +e
|
|
|
|
while [ ${#cleanup_actions[*]} -gt 0 ]; do
|
|
perform_latest_cleanup_action
|
|
done
|
|
|
|
set -e
|
|
}
|
|
|
|
# ANSI color codes used when displaying messages.
|
|
# Taken from src/scripts/common.sh.
|
|
V_RED="\e[31m"
|
|
V_YELLOW="\e[33m"
|
|
V_BOLD_GREEN="\e[1;32m"
|
|
V_BOLD_RED="\e[1;31m"
|
|
V_BOLD_YELLOW="\e[1;33m"
|
|
V_VIDOFF="\e[0m"
|
|
|
|
# Prints an informational message.
|
|
# Taken from src/scripts/common.sh.
|
|
# Arg: MESSAGE
|
|
info() {
|
|
echo -e >&2 "${V_BOLD_GREEN}${CROS_LOG_PREFIX:-}INFO : $1${V_VIDOFF}"
|
|
}
|
|
|
|
# Prints a warning message.
|
|
# Taken from src/scripts/common.sh.
|
|
# Arg: MESSAGE
|
|
warn() {
|
|
echo -e >&2 "${V_BOLD_YELLOW}${CROS_LOG_PREFIX:-}WARNING: $1${V_VIDOFF}"
|
|
}
|
|
|
|
# Prints the specified error and exit the script with an error code.
|
|
# Taken from src/scripts/common.sh.
|
|
# Args: MESSAGE
|
|
error() {
|
|
echo -e >&2 "${V_BOLD_RED}${CROS_LOG_PREFIX:-}ERROR : $1${V_VIDOFF}"
|
|
}
|
|
|
|
# Prints an error message and exit with an error code.
|
|
# Taken from src/scripts/common.sh.
|
|
# Args: MESSAGE
|
|
die() {
|
|
error "$1"
|
|
exit 1
|
|
}
|
|
|
|
# Usage: lsbval path-to-lsb-file key
|
|
# Returns the value for the given lsb-release file variable.
|
|
lsbval() {
|
|
local lsbfile="$1"
|
|
local key="$2"
|
|
grep "^${key}=" "${lsbfile}" | sed "s/^${key}=//"
|
|
}
|
|
|
|
# Usage: get_board_from_lsb_release rootfs
|
|
# Returns the exact board name from /etc/lsb-release. This may contain
|
|
# dashes or other characters not suitable for variable names. See the
|
|
# next function for that.
|
|
get_board_from_lsb_release() {
|
|
local rootfs="$1"
|
|
lsbval "${rootfs}/etc/lsb-release" CHROMEOS_RELEASE_BOARD
|
|
}
|
|
|
|
# Usage: get_boardvar_from_lsb_release rootfs
|
|
# Returns the board name from /etc/lsb-release in a mangled form that can
|
|
# be used in variable names. e.g. dashes are turned into underscores.
|
|
get_boardvar_from_lsb_release() {
|
|
get_board_from_lsb_release "$@" | sed 's:[-]:_:g'
|
|
}
|
|
|
|
# This will override the trap set in common_minmal.sh
|
|
trap "cleanup" INT TERM EXIT
|
|
|
|
add_cleanup_action "cleanup_temps_and_mounts"
|