On 28/08/2015 09:15, Gavin Shan wrote:
> This submits changes with formatted commit log while updating Linux
> headers using scripts/update-linux-headers.sh.
> 
> Signed-off-by: Gavin Shan <[email protected]>
> ---
>  scripts/update-linux-headers.sh | 24 ++++++++++++++++++++++++
>  1 file changed, 24 insertions(+)
> 
> diff --git a/scripts/update-linux-headers.sh b/scripts/update-linux-headers.sh
> index 18daabe..1be02b8 100755
> --- a/scripts/update-linux-headers.sh
> +++ b/scripts/update-linux-headers.sh
> @@ -63,6 +63,28 @@ cp_virtio() {
>      fi
>  }
>  
> +submit_change() {
> +    from=$1
> +    to=$2
> +    if ! [ -e $to/include/qemu-common.h ]; then
> +        echo "$to not QEMU source directory, skip submitting changes"
> +        exit 3
> +    fi
> +
> +    version=$(make -C $from -s kernelversion)
> +    commit=$(cd $from && git log --oneline -1 | cut -d " " -f 1)

it's a detail, but you can use directly: git log --format="%h" -1

> +    subject="Synchronize Linux headers from kernel $version"
> +    message="Synchronize the Linux headers from kernel version $version"
> +    message=$(echo "$message\n(commit $commit)")
> +    res=$(cd $to && git commit -qa -m "$subject" -m "$message" -s && echo $?)
> +    if [ "$res" = "0" ]; then

another detail, but you should be able to do something like:

       if git commit -C $to -qa -m "$subject" -m "$message" -s ; then

> +        echo "Changes submitted successfully"
> +    else
> +        echo "Error $res submitting changes"
> +        exit 4
> +    fi
> +}
> +
>  # This will pick up non-directories too (eg "Kconfig") but we will
>  # ignore them in the next loop.
>  ARCHLIST=$(cd "$linux/arch" && echo *)
> @@ -132,3 +154,5 @@ cat <<EOF 
> >$output/include/standard-headers/linux/if_ether.h
>  EOF
>  
>  rm -rf "$tmpdir"
> +
> +submit_change "$linux" "$output"
> 

Reply via email to