diff options
| author | mbm <mbm@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2004-05-25 04:32:27 +0000 | 
|---|---|---|
| committer | mbm <mbm@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2004-05-25 04:32:27 +0000 | 
| commit | 3ac1acb9ea70080aaaf49ae211835f057e60eefa (patch) | |
| tree | a2e08d2be3224409a033d25af8861d9853e72de7 /obsolete-buildroot/sources/patch-kernel.sh | |
| parent | 1eb1b593980fdc06ab92f8e354129b0aadc4f1b0 (diff) | |
Initial revision
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@30 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'obsolete-buildroot/sources/patch-kernel.sh')
| -rwxr-xr-x | obsolete-buildroot/sources/patch-kernel.sh | 53 | 
1 files changed, 53 insertions, 0 deletions
diff --git a/obsolete-buildroot/sources/patch-kernel.sh b/obsolete-buildroot/sources/patch-kernel.sh new file mode 100755 index 000000000..79401c2a7 --- /dev/null +++ b/obsolete-buildroot/sources/patch-kernel.sh @@ -0,0 +1,53 @@ +#! /bin/sh +# A little script I whipped up to make it easy to +# patch source trees and have sane error handling +# -Erik +# +# (c) 2002 Erik Andersen <andersen@codepoet.org> + +# Set directories from arguments, or use defaults. +targetdir=${1-.} +patchdir=${2-../kernel-patches} +patchpattern=${3-*} + +if [ ! -d "${targetdir}" ] ; then +    echo "Aborting.  '${targetdir}' is not a directory." +    exit 1 +fi +if [ ! -d "${patchdir}" ] ; then +    echo "Aborting.  '${patchdir}' is not a directory." +    exit 1 +fi +     +for i in ${patchdir}/${patchpattern} ; do  +    case "$i" in +	*.gz) +	type="gzip"; uncomp="gunzip -dc"; ;;  +	*.bz) +	type="bzip"; uncomp="bunzip -dc"; ;;  +	*.bz2) +	type="bzip2"; uncomp="bunzip2 -dc"; ;;  +	*.zip) +	type="zip"; uncomp="unzip -d"; ;;  +	*.Z) +	type="compress"; uncomp="uncompress -c"; ;;  +	*) +	type="plaintext"; uncomp="cat"; ;;  +    esac +    echo "" +    echo "Applying ${i} using ${type}: "  +    ${uncomp} ${i} | patch -p1 -E -d ${targetdir}  +    if [ $? != 0 ] ; then +        echo "Patch failed!  Please fix $i!" +	exit 1 +    fi +done + +# Check for rejects... +if [ "`find $targetdir/ '(' -name '*.rej' -o -name '.*.rej' ')' -print`" ] ; then +    echo "Aborting.  Reject files found." +    exit 1 +fi + +# Remove backup files +find $targetdir/ '(' -name '*.orig' -o -name '.*.orig' ')' -exec rm -f {} \;  | 
