[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]

[or-cvs] [https-everywhere/master 3/5] added "uncommitted" target for makexpi.sh



Author: Daniel Kahn Gillmor <dkg@xxxxxxxxxxxxxxxxx>
Date: Tue, 9 Nov 2010 14:38:46 -0500
Subject: added "uncommitted" target for makexpi.sh
Commit: abbea034da969079a27d65dd3600265b109d3ee7

---
 makexpi.sh |   40 +++++++++++++++++++++++++++++++++-------
 1 files changed, 33 insertions(+), 7 deletions(-)

diff --git a/makexpi.sh b/makexpi.sh
index e408f8d..1e05d01 100755
--- a/makexpi.sh
+++ b/makexpi.sh
@@ -7,7 +7,10 @@ APP_NAME=https-everywhere
 # invoke with no arguments to pull a prerelease of the current
 # development point.
 
-# invoke with a tag name to build a specific branch.
+# invoke with the literal argument "uncommitted" to build from the
+# current src directory.
+
+# invoke with a tag name to build a specific branch or tag.
 
 # e.g.:
 #  ./makexpi.sh 0.2.3.development.2
@@ -15,24 +18,47 @@ APP_NAME=https-everywhere
 # or just:
 #  ./makexpi.sh
 
-if [ "$1" ] ; then
+# BUGS: if you have a branch or tagged named "uncommitted" then this
+# is kind of ambiguous.
+
+cd "$(dirname $0)"
+
+if [ -n "$1" ] && [ "$1" != "uncommitted" ]; then
     VERSION="$1"
     TARG="$1"
 else
     VERSION="$(grep em:version src/install.rdf | sed -e 's/[<>]/	/g' | cut -f3)~pre"
     TARG=HEAD
-    if [ -n "$(git status -s)" ] ; then
-        printf "WARNING: There are uncommitted changes in your current repostitory.\nWARNING: These changes will not be included in the generated .xpi\nWARNING: Run 'git status' for information about the uncommitted changes.\n" >&2
+    if [ "$1" != "uncommitted" ] && [ -n "$(git status src -s)" ] ; then
+        printf >&2 "\
+WARNING: There are uncommitted changes in your current repostitory.
+WARNING: These changes will not be included in the generated .xpi
+WARNING: Run 'git status' for information about the uncommitted changes.
+WARNING: Or, use 'makexpi.sh uncommitted' to include them in the build.
+" 
     fi
 fi
 XPI_NAME="pkg/$APP_NAME-$VERSION.xpi"
 
-cd "$(dirname $0)/src"
-git archive --format=zip -9 "$TARG" . > "../$XPI_NAME"
+cd "src"
+if [ "$1" == "uncommitted" ]; then
+    printf >&2 "WARNING: using zip instead of git archive to build .xpi\n"
+    CHANGES="$(git status . -s)"
+    if [ -n "$CHANGES" ]; then
+        printf >&2 "WARNING: uncommitted changes were included:\n%s\n" "$CHANGES"
+    fi
+    # FIXME: is it really acceptable to reuse .gitignore to specify
+    # include patterns for /usr/bin/zip?  It seems to work for our
+    # current patterns (2010-11-09)
+    zip -X -q -9r "../$XPI_NAME" . "-x@../.gitignore"
+else
+    git archive --format=zip -9 "$TARG" . > "../$XPI_NAME"
+fi
+
 ret="$?"
 if [ "$ret" != 0 ]; then
     rm -f "../$XPI_NAME"
     exit "$?"
 else
-  echo Created $XPI_NAME
+  printf >&2 "Created %s\n" "$XPI_NAME"
 fi
-- 
1.7.1