summaryrefslogtreecommitdiff
path: root/ghclone
diff options
context:
space:
mode:
authorBen Sima <ben@bsima.me>2019-05-24 16:51:47 -0700
committerBen Sima <ben@bsima.me>2019-05-24 16:51:47 -0700
commitb218f9b9c4bd2bf1a5655a50e853a1df087214d2 (patch)
tree97c32935da6fc8c646f01f9200d09fa00fbc8418 /ghclone
parentd0ddaecd969238e9e645a8b38dbbc5ccf7051298 (diff)
add copy of jb55's gh-clone script
Diffstat (limited to 'ghclone')
-rwxr-xr-xghclone47
1 files changed, 47 insertions, 0 deletions
diff --git a/ghclone b/ghclone
new file mode 100755
index 0000000..6481a82
--- /dev/null
+++ b/ghclone
@@ -0,0 +1,47 @@
+#!/usr/bin/env bash
+
+set -e
+
+usage () {
+ printf "usage: $(basename $0) <owner>[/]<repo>\n" >&2
+ exit 1
+}
+
+already_exists () {
+ printf "%s\n" "$2"
+ exit 2
+}
+
+root=${GITHUB_ROOT:-"$HOME/src"}
+owner="$1"
+repo="$2"
+
+[ -z "$owner" ] && usage
+
+if [ -z "$repo" ]; then
+ IFS='/' read -ra parsed <<< "$owner"
+ owner="${parsed[0]}"
+ repo="${parsed[1]}"
+ if [ -z "$owner" ] || [ -z "$repo" ]; then
+ usage
+ fi
+fi
+
+dest="$root/$owner"
+dir="$dest/$repo"
+
+[ -d "$dir" ] && already_exists "$owner/$repo" "$dir"
+
+mkdir -p "$dest"
+cd "$dest"
+git clone "gh:$owner/$repo"
+
+git config \
+ --file="$dir/.git/config" \
+ --add remote.origin.fetch '+refs/pull/*/head:refs/pull/origin/*'
+
+git config \
+ --file="$dir/.git/config" \
+ --add remote.origin.fetch '+refs/pull/*/merge:refs/merge/origin/*'
+
+printf "%s\n" "$dest/$repo"