]> git.ozlabs.org Git - next-scripts/blob - do_merge1
make_tree_file: ABAT can fetch a git tree
[next-scripts] / do_merge1
1 #!/bin/bash
2
3 LOG_FILE="../merge.log"
4 build_host="sprygo"
5 build_dir="/scratch/sfr/next"
6 build_cmd="bin/build_next"
7
8 no_build=false
9 [ "$1" = "-n" ] && {
10         shift
11         no_build=true
12 }
13 [ -n "$1" ] && build_host="$1"
14
15 log()
16 {
17         echo "$@" | tee -a $LOG_FILE
18 }
19
20 execute()
21 {
22         log "$" $@
23         $@ 2>&1 | tee -a $LOG_FILE
24         return ${PIPESTATUS[0]}
25 }
26
27 heads=$(grep -v '^#' ../real_control | awk -F ' ' '$2=="quilt" { printf("quilt/%s ", $3); } $2=="git" { printf("%s/%s ", $3, $5); }')
28
29 for h in $heads; do
30         log Merging $h
31         old_head=$(git rev-parse HEAD)
32         execute git merge $h || {
33                 echo Merge failed 1>&2
34                 bash -i || exit
35                 GIT_EDITOR=: execute git commit -v -a
36                 execute git diff -M --stat --summary 'HEAD^..'
37         }
38         new_head=$(git rev-parse HEAD)
39         [ "$old_head" = "$new_head" ] && continue
40         $no_build && continue
41         rsync -avH --exclude .git --delete . "$build_host":"$build_dir"/. || {
42                 echo Rsync failed 1>&2
43                 bash -i || exit
44         }
45         ssh "$build_host" "$build_cmd" || {
46                 echo Build failed 1>&2
47                 bash -i || exit
48         }
49 done
50
51 exit 0