summaryrefslogtreecommitdiffstats
path: root/Werkzeug
diff options
context:
space:
mode:
authortv <tv@xso>2011-09-06 16:29:50 +0200
committertv <tv@xso>2011-09-06 16:29:50 +0200
commitda541cdd4c926de01198edc31e4500ccb9a6a457 (patch)
treed2c8e4b8bc45a9009128c3f97672a79b818447d0 /Werkzeug
parentf909f3d53ad44874d4f51f7efbb2533c1ea482fe (diff)
//Refactory -> //Werkzeug: solve name clash
Diffstat (limited to 'Werkzeug')
-rw-r--r--Werkzeug/Makefile2
-rwxr-xr-xWerkzeug/bin/git-clone-into48
-rwxr-xr-xWerkzeug/bin/git-eternal-move15
3 files changed, 65 insertions, 0 deletions
diff --git a/Werkzeug/Makefile b/Werkzeug/Makefile
new file mode 100644
index 00000000..57b983df
--- /dev/null
+++ b/Werkzeug/Makefile
@@ -0,0 +1,2 @@
+install:
+ ln -snf $$PWD/bin/git-clone-into ../bin/
diff --git a/Werkzeug/bin/git-clone-into b/Werkzeug/bin/git-clone-into
new file mode 100755
index 00000000..67e820e6
--- /dev/null
+++ b/Werkzeug/bin/git-clone-into
@@ -0,0 +1,48 @@
+#! /bin/sh
+#
+# usage: git-clone-into repository directory
+#
+set -euf
+
+tempdir() {
+ set -- `tempnam $1`
+ mkdir $1
+ echo $1
+}
+
+## [prefix] -> tempnam
+tempnam() {
+ until set -- $1 ${1-}`candnam` && ! test -e $2; do :; done
+ echo $2
+}
+
+candnam() {
+ uuidgen 2>/dev/null || date +%s%N
+}
+
+
+
+ tmp_remote=`candnam`
+ tmp_branch=`candnam`
+
+ subdir=$2
+ if test -e $subdir; then
+ echo 'You are made of stupid!' >&2
+ exit 23
+ fi
+ tmpdir=`tempdir /tmp/tempdir-`
+ #trap "test -d $tmpdir && rm -vfR $tmpdir" EXIT
+ trap "test -d $tmpdir && rm -fR $tmpdir" EXIT
+ repository="${1-$repository}"
+ git clone "$repository" $tmpdir
+ (cd $tmpdir
+ subdir="$subdir" git filter-branch --tree-filter '
+ if ! test -d $subdir; then
+ mkdir -p $subdir
+ git ls-tree -z --name-only $GIT_COMMIT | xargs -I. --null mv . $subdir
+ fi
+ '
+ git checkout -b $tmp_branch)
+ git remote add $tmp_remote $tmpdir
+ git fetch $tmp_remote
+ git merge $tmp_remote/$tmp_branch # TODO configurable branch
diff --git a/Werkzeug/bin/git-eternal-move b/Werkzeug/bin/git-eternal-move
new file mode 100755
index 00000000..50361e7b
--- /dev/null
+++ b/Werkzeug/bin/git-eternal-move
@@ -0,0 +1,15 @@
+#! /bin/sh
+#
+# git-eternal-move FROM TO-DIRECTORY
+#
+set -euf
+if test $# -ne 2; then
+ echo 'Error 1: You are made of stupid!' >&2
+ exit 23
+fi
+exec git filter-branch --tree-filter "
+ set -euf
+ if test -e '$1'; then
+ mkdir -p '$2'
+ mv '$1' '$2'
+ fi"