X-Git-Url: https://git.plutz.net/?a=blobdiff_plain;f=multipart.sh;h=09e3ca8f256fd1bd598c9175150eb74aa78e7762;hb=8a93d4ef20815df18bfc1a580d3cffb8c6a31ea2;hp=70270f68f1c3f91830af52e22847f6887ee27081;hpb=2afe9b76c613f3edf74ebd2156e1ae78ac971960;p=shellwiki diff --git a/multipart.sh b/multipart.sh old mode 100644 new mode 100755 index 70270f6..09e3ca8 --- a/multipart.sh +++ b/multipart.sh @@ -37,7 +37,7 @@ multipart(){ local name="$1" count="${2:-1}" local formdata state=begin - while read -r formdata; do case "$formdata" in + while IFS='' read -r formdata; do case "$formdata" in "--${multipart_boundary}--${CR}") [ $state = data ] && return 0 \ || return 1 @@ -52,12 +52,13 @@ multipart(){ [ $state = data ] && printf "%s\n" "$formdata" ;; "${CR}") - [ $state = dheader ] && state=data + if [ $state = dheader ]; then + sed -n "/--${multipart_boundary}\(--\)\?${CR}/q; p;" \ + | head -c-2 + return 0; + fi [ $state = header ] && state=junk ;; - *) - [ $state = data ] && printf "%s\n" "$formdata" - ;; esac; done <"${multipart_cachefile}" } @@ -79,8 +80,6 @@ multipart_filename(){ "${CR}") [ $state = header ] && state=junk ;; - *): - ;; esac; done <"${multipart_cachefile}" filename="${formdata#*; filename=\"}"