summaryrefslogtreecommitdiffstats
path: root/util/update_chibios_mirror.sh
blob: 05e22fa2eaa91cf2578f556fd5d1a9bcfbcb2983 (plain)
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
#!/bin/bash

################################
# Configuration

# The ChibiOS branches to mirror
chibios_branches="trunk stable_20.3.x stable_21.11.x"

# The ChibiOS tags to mirror
chibios_tags="ver20.3.1 ver20.3.2 ver20.3.3 ver20.3.4 ver21.11.1 ver21.11.2 ver21.11.3"

# The ChibiOS-Contrib branches to mirror
contrib_branches="chibios-20.3.x chibios-21.11.x"

################################
# Actions

set -eEuo pipefail
umask 022

this_script="$(realpath "${BASH_SOURCE[0]}")"
script_dir="$(realpath "$(dirname "$this_script")")"
qmk_firmware_dir="$(realpath "$script_dir/../")"
chibios_dir="$qmk_firmware_dir/lib/chibios"
contrib_dir="$qmk_firmware_dir/lib/chibios-contrib"

chibios_git_location=$(realpath "$chibios_dir/$(cat "$chibios_dir/.git" | awk '/gitdir:/ {print $2}')")
chibios_git_config=$(realpath "$chibios_git_location/config")
contrib_git_location=$(realpath "$contrib_dir/$(cat "$contrib_dir/.git" | awk '/gitdir:/ {print $2}')")
contrib_git_config=$(realpath "$contrib_git_location/config")

cd "$chibios_dir"

if [[ -z "$(cat "$chibios_git_config" | grep '\[svn-remote "svn"\]')" ]] ; then
    git svn init --stdlayout --prefix='svn/' https://svn.code.sf.net/p/chibios/code/
fi

if [[ -z "$(cat "$chibios_git_config" | grep '\[remote "qmk"\]')" ]] ; then
    git remote add qmk git@github.com:qmk/ChibiOS.git
    git remote set-url qmk git@github.com:qmk/ChibiOS.git --push
else
    git remote set-url qmk git@github.com:qmk/ChibiOS.git
    git remote set-url qmk git@github.com:qmk/ChibiOS.git --push
fi

echo "Updating remotes..."
git fetch --all --tags --prune

echo "Fetching latest from subversion..."
git svn fetch

echo "Updating ChibiOS branches..."
for branch in $chibios_branches ; do
    echo "Creating branch 'svn-mirror/$branch' from 'svn/$branch'..."
    git branch -f svn-mirror/$branch svn/$branch \
        && git push qmk svn-mirror/$branch
done

echo "Updating ChibiOS tags..."
for tagname in $chibios_tags ; do
    echo "Creating tag 'svn-mirror/$tagname' from 'svn/tags/$tagname'..."
    GIT_COMMITTER_DATE="$(git log -n1 --pretty=format:'%ad' svn/tags/$tagname)" git tag -f -a -m "Tagging $tagname" svn-mirror/$tagname svn/tags/$tagname
    git push qmk svn-mirror/$tagname
done

cd "$contrib_dir"

if [[ -z "$(cat "$contrib_git_config" | grep '\[remote "qmk"\]')" ]] ; then
    git remote add qmk git@github.com:qmk/ChibiOS-Contrib.git
    git remote set-url qmk git@github.com:qmk/ChibiOS-Contrib.git --push
else
    git remote set-url qmk git@github.com:qmk/ChibiOS-Contrib.git
    git remote set-url qmk git@github.com:qmk/ChibiOS-Contrib.git --push
fi

if [[ -z "$(cat "$contrib_git_config" | grep '\[remote "upstream"\]')" ]] ; then
    git remote add upstream git@github.com:ChibiOS/ChibiOS-Contrib.git
    git remote set-url upstream git@github.com:ChibiOS/ChibiOS-Contrib.git --push
else
    git remote set-url upstream git@github.com:ChibiOS/ChibiOS-Contrib.git
    git remote set-url upstream git@github.com:ChibiOS/ChibiOS-Contrib.git --push
fi

echo "Updating remotes..."
git fetch --all --tags --prune

echo "Updating ChibiOS-Contrib branches..."
for branch in $contrib_branches ; do
    echo "Creating branch 'mirror/$branch' from 'upstream/$branch'..."
    git branch -f mirror/$branch upstream/$branch \
        && git push qmk mirror/$branch || true # Allow for nonexistent ChibiOS-Contrib branches -- they'll turn up eventually.
done