File: squash_commit.sh

package info (click to toggle)
mpich 4.3.2-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 101,184 kB
  • sloc: ansic: 1,040,629; cpp: 82,270; javascript: 40,763; perl: 27,933; python: 16,041; sh: 14,676; xml: 14,418; f90: 12,916; makefile: 9,270; fortran: 8,046; java: 4,635; asm: 324; ruby: 103; awk: 27; lisp: 19; php: 8; sed: 4
file content (77 lines) | stat: -rwxr-xr-x 1,629 bytes parent folder | download | duplicates (2)
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
#!/bin/bash -eEu
#
# Copyright (c) NVIDIA CORPORATION & AFFILIATES, 2023. ALL RIGHTS RESERVED.
# See file LICENSE for terms.
#
# Prepare one commit after PR has been approved.
#

message=
parent=
remote=

usage() {
    echo "usage: $0 -m <commit_message> [-r <remote_branch>] [-p <new_parent>]" >&2
    echo "" >&2
    echo "Arguments" >&2
    echo "  -m <commit_message>     commit message to use" >&2
    echo "  -r <remote_branch>      upstream master branch to merge into" >&2
    echo "  -p <new_parent>         new base to use for squashed commit" >&2
    echo "" >&2
    echo "Sample" >&2
    echo "    $0 -m \"Commit message\" -r upstream/master" >&2
    echo "    $0 -m \"Commit message\" -p adef30" >&2
    exit 1
}

param_checks() {
    if [ -z "$message" ]
    then
        usage
    fi

    if [ -z "$parent" ] && [ -z "$remote" ]
    then
        echo "error: parent must be specified when remote is missing (-p)" >&2
        exit 1
    fi

    if [ -z "$parent" ]
    then
        parent=$(git merge-base HEAD "$remote")
    fi

    object=$(git cat-file -t "$parent" || :)

    if [ "$object" != "commit" ]
    then
        echo "error: parent sha1 $parent is not a commit" >&2
        exit 1
    fi
}

while getopts "hm:r:p:" o; do
    case "$o" in
    m)
        message="$OPTARG"
        ;;
    r)
        remote="$OPTARG"
        ;;
    p)
        parent="$OPTARG"
        ;;
    *)
        usage
        ;;
    esac
done

param_checks

revision=$(git rev-parse HEAD)
tree=$(git rev-parse "$revision"^{tree})
commit=$(git commit-tree "$tree" -m "$message" -p "$parent")

git reset "$commit"
git log -2 --stat