Harald Hoyer 9e9f8f
From 04febed7822979d38cecb47b8675d021bbd7bd72 Mon Sep 17 00:00:00 2001
Harald Hoyer 9e9f8f
From: Will Woods <wwoods@redhat.com>
Harald Hoyer 9e9f8f
Date: Thu, 8 Mar 2012 18:02:29 -0500
Harald Hoyer 9e9f8f
Subject: [PATCH] img-lib: fix unpack_img()
Harald Hoyer 9e9f8f
Harald Hoyer 9e9f8f
- det_img should have been det_archive
Harald Hoyer 9e9f8f
- for ft=xz|gzip|bzip2, decompr should be "$ft -dc"
Harald Hoyer 9e9f8f
---
Harald Hoyer 9e9f8f
 modules.d/99img-lib/img-lib.sh |    7 ++++---
Harald Hoyer 9e9f8f
 1 file changed, 4 insertions(+), 3 deletions(-)
Harald Hoyer 9e9f8f
Harald Hoyer 9e9f8f
diff --git a/modules.d/99img-lib/img-lib.sh b/modules.d/99img-lib/img-lib.sh
Harald Hoyer 9e9f8f
index f6be26d..22507aa 100755
Harald Hoyer 9e9f8f
--- a/modules.d/99img-lib/img-lib.sh
Harald Hoyer 9e9f8f
+++ b/modules.d/99img-lib/img-lib.sh
Harald Hoyer 9e9f8f
@@ -1,12 +1,13 @@
Harald Hoyer 9e9f8f
 #!/bin/sh
Harald Hoyer 9e9f8f
 # img-lib.sh: utilities for dealing with archives and filesystem images.
Harald Hoyer 9e9f8f
 #
Harald Hoyer 9e9f8f
-# TODO: identify/unpack rpm, deb?
Harald Hoyer 9e9f8f
+# TODO: identify/unpack rpm, deb, maybe others?
Harald Hoyer 9e9f8f
 
Harald Hoyer 9e9f8f
 
Harald Hoyer 9e9f8f
 # super-simple "file" that only identifies archives.
Harald Hoyer 9e9f8f
 # works with stdin if $1 is not set.
Harald Hoyer 9e9f8f
 det_archive() {
Harald Hoyer 9e9f8f
+    # NOTE: echo -e works in ash and bash, but not dash
Harald Hoyer 9e9f8f
     local bz="BZh" xz="$(echo -e '\xfd7zXZ')" gz="$(echo -e '\x1f\x8b')"
Harald Hoyer 9e9f8f
     local headerblock="$(dd ${1:+if=$1} bs=262 count=1 2>/dev/null)"
Harald Hoyer 9e9f8f
     case "$headerblock" in
Harald Hoyer 9e9f8f
@@ -32,7 +33,7 @@ unpack_archive() {
Harald Hoyer 9e9f8f
     local img="$1" outdir="$2" archiver="" decompr=""
Harald Hoyer 9e9f8f
     local ft="$(det_archive $img)"
Harald Hoyer 9e9f8f
     case "$ft" in
Harald Hoyer 9e9f8f
-        xz|gzip|bzip2) decompr="$decompr -dc" ;;
Harald Hoyer 9e9f8f
+        xz|gzip|bzip2) decompr="$ft -dc" ;;
Harald Hoyer 9e9f8f
         cpio|tar) decompr="cat";;
Harald Hoyer 9e9f8f
         *) return 1 ;;
Harald Hoyer 9e9f8f
     esac
Harald Hoyer 9e9f8f
@@ -64,7 +65,7 @@ unpack_img() {
Harald Hoyer 9e9f8f
     [ -r "$img" ] || { warn "can't read img!"; return 1; }
Harald Hoyer 9e9f8f
     [ -n "$outdir" ] || { warn "unpack_img: no output dir given"; return 1; }
Harald Hoyer 9e9f8f
 
Harald Hoyer 9e9f8f
-    if [ "$(det_img $img)" ]; then
Harald Hoyer 9e9f8f
+    if [ "$(det_archive $img)" ]; then
Harald Hoyer 9e9f8f
         unpack_archive "$@" || { warn "can't unpack archive file!"; return 1; }
Harald Hoyer 9e9f8f
     else
Harald Hoyer 9e9f8f
         unpack_fs "$@" || { warn "can't unpack filesystem image!"; return 1; }