fb65b02dcf
The script requires LINUX_GIT to be set, preferably, in your local .bashrc. I added a quick check to see if .bashrc exists and check it first to see if LINUX_GIT is set there. [labbott: Tweaked commit text] Signed-off-by: Miguel Flores Silverio <floresmigu3l@gmail.com>
45 lines
1.2 KiB
Bash
Executable File
45 lines
1.2 KiB
Bash
Executable File
#!/bin/sh
|
|
# This script allows for the generation of a git snapshot between the upstream
|
|
# git tree and the current tree.
|
|
#
|
|
# Prerequisites:
|
|
# Set LINUX_GIT to point to an upstream Linux git tree in your .bashrc
|
|
# or wherever.
|
|
|
|
# Look to see if LINUX_GIT is set in local .bashrc
|
|
if [ -f ~/.bashrc ]; then
|
|
source ~/.bashrc
|
|
fi
|
|
|
|
if [ ! -d "$LINUX_GIT" ]; then
|
|
echo "error: set \$LINUX_GIT to point at upstream git tree"
|
|
exit 1
|
|
fi
|
|
|
|
VER=$(grep patch sources | head -n1 | awk '{ print $2 }' | sed s/patch-// | sed s/-git.*// | sed s/.xz//)
|
|
|
|
if [ -z "$VER" ] ;
|
|
then
|
|
VER=$(grep linux sources | head -1 | awk '{ print $2 }' | sed s/linux-// | sed s/.tar.xz//)
|
|
fi
|
|
|
|
OLDGIT=$(grep gitrev kernel.spec | head -n1 | sed s/%define\ gitrev\ //)
|
|
export NEWGIT=$(($OLDGIT+1))
|
|
|
|
pushd $LINUX_GIT
|
|
|
|
git diff v$VER.. > /tmp/patch-$VER-git$NEWGIT
|
|
xz -9 /tmp/patch-$VER-git$NEWGIT
|
|
DESC=$(git describe)
|
|
git rev-list --max-count=1 HEAD > /tmp/gitrev
|
|
popd
|
|
|
|
mv /tmp/patch-$VER-git$NEWGIT.xz .
|
|
mv /tmp/gitrev .
|
|
|
|
perl -p -i -e 's|%global baserelease.*|%global baserelease 0|' kernel.spec
|
|
|
|
perl -p -i -e 's|%define gitrev.*|%define gitrev $ENV{'NEWGIT'}|' kernel.spec
|
|
|
|
rpmdev-bumpspec -c "Linux $DESC" kernel.spec
|