diff options
Diffstat (limited to 'scripts/code.angularjs.org/publish.sh')
| -rwxr-xr-x | scripts/code.angularjs.org/publish.sh | 123 |
1 files changed, 67 insertions, 56 deletions
diff --git a/scripts/code.angularjs.org/publish.sh b/scripts/code.angularjs.org/publish.sh index 352ac10b..4845ad2a 100755 --- a/scripts/code.angularjs.org/publish.sh +++ b/scripts/code.angularjs.org/publish.sh @@ -1,62 +1,73 @@ #!/bin/bash +# Script for updating code.angularjs.org repo from current local build. + echo "#################################" echo "## Update code.angular.js.org ###" echo "#################################" -# Enable tracing and exit on first failure -set -xe -# Normalize working dir to script dir -cd `dirname $0` - -TMP_DIR=../../tmp -REPO_DIR=$TMP_DIR/code.angularjs.org -BUILD_DIR=../../build -SCRIPT_DIR=`pwd` -NEW_VERSION=`cat $BUILD_DIR/version.txt` - -# -# Snapshot builds are kept in a temp directory in code.angularjs.org -# that is filled by calling a php script there. -# -if [[ "$NEW_VERSION" =~ sha ]] ;then - echo "-- updating snapshot version" - curl -G --data-urlencode "ver=$NEW_VERSION" http://code.angularjs.org/fetchLatestSnapshot.php - exit 0; -fi - -# -# clone -# - -echo "-- Cloning code.angularjs.org" -git clone git@github.com:angular/code.angularjs.org.git $REPO_DIR - -# -# copy the files from the build -# - -echo "-- Updating code.angularjs.org" -mkdir $REPO_DIR/$NEW_VERSION -cd $REPO_DIR -git reset --hard HEAD -git checkout master -git fetch --all -git reset --hard origin/master -cd $SCRIPT_DIR -cp -r $BUILD_DIR/* $REPO_DIR/$NEW_VERSION/ - -# -# commit and push -# -echo "-- Committing and pushing code.angularjs.org" -cd $REPO_DIR -git add -A -git commit -m "v$NEW_VERSION" -git push origin master -cd $SCRIPT_DIR - -# -# refresh code.angularjs.org from github -# -curl http://code.angularjs.org/gitFetchSite.php
\ No newline at end of file +ARG_DEFS=( + "--action=(prepare|publish)" +) + +function init { + TMP_DIR=$(resolveDir ../../tmp) + BUILD_DIR=$(resolveDir ../../build) + REPO_DIR=$TMP_DIR/code.angularjs.org + NEW_VERSION=$(cat $BUILD_DIR/version.txt) + if [[ "$NEW_VERSION" =~ sha ]]; then + IS_SNAPSHOT_BUILD=true + else + IS_SNAPSHOT_BUILD= + fi +} + +function prepare { + if [[ $IS_SNAPSHOT_BUILD ]]; then + # nothing to prepare for snapshot builds as + # code.angularjs.org will fetch the current snapshot from + # the build server during publish + exit 0 + fi + + echo "-- Cloning code.angularjs.org" + git clone git@github.com:angular/code.angularjs.org.git $REPO_DIR + + # + # copy the files from the build + # + echo "-- Updating code.angularjs.org" + mkdir $REPO_DIR/$NEW_VERSION + cd $REPO_DIR + git reset --hard HEAD + git checkout master + git fetch --all + git reset --hard origin/master + cd $SCRIPT_DIR + cp -r $BUILD_DIR/* $REPO_DIR/$NEW_VERSION/ + + # + # commit + # + echo "-- Committing code.angularjs.org" + cd $REPO_DIR + git add -A + git commit -m "v$NEW_VERSION" +} + +function publish { + if [[ $IS_SNAPSHOT_BUILD ]]; then + echo "-- Updating snapshot version" + curl -G --data-urlencode "ver=$NEW_VERSION" http://code.angularjs.org/fetchLatestSnapshot.php + exit 0; + fi + + cd $REPO_DIR + echo "-- Pushing code.angularjs.org" + git push origin master + + echo "-- Refreshing code.angularjs.org" + curl http://code.angularjs.org/gitFetchSite.php +} + +source $(dirname $0)/../utils.inc |
