forked from alexforencich/verilog-ethernet
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathupdate-axis.sh
executable file
·118 lines (101 loc) · 2.82 KB
/
update-axis.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
#!/bin/bash
# Git subtree manager
# Alex Forencich <[email protected]>
# This script facilitates easy management of subtrees
# included in larger repositories as this script can
# be included in the repository itself.
# Settings
# uncomment to use --squash
#squash="yes"
# Remote repository
repo="[email protected]:alexforencich/verilog-axis.git"
# Remote name
remote="axis"
# Subdirectory to store code in
# (relative to repo root or to script location)
#subdir="axis"
rel_subdir="axis"
# Remote branch
branch="master"
# Backport branch name (only used for pushing)
backportbranch="${remote}backport"
# Add commit message
addmsg="added ${remote} as a subproject"
# Merge commit message
mergemsg="merged changes in ${remote}"
# Usage
# add - adds subtree
# pull - default, pulls from remote
# push - pushes to remote
# determine repo absolute path
if [ -n "$rel_subdir" ]; then
# cd to script dir
SOURCE="${BASH_SOURCE[0]}"
while [ -h "$SOURCE" ]; do # resolve $SOURCE until the file is no longer a symlink
DIR="$( cd -P "$( dirname "$SOURCE" )" && pwd )"
SOURCE="$(readlink "$SOURCE")"
[[ $SOURCE != /* ]] && SOURCE="$DIR/$SOURCE" # if $SOURCE was a relative symlink, we need to resolve it relative to the path where the symlink file was located
done
DIR="$( cd -P "$( dirname "$SOURCE" )" && pwd )"
cd "$DIR"
# relative path to script dir
git-absolute-path () {
fullpath=$(readlink -f "$1")
gitroot="$(git rev-parse --show-toplevel)" || return 1
[[ "$fullpath" =~ "$gitroot" ]] && echo "${fullpath/$gitroot\//}"
}
subdir="$(git-absolute-path .)/$rel_subdir"
fi
squashflag=""
cd $(git rev-parse --show-toplevel)
if [ $squash ]; then
squashflag="--squash"
fi
action="pull"
if [ ! -d "$subdir" ]; then
action="add"
fi
if [ -n "$1" ]; then
action="$1"
fi
# array contains value
# usage: contains array value
function contains() {
local n=$#
local value=${!n}
for ((i=1;i < $n;i++)) {
if [ "${!i}" == "${value}" ]; then
echo "y"
return 0
fi
}
echo "n"
return 1
}
case "$action" in
add)
if [ $(contains $(git remote) "$remote") != "y" ]; then
git remote add "$remote" "$repo"
fi
git fetch "$remote"
git subtree add -P "$subdir" $squashflag -m "$addmsg" "$remote/$branch"
;;
pull)
if [ $(contains $(git remote) "$remote") != "y" ]; then
git remote add "$remote" "$repo"
fi
git fetch "$remote"
git subtree merge -P "$subdir" $squashflag -m "$mergemsg" "$remote/$branch"
;;
push)
if [ $(contains $(git remote) "$remote") != "y" ]; then
git remote add "$remote" "$repo"
fi
git subtree split -P "$subdir" -b "$backportbranch"
git push "$remote" "$backportbranch:$branch"
;;
*)
echo "Error: unknown action!"
exit 1
esac
exit 0