summaryrefslogtreecommitdiff
path: root/localvcshinit
diff options
context:
space:
mode:
authorJonas Smedegaard <dr@jones.dk>2015-02-21 16:19:56 +0100
committerJonas Smedegaard <dr@jones.dk>2015-02-21 16:19:56 +0100
commitafc03d0224f04b0bd57402408e608c6ef81b522d (patch)
treebd28b13b081a1f117a78a8876f9f44b4320b96d5 /localvcshinit
parenta95890790e41ec1d96c1d56eacb71c6dd97856e8 (diff)
Add localmrsync and localvcshinit.
Diffstat (limited to 'localvcshinit')
-rwxr-xr-xlocalvcshinit73
1 files changed, 73 insertions, 0 deletions
diff --git a/localvcshinit b/localvcshinit
new file mode 100755
index 0000000..9f9da81
--- /dev/null
+++ b/localvcshinit
@@ -0,0 +1,73 @@
+#!/bin/sh
+# Copyright © 2014-2015 Jonas Smedegaard <dr@jones.dk>
+# Description: initialize vcsh local + remote git repository
+#
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3, or (at your option)
+# any later version.
+#
+# This program is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+# General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+# Depends: vcsh git
+
+set -eu
+
+skel_url=https://github.com/RichiH/vcsh_mr_template
+
+PRG=$(basename "$0")
+
+showhelp() {
+ cat <<EOF
+Usage: $PRG REPO BASE_URL
+
+Examples:
+ $PRG project git+ssh://source.example.org/srv/git/project
+
+EOF
+}
+
+exit1() {
+ response="${1:+Error: }${1:-Internal error!}"
+ echo >&2 "$response"
+ exit 1
+}
+
+repo=${1:-mr}
+base_url="$2"
+url="$base_url/$repo"
+
+if [ $# -ne 2 ]; then
+ showhelp
+ exit1 "wrong parameters"
+fi
+
+if ! vcsh list | grep -Fxq "$repo"; then
+ if [ vcsh = "$repo" ]; then
+ url="$base_url"
+ vcsh clone $skel_url mr
+ vcsh "$repo" remote set-url origin "$url"
+ else
+ vcsh init "$repo"
+ vcsh "$repo" remote add origin "$url"
+ fi
+fi
+
+host=$(echo "$url" | sed -e 's/:.*//')
+path=$(echo "$url" | sed -e 's/.*://')
+if ssh "$host" test -d "$path.git"; then
+ echo "Skipping vcsh remote \"$repo\" already pushed"
+else
+ ssh "$host" mkdir -p "$(dirname "$path")"
+ ssh "$host" git init --bare "$path.git"
+ vcsh "$repo" push --set-upstream origin master
+fi
+
+printf 'Done (press return)'
+read foo