summaryrefslogtreecommitdiffstats
path: root/media/webrtc/webrtc_update.sh
diff options
context:
space:
mode:
Diffstat (limited to 'media/webrtc/webrtc_update.sh')
-rw-r--r--media/webrtc/webrtc_update.sh101
1 files changed, 101 insertions, 0 deletions
diff --git a/media/webrtc/webrtc_update.sh b/media/webrtc/webrtc_update.sh
new file mode 100644
index 000000000..d6a44a9d7
--- /dev/null
+++ b/media/webrtc/webrtc_update.sh
@@ -0,0 +1,101 @@
+#!/bin/bash
+# This Source Code Form is subject to the terms of the Mozilla Public
+# License, v. 2.0. If a copy of the MPL was not distributed with this file,
+# You can obtain one at http://mozilla.org/MPL/2.0/.
+
+# First, get a new copy of the tree to play with
+# They both want to be named 'trunk'...
+mkdir webrtc_update
+cd webrtc_update
+
+# Note: must be in trunk; won't work with --name (error during sync)
+gclient config --name trunk http://webrtc.googlecode.com/svn/trunk/peerconnection
+gclient sync --force
+if [ $2 ] ; then
+if [ $3 ] ; then
+ echo
+else
+ sed -i -e "s/\"webrtc_revision\":.*,/\"webrtc_revision\": \"$1\",/" -e "s/\"libjingle_revision\":.*,/\"libjingle_revision\": \"$2\",/" trunk/DEPS
+ gclient sync --force
+fi
+fi
+
+if [ $3 ] ; then
+echo "Updating from $3..."
+rm -rf trunk/third_party/webrtc
+mkdir trunk/src
+cp -a $3/webrtc/* trunk/src
+fi
+
+cd trunk
+
+export date=`date`
+export revision=`svnversion -n`
+if [ $1 ] ; then
+ echo "WebRTC revision overridden from $revision to $1"
+ export revision=$1
+else
+ echo "WebRTC revision = $revision"
+fi
+
+cd ../../media/webrtc
+
+# safety - make it easy to find our way out of the forest
+hg tag -f -l old-tip
+
+# Ok, now we have a copy of the source. See what changed
+# (webrtc-import-last is a bookmark)
+# FIX! verify no changes in webrtc!
+hg update --clean webrtc-import-last
+
+rm -rf trunk
+mv ../../webrtc_update/trunk trunk
+mv -f ../../webrtc_update/.g* .
+rmdir ../../webrtc_update
+(hg addremove --exclude "**webrtcsessionobserver.h" --exclude "**webrtcjson.h" --exclude "**.svn" --exclude "**.git" --exclude "**.pyc" --exclude "**.yuv" --similarity 70 --dry-run trunk; hg status -m; echo "************* Please look at the filenames found by rename and see if they match!!! ***********" ) | less
+
+# FIX! Query user about add-removes better!!
+echo "Waiting 30 seconds - Hit ^C now to stop addremove and commit!"
+sleep 30 # let them ^C
+
+# Add/remove files, detect renames
+hg addremove --exclude "**webrtcsessionobserver.h" --exclude "**webrtcjson.h" --exclude "**.svn" --exclude "**.git" --exclude "**.pyc" --exclude "**.yuv" --similarity 70 trunk
+hg status -a -r >/tmp/changed_webrtc_files
+
+# leave this for the user for now until we're comfortable it works safely
+
+# Commit the vendor branch
+echo "Commit, merge and push to server - cut and paste"
+echo "You probably want to do these from another shell so you can look at these"
+hg commit -m "Webrtc import $revision"
+# webrtc-import-last is auto-updated (bookmark)
+
+#echo ""
+#hg update --clean webrtc-pending
+#hg merge -r webrtc-import-last
+#hg commit -m "merge latest import to pending, $revision"
+# webrtc-pending is auto-updated (bookmark)
+
+echo ""
+echo "hg update --clean webrtc-trim"
+echo "hg merge -r webrtc-import-last"
+echo "hg commit -m 'merge latest import to trim, $revision'"
+# webrtc-trim is auto-updated (bookmark)
+
+# commands to pull - never do more than echo them for the user
+echo ""
+echo "Here's how to pull this update into the mozilla repo:"
+echo "cd your_tree"
+echo "hg qpop -a"
+echo "hg pull --bookmark webrtc-trim path-to-webrtc-import-repo"
+echo "hg merge"
+echo "echo '#define WEBRTC_SVNVERSION $revision' >media/webrtc/webrtc_version.h"
+echo "echo '#define WEBRTC_PULL_DATE \"$date\"' >>media/webrtc/webrtc_version.h"
+echo "hg commit -m 'Webrtc updated to $revision; pull made on $date'"
+echo ""
+echo "Please check for added/removed/moved .gyp/.gypi files, and if so update EXTRA_CONFIG_DEPS in client.mk!"
+echo "possible gyp* file changes:"
+grep gyp /tmp/changed_webrtc_files
+echo ""
+echo "Once you feel safe:"
+echo "hg push"