apply-patches.sh: add recursivity when scanning patchdir
authorLudovic Desroches <ludovic.desroches@atmel.com>
Wed, 21 Mar 2012 13:26:27 +0000 (14:26 +0100)
committerPeter Korsgaard <jacmet@sunsite.dk>
Wed, 21 Mar 2012 12:47:27 +0000 (13:47 +0100)
Recursivity is needed with some tarballs containing debian patches:
.
  debian
    changelog
    control
    patches
      02-COPYRIGHT.patch
[...]

Since we can find some files which are not patches in those directories, only
consider .patch* and .diff* files as valid patches.
Due to recursivity, strip-components option is no more necessary so it has
been removed.

Signed-off-by: Ludovic Desroches <ludovic.desroches@atmel.com>
Signed-off-by: Peter Korsgaard <jacmet@sunsite.dk>
support/scripts/apply-patches.sh

index 968e2a406ce0c0d80390d6442e064fe6b2e86329..e4b98bc0575dcc7be2a00f4234d0f12a7c9aff0a 100755 (executable)
@@ -40,8 +40,14 @@ function apply_patch {
        type="zip"; uncomp="unzip -d"; ;; 
        *.Z)
        type="compress"; uncomp="uncompress -c"; ;; 
+       *.diff*)
+       type="diff"; uncomp="cat"; ;;
+       *.patch*)
+       type="patch"; uncomp="cat"; ;;
        *)
-       type="plaintext"; uncomp="cat"; ;; 
+       echo "Unsupported format file for ${patch}, skip it";
+       return 0;
+       ;;
     esac
     echo ""
     echo "Applying $patch using ${type}: "
@@ -67,12 +73,12 @@ function scan_patchdir {
     else
         for i in `cd $path; ls -d $patches 2> /dev/null` ; do
             if [ -d "${path}/$i" ] ; then
-                echo "${path}/$i skipped"
+                scan_patchdir "${path}/$i"
             elif echo "$i" | grep -q -E "\.tar(\..*)?$|\.tbz2?$|\.tgz$" ; then
                 unpackedarchivedir="$builddir/.patches-$(basename $i)-unpacked"
                 rm -rf "$unpackedarchivedir" 2> /dev/null
                 mkdir "$unpackedarchivedir"
-                tar -C "$unpackedarchivedir" --strip-components=1 -xaf "${path}/$i"
+                tar -C "$unpackedarchivedir" -xaf "${path}/$i"
                 scan_patchdir "$unpackedarchivedir"
             else
                 apply_patch "$path" "$i" || exit 1