1 # Copyright 2012 Google Inc.
4 # Redistribution and use in source and binary forms, with or without
5 # modification, are permitted provided that the following conditions are
8 # * Redistributions of source code must retain the above copyright
9 # notice, this list of conditions and the following disclaimer.
10 # * Redistributions in binary form must reproduce the above copyright
11 # notice, this list of conditions and the following disclaimer in the
12 # documentation and/or other materials provided with the distribution.
13 # * Neither the name of Google Inc. nor the names of its contributors
14 # may be used to endorse or promote products derived from this software
15 # without specific prior written permission.
17 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19 # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
20 # A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
21 # OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
22 # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
23 # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24 # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25 # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
27 # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 # Common initialization and functions for shell scripts.
36 # Directory where the running script lives.
37 Lib_DirName="$(dirname ${0})"
40 # Base name of the running script.
41 Lib_ProgName="${0##*/}"
44 # Path to the temporary directory for this execution.
48 # List of cleanup functions to execute on exit.
52 # Catch unexpected exits and perform the required cleanups. In particular,
53 # ensure that the temporary directory in Lib_TempDir, if any, is removed.
54 trap 'lib_cleanup ; exit 2' HUP INT QUIT TERM
57 # Prints an informational message.
59 # \param ... The message to print. Can be provided as multiple words and, in
60 # that case, they are joined together by a single whitespace.
62 echo "${Lib_ProgName}: I: $*" 1>&2
66 # Prints a runtime error and exits.
68 # \param ... The message to print. Can be provided as multiple words and, in
69 # that case, they are joined together by a single whitespace.
71 echo "${Lib_ProgName}: E: $*" 1>&2
76 # Prints a runtime warning.
78 # \param ... The message to print. Can be provided as multiple words and, in
79 # that case, they are joined together by a single whitespace.
81 echo "${Lib_ProgName}: W: $*" 1>&2
85 # Prints an usage error and exits.
87 # \param ... The message to print. Can be provided as multiple words and, in
88 # that case, they are joined together by a single whitespace.
90 echo "${Lib_ProgName}: E: $*" 1>&2
91 usage "${Lib_ProgName}" 1>&2
96 # Executes the registered cleanup hooks.
99 for hook in ${_Lib_Cleanup_Hooks}; do
105 # Installs a new cleanup hook.
107 # \param ... The names of the cleanup functions to register.
108 lib_register_cleanup() {
109 _Lib_Cleanup_Hooks="${_Lib_Cleanup_Hooks} ${*}"
113 # Creates a temporary directory for this execution.
115 # The temporary directory is unique to this script and execution. A cleanup
116 # hook is installed to delete such directory whenever lib_cleanup is called or
117 # when the program abruptly exits.
119 # \post Lib_TempDir is set to the path of the created temporary directory.
121 Lib_TempDir=$(mktemp -d -t "${_Lib_ProgName}.XXXXXX")
122 lib_register_cleanup "lib_clean_tempdir"
126 # Cleanup hook to delete the temporary directory.
128 # This operation is idempotent.
129 lib_clean_tempdir() {
130 if [ -n "${Lib_TempDir}" ]; then
131 rm -rf "${Lib_TempDir}"