3 # Copyright (c) 2012 The Chromium Authors. All rights reserved.
4 # Use of this source code is governed by a BSD-style license that can be
5 # found in the LICENSE file.
7 # This script expects the following environment variables to be set. Xcode
10 # CONFIGURATION - Release or Debug; this script only operates when Release.
11 # SRCROOT - /path/to/chrome/src/chrome
12 # BUILT_PRODUTS_DIR - /path/to/chrome/src/xcodebuild/Release
14 # The script also takes a single argument defining the branding type.
16 # To test this script without running an entire build:
18 # cd /path/to/chrome/src/chrome
19 # CONFIGURATION=Release \
21 # BUILT_PRODUCTS_DIR=$(pwd)/../xcodebuild/Release \
22 # tools/build/mac/dump_app_syms Chromium
24 # Make sure we got the header to write into passed to us
26 echo "error: missing branding as an argument" >&2
32 # Skip out if we're aren't in Release mode, no need for dump_syms on debug runs.
33 if [ "${CONFIGURATION}" != "Release" ] ; then
40 BRAND_SCRIPT
="${TOP}/build/branding_value.sh"
41 SRC_APP_NAME
=$
("${BRAND_SCRIPT}" "${BUILD_BRANDING}" PRODUCT_FULLNAME
)
42 .
"${TOP}/chrome/VERSION"
44 BREAKPAD_DUMP_SYMS
="${BUILT_PRODUCTS_DIR}/dump_syms"
45 FULL_VERSION
="${MAJOR}.${MINOR}.${BUILD}.${PATCH}"
47 DSYM_TAR_PATH
="${BUILT_PRODUCTS_DIR}/${SRC_APP_NAME}.dSYM.tar.bz2"
49 # Starting with an already-dumped symbol file at ${original_sym_path},
50 # transforms the MODULE line (which must be the first line) from referring to
51 # ${original_stem} to refer to ${variant_stem}. The transformed symbol file
52 # is written to a symbol file at the same location that a symbol file would
53 # be written to if ${variant_name} were in the SRC_NAMES array below.
55 # If the transformed symbol file already appears more recent than
56 # ${original_sym_path}, it is left alone.
57 redump_syms_variant
() {
58 local original_sym_path
="${1}"
59 local original_stem
="${2}"
60 local variant_stem
="${3}"
61 local variant_name
="${4}"
64 local variant_sym_name
="${variant_name}-${FULL_VERSION}-${arch}.breakpad"
65 local variant_sym_path
="${BUILT_PRODUCTS_DIR}/${variant_sym_name}"
67 if [[ "${original_sym_path}" -nt "${variant_sym_path}" ]]; then
69 1s/^(MODULE [^ ]+ [^ ]+ [0-9a-fA-F]{33}) ${original_stem}\$/\1 ${variant_stem}/"
70 sed -E -e "${pattern}" < "${original_sym_path}" > "${variant_sym_path}"
76 # Everything in SRC_NAMES is required. It's an error for any of these files
80 "${SRC_APP_NAME} Framework.framework"
81 "${SRC_APP_NAME} Helper.app"
87 # PDF.plugin is optional. Only include it if present.
88 if [[ -e "${BUILT_PRODUCTS_DIR}/PDF.plugin" ]]; then
89 SRC_NAMES
[${#SRC_NAMES[@]}]="PDF.plugin"
92 # libpeerconnection.so is optional. Only include it if present.
93 if [[ -e "${BUILT_PRODUCTS_DIR}/libpeerconnection.so" ]]; then
94 SRC_NAMES
[${#SRC_NAMES[@]}]="libpeerconnection.so"
97 for SRC_NAME
in "${SRC_NAMES[@]}"; do
98 # SRC_STEM is the name of the file within the DWARF directory of the .dSYM
99 # bundle, which comes from the on-disk name of an executable or dylib within
100 # its enclosing .app, .framework or .plugin bundle. This is the bundle name
101 # without .app, .framework or .plugin appended. For non-bundled types, the
102 # stem is just the name of the singular file on disk.
103 SRC_STEM
=$
(echo "${SRC_NAME}" |
sed -Ee 's/\.(app|framework|plugin)$//')
104 DSYM_NAME
="${SRC_NAME}.dSYM"
105 DSYM_PATH
="${BUILT_PRODUCTS_DIR}/${DSYM_NAME}"
106 DWARF_PATH
="${DSYM_PATH}/Contents/Resources/DWARF/${SRC_STEM}"
108 # SRC_PATH is the path to the Mach-O file to which the DSYM_PATH corresponds.
109 # If this is a directory, it is a bundle, and the path to the actual image
110 # needs to be computed for dump_syms.
111 SRC_PREFIX
="${BUILT_PRODUCTS_DIR}/${SRC_NAME}"
113 if [[ -d "${SRC_PREFIX}" ]]; then
115 # Executables and plugins:
116 "${SRC_PREFIX}/Contents/MacOS/${SRC_STEM}"
118 "${SRC_PREFIX}/Versions/Current/${SRC_STEM}"
120 for BUNDLED_OPTION
in "${BUNDLED_OPTIONS[@]}"; do
121 if [[ -fx "${BUNDLED_OPTION}" ]]; then
122 SRC_PATH
="${BUNDLED_OPTION}"
127 if [[ -z "${SRC_PATH}" ]]; then
128 echo "${0}: Could not find bundled Mach-O file for ${SRC_NAME}"
132 # The Mach-O file is not a bundle.
133 SRC_PATH
="${SRC_PREFIX}"
136 ARCHS
=$
(file "${DWARF_PATH}" |
sed -Ene 's/^.*(i386|x86_64)$/\1/p')
137 if [[ -z "${ARCHS}" ]]; then
138 echo "${0}: expected something dumpable in ${DWARF_PATH}" >& 2
142 for ARCH
in ${ARCHS}; do
143 BPAD_SYM_NAME
="${SRC_NAME}-${FULL_VERSION}-${ARCH}.breakpad"
144 BPAD_SYM_PATH
="${BUILT_PRODUCTS_DIR}/${BPAD_SYM_NAME}"
146 # Only run dump_syms if the file has changed since the last dump. Use -g
147 # to dump data from the dSYM and CFI data from the Mach-O library or
149 if [ "${DWARF_PATH}" -nt "${BPAD_SYM_PATH}" -o \
150 "${SRC_PATH}" -nt "${BPAD_SYM_PATH}" ] ; then
151 "${BREAKPAD_DUMP_SYMS}" -a "${ARCH}" -g "${DWARF_PATH}" "${SRC_PATH}" > \
155 # Some executables will show up with variant names. The Breakpad symbol
156 # server looks up modules based on a combination of the module name and
157 # identifier (UUID). Produce symbol files for these variant names so that
158 # the Breakpad symbol server will have something to return for stacks that
159 # travel through these modules.
160 case "${SRC_NAME}" in
161 "${SRC_APP_NAME}.app")
162 # Google Chrome Canary is produced during packaging.
163 redump_syms_variant
"${BPAD_SYM_PATH}" "${SRC_STEM}" \
164 "${SRC_STEM} Canary" "${SRC_STEM} Canary.app" \
168 "${SRC_APP_NAME} Helper.app")
169 # Google Chrome Helper EH and Google Chrome Helper NP are produced by
170 # build/mac/make_more_helpers.sh.
171 redump_syms_variant
"${BPAD_SYM_PATH}" "${SRC_STEM}" \
172 "${SRC_STEM} EH" "${SRC_STEM} EH.app" "${ARCH}"
173 redump_syms_variant
"${BPAD_SYM_PATH}" "${SRC_STEM}" \
174 "${SRC_STEM} NP" "${SRC_STEM} NP.app" "${ARCH}"
179 # Remove the .dSYM archive if the file has changed since the archive was
180 # last generated. This will cause a new .dSYM archive to be created.
181 if [ "${DWARF_PATH}" -nt "${DSYM_TAR_PATH}" ] ; then
182 rm -f "${DSYM_TAR_PATH}"
185 # Push the .dSYM bundle onto the DSYMS array so that it will be included in
186 # the .dSYM archive if a new one is needed
187 DSYMS
[${#DSYMS[@]}]="${DSYM_NAME}"
190 # Create the archive of .dSYM bundles.
191 if [ ! -e "${DSYM_TAR_PATH}" ] ; then
192 # Change directory so that absolute paths aren't included in the archive.
193 (cd "${BUILT_PRODUCTS_DIR}" &&
194 tar -jcf "${DSYM_TAR_PATH}" "${DSYMS[@]}")