#!/bin/bash -e # # Copyright (c) 2012 The Chromium Authors. All rights reserved. # Use of this source code is governed by a BSD-style license that can be # found in the LICENSE file. # This tool is used to update libaom source code to a revision of the upstream # repository. Modified from Chromium src/third_party/libvpx/update_libvpx.sh # Usage: # # $ ./update_libaom.sh [branch | revision | file or url containing a revision] # When specifying a branch it may be necessary to prefix with origin/ # Tools required for running this tool: # # 1. Linux / Mac # 2. git export LC_ALL=C die() { echo "@" exit 1 } # Location for the remote git repository. GIT_REPO="https://aomedia.googlesource.com/aom" # Update to TOT by default. GIT_BRANCH="origin/master" # Relative path of target checkout. LIBAOM_SRC_DIR="libaom" BASE_DIR=`pwd` if [ -n "$1" ]; then GIT_BRANCH="$1" if [ -f "$1" ]; then GIT_BRANCH=$(<"$1") elif [[ $1 = http* ]]; then GIT_BRANCH=`curl $1` fi fi prev_hash="$(egrep "^Commit: [[:alnum:]]" README.android | awk '{ print $2 }')" echo "prev_hash:$prev_hash" rm -rf $LIBAOM_SRC_DIR mkdir $LIBAOM_SRC_DIR || die "Unable to create ${LIBAOM_SRC_DIR}" cd $LIBAOM_SRC_DIR || die "Unable to enter ${LIBAOM_SRC_DIR}" # Start a local git repo. git clone $GIT_REPO . # Switch the content to the desired revision. git checkout -b tot $GIT_BRANCH add="$(git diff-index --diff-filter=A $prev_hash | \ tr -s [:blank:] ' ' | cut -f6 -d\ )" delete="$(git diff-index --diff-filter=D $prev_hash | \ tr -s [:blank:] ' ' | cut -f6 -d\ )" # Get the current commit hash. hash=$(git log -1 --format="%H") # README reminder. echo "Update README.android:" echo "===============" echo "Date: $(date +"%A %B %d %Y")" echo "Branch: $GIT_BRANCH" echo "Commit: $hash" echo "===============" echo "" # Commit message header. echo "Commit message:" echo "===============" echo "libaom: Pull from upstream" echo "" # Output the current commit hash. echo "Current HEAD: $hash" echo "" # Output log for upstream from current hash. if [ -n "$prev_hash" ]; then echo "git log from upstream:" pretty_git_log="$(git log \ --no-merges \ --topo-order \ --pretty="%h %s" \ --max-count=20 \ $prev_hash..$hash)" if [ -z "$pretty_git_log" ]; then echo "No log found. Checking for reverts." pretty_git_log="$(git log \ --no-merges \ --topo-order \ --pretty="%h %s" \ --max-count=20 \ $hash..$prev_hash)" fi echo "$pretty_git_log" # If it makes it to 20 then it's probably skipping even more. if [ `echo "$pretty_git_log" | wc -l` -eq 20 ]; then echo "<...>" fi else # no previous hash echo "git log from upstream:" pretty_git_log="$(git log \ --no-merges \ --topo-order \ --pretty="%h %s" \ --max-count=20 \ $hash)" fi # Commit message footer. echo "" echo "===============" # Git is useless now, remove the local git repo. rm -rf .git .gitignore .gitattributes # Add and remove files. echo "$add" | xargs -I {} git add {} echo "$delete" | xargs -I {} git rm --ignore-unmatch {} # Find empty directories and remove them. find . -type d -empty -exec git rm {} \; chmod 755 build/cmake/*.sh build/cmake/*.pl