-
Notifications
You must be signed in to change notification settings - Fork 0
/
aurpublish
executable file
·94 lines (83 loc) · 2.66 KB
/
aurpublish
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
#!/bin/bash
# Declare usage
usage()
{
cat <<- _EOF_
Usage: ./aurpublish [OPTIONS] PACKAGE
Push a subtree to the AUR
OPTIONS
-p, --pull Instead of publishing, pull changes from the AUR.
Can import packages into a new subtree.
-s, --speedup Speedup future publishing by recording the subtree
history during a push. This creates a merge commit
and a second copy of all commits in the subtree.
For more details, see the "--rejoin" option in git
subtree.
-h, --help Show this usage message
COMMANDS
log Wrapper for \`git log\`, substituting a package
subtree for the revision/branch. This is only
useful if changes were pulled from the AUR
(because \`git log\` isn't very good at reading
subtrees).
_EOF_
}
# Function to test if package is already committed in git
is_package_in_git()
{
git ls-tree -d --name-only HEAD | grep -E "^${1}$" > /dev/null 2>&1
}
#### Do the great option check
if [[ $# -eq 0 ]]; then
echo "error: No arguments passed. aurpublish needs a package to upload."
exit 1
fi
while [[ "${1}" != "" ]]; do
case ${1} in
-h|--help)
usage
exit
;;
-p|--pull)
pull_subtree=1
shift
package="${1%/}"
;;
-s|--speedup)
speedup=1
;;
log)
shift
while [[ ! -d "${1}" ]]; do log_pre_opts+=("${1}"); shift; done
package="${1%/}"
shift
git log "${log_pre_opts[@]}" $(git subtree split -P "${package}") "$@"
exit
;;
*)
if is_package_in_git ${1%/}; then
package="${1%/}"
else
echo "${0}: unrecognized package '${1}'"
echo "Try '${0} --help' for more information."
exit 1
fi
esac
shift
done
#### MAIN
pkgbase="$(sed -rn 's/pkgbase = (.*)/\1/p' "${package}"/.SRCINFO 2>/dev/null)"
if [[ "${pull_subtree}" = "1" ]]; then
# test if prefix already exists
if is_package_in_git ${package}; then
git subtree split -P "${package}" --rejoin
git subtree pull -P "${package}" aur:${pkgbase}.git master -m "Merge subtree '${package}'"
else
git subtree add -P "${package}" aur:${package}.git master
fi
exit 0
fi
if [[ "${speedup}" = "1" ]]; then
git subtree split -P "${package}" --rejoin
fi
git subtree push -P "${package}" aur:${pkgbase}.git master