#!/bin/bash # Download and extract Jinja2 # Homepage: # http://jinja.pocoo.org/ # Installation instructions: # http://jinja.pocoo.org/docs/intro/#from-the-tarball-release # Download page: # https://pypi.python.org/pypi/Jinja2 PACKAGE='Jinja2' VERSION='2.10' SRC_URL='https://pypi.python.org/packages/56/e6/332789f295cf22308386cf5bbd1f4e00ed11484299c5d7383378cf48ba47/Jinja2-2.10.tar.gz' PACKAGE_DIR='jinja2' CHROMIUM_FILES="README.chromium OWNERS get_jinja2.sh" EXTRA_FILES='LICENSE AUTHORS' REMOVE_FILES='testsuite' FILENAME="$(basename $SRC_URL)" MD5_FILENAME="$FILENAME.md5" SHA512_FILENAME="$FILENAME.sha512" CHROMIUM_FILES+=" $MD5_FILENAME $SHA512_FILENAME" BUILD_DIR="$PACKAGE-$VERSION" THIRD_PARTY="$(dirname $(realpath $(dirname "${BASH_SOURCE[0]}")))" INSTALL_DIR="$THIRD_PARTY/$PACKAGE_DIR" OUT_DIR="$INSTALL_DIR/$BUILD_DIR/$PACKAGE_DIR" OLD_DIR="$THIRD_PARTY/$PACKAGE_DIR.old" function check_hashes { # Hashes generated via: # FILENAME=Jinja2-2.8.tar.gz # md5sum "$FILENAME" > "$FILENAME.md5" # sha512sum "$FILENAME" > "$FILENAME.sha512" # unset FILENAME # MD5 if ! [ -f "$MD5_FILENAME" ] then echo "MD5 hash file $MD5_FILENAME not found, could not verify archive" exit 1 fi # 32-digit hash, followed by filename MD5_HASHFILE_REGEX="^[0-9a-f]{32} $FILENAME" if ! grep --extended-regex --line-regex --silent \ "$MD5_HASHFILE_REGEX" "$MD5_FILENAME" then echo "MD5 hash file $MD5_FILENAME does not contain hash for $FILENAME," \ 'could not verify archive' echo 'Hash file contents are:' cat "$MD5_FILENAME" exit 1 fi if ! md5sum --check "$MD5_FILENAME" then echo 'MD5 hash does not match,' \ "archive file $FILENAME corrupt or compromised!" exit 1 fi # SHA-512 if ! [ -f "$SHA512_FILENAME" ] then echo "SHA-512 hash file $SHA512_FILENAME not found," \ 'could not verify archive' exit 1 fi # 128-digit hash, followed by filename SHA512_HASHFILE_REGEX="^[0-9a-f]{128} $FILENAME" if ! grep --extended-regex --line-regex --silent \ "$SHA512_HASHFILE_REGEX" "$SHA512_FILENAME" then echo "SHA-512 hash file $SHA512_FILENAME does not contain hash for" \ "$FILENAME, could not verify archive" echo 'Hash file contents are:' cat "$SHA512_FILENAME" exit 1 fi if ! sha512sum --check "$SHA512_FILENAME" then echo 'SHA-512 hash does not match,' \ "archive file $FILENAME corrupt or compromised!" exit 1 fi } ################################################################################ # Body cd "$INSTALL_DIR" echo "Downloading $SRC_URL" curl --remote-name "$SRC_URL" check_hashes tar xvzf "$FILENAME" # Copy extra files over for FILE in $CHROMIUM_FILES do cp "$FILE" "$OUT_DIR" done cd "$BUILD_DIR" for FILE in $EXTRA_FILES do cp "$FILE" "$OUT_DIR" done cd "$OUT_DIR" for FILE in $REMOVE_FILES do rm -fr "$FILE" done # Replace with new directory cd .. mv "$INSTALL_DIR" "$OLD_DIR" mv "$PACKAGE_DIR" "$INSTALL_DIR" cd "$INSTALL_DIR" rm -fr "$OLD_DIR" # Generating jinja2.gni cat > jinja2.gni <<EOF # DO NOT EDIT # This is generated from get_jinja2.sh. jinja2_sources = [ EOF for i in $(LC_COLLATE=C ls *.py) do echo " \"//third_party/jinja2/${i}\"," >> jinja2.gni done echo "]" >> jinja2.gni