libretro-super/script-modules/fetch-rules.sh

48 lines
1.3 KiB
Bash

# vim: set ts=3 sw=3 noet ft=sh : bash
# fetch_git: Clones or pulls updates from a git repository into a local directory
#
# $1 The URI to fetch
# $2 The local directory to fetch to (relative)
# $3 Set to clone --recursive
# $4 Set to pull --recursive
#
# NOTE: git _now_ has a -C argument that would replace the cd commands in
# this rule, but this is a fairly recent addition to git, so we can't
# use it here. --iKarith
fetch_git() {
fetch_dir="$WORKDIR/$2"
if [ -d "$fetch_dir/.git" ]; then
echo_cmd "cd \"$fetch_dir\""
echo_cmd "git pull"
if [ -n "$4" ]; then
echo_cmd "git submodule foreach git pull origin master"
fi
else
clone_type=
[ -n "$SHALLOW_CLONE" ] && depth="--depth 1 "
echo_cmd "git clone $depth\"$1\" \"$WORKDIR/$2\""
if [ -n "$3" ]; then
echo_cmd "cd \"$fetch_dir\""
echo_cmd "git submodule update --init"
fi
fi
}
# fetch_revision_git: Output the hash of the last commit in a git repository
#
# $1 Local directory to run git in
fetch_revision_git() {
[ -n "$1" ] && cd "$1"
git log -n 1 --pretty=format:%H
}
# fetch_revision: Output SCM-dependent revision string of a module
# (currently just calls fetch_revision_git)
#
# $1 The directory of the module
fetch_revision() {
fetch_revision_git $1
}