installer.include revision 3551c9c881056c480085172ff9840cab31610854
1# Recursively replace @@include@@ template variables with the referenced file, 2# and write the resulting text to stdout. 3process_template_includes() { 4 INCSTACK+="$1->" 5 # Includes are relative to the file that does the include. 6 INCDIR=$(dirname $1) 7 # Clear IFS so 'read' doesn't trim whitespace 8 local OLDIFS="$IFS" 9 IFS='' 10 while read -r LINE 11 do 12 INCLINE=$(sed -e '/^[[:space:]]*@@include@@/!d' <<<$LINE) 13 if [ -n "$INCLINE" ]; then 14 INCFILE=$(echo $INCLINE | sed -e "s#@@include@@\(.*\)#\1#") 15 # Simple filename match to detect cyclic includes. 16 CYCLE=$(sed -e "\#$INCFILE#"'!d' <<<$INCSTACK) 17 if [ "$CYCLE" ]; then 18 echo "ERROR: Possible cyclic include detected." 1>&2 19 echo "$INCSTACK$INCFILE" 1>&2 20 exit 1 21 fi 22 if [ ! -r "$INCDIR/$INCFILE" ]; then 23 echo "ERROR: Couldn't read include file: $INCDIR/$INCFILE" 1>&2 24 exit 1 25 fi 26 process_template_includes "$INCDIR/$INCFILE" 27 else 28 echo "$LINE" 29 fi 30 done < "$1" 31 IFS="$OLDIFS" 32 INCSTACK=${INCSTACK%"$1->"} 33} 34 35# Replace template variables (@@VARNAME@@) in the given template file. If a 36# second argument is given, save the processed text to that filename, otherwise 37# modify the template file in place. 38process_template() ( 39 # Don't worry if some of these substitution variables aren't set. 40 # Note that this function is run in a sub-shell so we don't leak this 41 # setting, since we still want unbound variables to be an error elsewhere. 42 set +u 43 44 local TMPLIN="$1" 45 if [ -z "$2" ]; then 46 local TMPLOUT="$TMPLIN" 47 else 48 local TMPLOUT="$2" 49 fi 50 # Process includes first so included text also gets substitutions. 51 TMPLINCL="$(process_template_includes "$TMPLIN")" 52 sed \ 53 -e "s#@@PACKAGE@@#${PACKAGE}#g" \ 54 -e "s#@@PACKAGE_FILENAME@@#${PACKAGE_FILENAME}#g" \ 55 -e "s#@@PROGNAME@@#${PROGNAME}#g" \ 56 -e "s#@@CHANNEL@@#${CHANNEL}#g" \ 57 -e "s#@@COMPANY_FULLNAME@@#${COMPANY_FULLNAME}#g" \ 58 -e "s#@@VERSION@@#${VERSION}#g" \ 59 -e "s#@@PACKAGE_RELEASE@@#${PACKAGE_RELEASE}#g" \ 60 -e "s#@@VERSIONFULL@@#${VERSIONFULL}#g" \ 61 -e "s#@@INSTALLDIR@@#${INSTALLDIR}#g" \ 62 -e "s#@@BUILDDIR@@#${BUILDDIR}#g" \ 63 -e "s#@@STAGEDIR@@#${STAGEDIR}#g" \ 64 -e "s#@@SCRIPTDIR@@#${SCRIPTDIR}#g" \ 65 -e "s#@@MENUNAME@@#${MENUNAME}#g" \ 66 -e "s#@@PRODUCTURL@@#${PRODUCTURL}#g" \ 67 -e "s#@@PREDEPENDS@@#${PREDEPENDS}#g" \ 68 -e "s#@@DEPENDS@@#${DEPENDS}#g" \ 69 -e "s#@@PROVIDES@@#${PROVIDES}#g" \ 70 -e "s#@@REPLACES@@#${REPLACES}#g" \ 71 -e "s#@@CONFLICTS@@#${CONFLICTS}#g" \ 72 -e "s#@@ARCHITECTURE@@#${ARCHITECTURE}#g" \ 73 -e "s#@@MAINTNAME@@#${MAINTNAME}#g" \ 74 -e "s#@@MAINTMAIL@@#${MAINTMAIL}#g" \ 75 -e "s#@@REPOCONFIG@@#${REPOCONFIG}#g" \ 76 -e "s#@@SHORTDESC@@#${SHORTDESC}#g" \ 77 -e "s#@@FULLDESC@@#${FULLDESC}#g" \ 78 -e "s#@@DEFAULT_FLAGS@@#${DEFAULT_FLAGS:-}#g" \ 79 > "$TMPLOUT" <<< "$TMPLINCL" 80) 81 82# Setup the installation directory hierachy in the package staging area. 83prep_staging_common() { 84 install -m 755 -d "${STAGEDIR}/${INSTALLDIR}" \ 85 "${STAGEDIR}/usr/bin" \ 86 "${STAGEDIR}/usr/share/applications" \ 87 "${STAGEDIR}/usr/share/gnome-control-center/default-apps" \ 88 "${STAGEDIR}/usr/share/man/man1" 89} 90 91get_version_info() { 92 source "${BUILDDIR}/installer/version.txt" 93 VERSION="${MAJOR}.${MINOR}.${BUILD}.${PATCH}" 94 # TODO(phajdan.jr): Provide a mechanism to pass a different package 95 # release number if needed. The meaning of it is to bump it for 96 # packaging-only changes while the underlying software has the same version. 97 # This corresponds to the Release field in RPM spec files and debian_revision 98 # component of the Version field for DEB control file. 99 # Generally with Chrome's fast release cycle it'd be more hassle to try 100 # to bump this number between releases. 101 PACKAGE_RELEASE="1" 102} 103 104stage_install_common() { 105 echo "Staging common install files in '${STAGEDIR}'..." 106 107 # TODO(mmoss) This assumes we built the static binaries. To support shared 108 # builds, we probably want an install target in scons so it can give us all 109 # the right files. See also: 110 # http://code.google.com/p/chromium/issues/detail?id=4451 111 # 112 # app 113 # We need to add the debug link so gdb knows to look for the symbols. 114 DEBUGFILE="${BUILDDIR}/${PROGNAME}.debug" 115 STRIPPEDFILE="${BUILDDIR}/${PROGNAME}.stripped" 116 eu-strip -o "${STRIPPEDFILE}" -f "${DEBUGFILE}" "${BUILDDIR}/${PROGNAME}" 117 install -m 755 "${STRIPPEDFILE}" "${STAGEDIR}/${INSTALLDIR}/${PROGNAME}" 118 rm "${DEBUGFILE}" "${STRIPPEDFILE}" 119 120 # resources 121 install -m 644 "${BUILDDIR}/resources.pak" "${STAGEDIR}/${INSTALLDIR}/" 122 # TODO(mmoss): This has broken a couple times on adding new .pak files. Maybe 123 # we should flag all installer files in FILES.cfg and get them from there, so 124 # there's only one place people need to keep track of such things (and in 125 # only the public repository). 126 if [ -r "${BUILDDIR}/chrome_100_percent.pak" ]; then 127 install -m 644 "${BUILDDIR}/chrome_100_percent.pak" "${STAGEDIR}/${INSTALLDIR}/" 128 else 129 install -m 644 "${BUILDDIR}/theme_resources_100_percent.pak" "${STAGEDIR}/${INSTALLDIR}/" 130 install -m 644 "${BUILDDIR}/ui_resources_100_percent.pak" "${STAGEDIR}/${INSTALLDIR}/" 131 fi 132 133 # sandbox 134 # Rename sandbox binary with hyphen instead of underscore because that's what 135 # the code looks for, but the build targets can't use hyphens (scons bug?) 136 install -m 4755 -s "${BUILDDIR}/${PROGNAME}_sandbox" \ 137 "${STAGEDIR}/${INSTALLDIR}/${PROGNAME}-sandbox" 138 139 # l10n paks 140 cp -a "${BUILDDIR}/locales" "${STAGEDIR}/${INSTALLDIR}/" 141 find "${STAGEDIR}/${INSTALLDIR}/locales" -type f -exec chmod 644 '{}' \; 142 find "${STAGEDIR}/${INSTALLDIR}/locales" -type d -exec chmod 755 '{}' \; 143 144 # ffmpeg libs 145 install -m 644 -s "${BUILDDIR}/libffmpegsumo.so" "${STAGEDIR}/${INSTALLDIR}/" 146 147 # Widevine CDM. 148 if [ -f "${BUILDDIR}/libwidevinecdmadapter.so" ]; then 149 install -m 644 -s "${BUILDDIR}/libwidevinecdmadapter.so" "${STAGEDIR}/${INSTALLDIR}/" 150 install -m 644 "${BUILDDIR}/libwidevinecdm.so" "${STAGEDIR}/${INSTALLDIR}/" 151 fi 152 153 # Pepper Flash. 154 PEPPERFLASH_SRCDIR="${BUILDDIR}/PepperFlash" 155 PEPPERFLASH_DESTDIR="${STAGEDIR}/${INSTALLDIR}/PepperFlash" 156 install -m 755 -d "${PEPPERFLASH_DESTDIR}" 157 install -m 644 -s "${PEPPERFLASH_SRCDIR}/libpepflashplayer.so" \ 158 "${PEPPERFLASH_DESTDIR}/" 159 install -m 644 "${PEPPERFLASH_SRCDIR}/manifest.json" \ 160 "${PEPPERFLASH_DESTDIR}/" 161 162 # pdf plugin 163 if [ -f "${BUILDDIR}/libpdf.so" ]; then 164 install -m 644 -s "${BUILDDIR}/libpdf.so" "${STAGEDIR}/${INSTALLDIR}/" 165 fi 166 167 # peerconnection shared library 168 if [ -f "${BUILDDIR}/lib/libpeerconnection.so" ]; then 169 install -m 755 -d "${STAGEDIR}/${INSTALLDIR}/lib/" 170 install -m 644 -s "${BUILDDIR}/lib/libpeerconnection.so" "${STAGEDIR}/${INSTALLDIR}/lib/" 171 fi 172 173 # nacl pepper plugin 174 if [ -f "${BUILDDIR}/libppGoogleNaClPluginChrome.so" ]; then 175 install -m 644 -s "${BUILDDIR}/libppGoogleNaClPluginChrome.so" "${STAGEDIR}/${INSTALLDIR}/" 176 fi 177 178 # nacl_helper and nacl_helper_bootstrap 179 # Don't use "-s" (strip) because this runs binutils "strip", which 180 # mangles the special ELF program headers of nacl_helper_bootstrap. 181 # Explicitly use eu-strip instead, because it doesn't have that problem. 182 for file in nacl_helper nacl_helper_bootstrap; do 183 buildfile="${BUILDDIR}/${file}" 184 if [ -f "${buildfile}" ]; then 185 strippedfile="${buildfile}.stripped" 186 debugfile="${buildfile}.debug" 187 eu-strip -o "${strippedfile}" -f "${debugfile}" "${buildfile}" 188 install -m 755 "${strippedfile}" "${STAGEDIR}/${INSTALLDIR}/${file}" 189 fi 190 done 191 # Don't use "-s" (strip) because this would use the Linux toolchain to 192 # strip the NaCl binary, which has the potential to break it. It 193 # certainly resets the OSABI and ABIVERSION fields to non-NaCl values, 194 # although the NaCl IRT loader doesn't care about these fields. In any 195 # case, the IRT binaries are already stripped by NaCl's build process. 196 for filename in ${BUILDDIR}/nacl_irt_*.nexe; do 197 # Re-check the filename in case globbing matched nothing. 198 if [ -f "$filename" ]; then 199 install -m 644 "$filename" "${STAGEDIR}/${INSTALLDIR}/`basename "$filename"`" 200 fi 201 done 202 203 # default apps 204 if [ -d "${BUILDDIR}/default_apps" ]; then 205 cp -a "${BUILDDIR}/default_apps" "${STAGEDIR}/${INSTALLDIR}/" 206 find "${STAGEDIR}/${INSTALLDIR}/default_apps" -type d -exec chmod 755 '{}' \; 207 find "${STAGEDIR}/${INSTALLDIR}/default_apps" -type f -exec chmod 644 '{}' \; 208 fi 209 210 # launcher script and symlink 211 process_template "${BUILDDIR}/installer/common/wrapper" \ 212 "${STAGEDIR}/${INSTALLDIR}/${PACKAGE}" 213 chmod 755 "${STAGEDIR}/${INSTALLDIR}/${PACKAGE}" 214 pushd "${STAGEDIR}/usr/bin/" 215 ln -snf "${INSTALLDIR}/${PACKAGE}" "${PACKAGE}" 216 popd 217 218 # app icons 219 install -m 644 \ 220 "${BUILDDIR}/installer/theme/product_logo_"*.png \ 221 "${BUILDDIR}/installer/theme/product_logo_32.xpm" \ 222 "${STAGEDIR}/${INSTALLDIR}/" 223 224 # desktop integration 225 install -m 755 "${BUILDDIR}/xdg-mime" "${STAGEDIR}${INSTALLDIR}/" 226 install -m 755 "${BUILDDIR}/xdg-settings" "${STAGEDIR}${INSTALLDIR}/" 227 process_template "${BUILDDIR}/installer/common/desktop.template" \ 228 "${STAGEDIR}/${INSTALLDIR}/${PACKAGE}.desktop" 229 chmod 644 "${STAGEDIR}/${INSTALLDIR}/${PACKAGE}.desktop" 230 process_template "${BUILDDIR}/installer/common/default-app.template" \ 231 "${STAGEDIR}/usr/share/gnome-control-center/default-apps/${PACKAGE}.xml" 232 chmod 644 "${STAGEDIR}/usr/share/gnome-control-center/default-apps/${PACKAGE}.xml" 233 process_template "${BUILDDIR}/installer/common/default-app-block.template" \ 234 "${STAGEDIR}${INSTALLDIR}/default-app-block" 235 chmod 644 "${STAGEDIR}${INSTALLDIR}/default-app-block" 236 237 # documentation 238 install -m 755 "${BUILDDIR}/${PROGNAME}.1" \ 239 "${STAGEDIR}/usr/share/man/man1/${PACKAGE}.1" 240} 241