X-Git-Url: http://git.plutz.net/?p=cgilite;a=blobdiff_plain;f=cgilite.sh;fp=cgilite.sh;h=bee93d86089668be13c59375026e7cfaa0464313;hp=ddad1d4811c7635c8032c08620666fec9a9b2232;hb=7e6d863ffdd71e4bf83bb133ba429ea35c99796a;hpb=87f88f16edb809677be04464c15a6c89c3641724 diff --git a/cgilite.sh b/cgilite.sh index ddad1d4..bee93d8 100755 --- a/cgilite.sh +++ b/cgilite.sh @@ -95,11 +95,16 @@ if [ -z "$REQUEST_METHOD" ]; then # Without Content-Length header, connection will terminate after # script. - cgilite_status='200 OK'; cgilite_response=''; cgilite_cl="Connection: close${CR}"; + cgilite_status='200 OK'; cgilite_response=''; cgilite_cl="Connection: close${CR}${BR}"; . "$0" | while read -r l; do case $l in - Status:*) cgilite_status="${l#Status: }";; - Content-Length:*) cgilite_cl="${l}";; - $CR) printf '%s %s\r\n%s%s\n\r\n' \ + Status:*) + cgilite_status="${l#Status: }";; + Content-Length:*) + cgilite_cl="" + cgilite_response="${cgilite_response:+${cgilite_response}${BR}}${l}";; + Connection:*) + cgilite_cl="${l}${BR}";; + $CR) printf '%s %s\r\n%s%s\r\n' \ 'HTTP/1.1' "${cgilite_status%${CR}}" \ "${cgilite_response}${cgilite_response:+${BR}}" "${cgilite_cl}" cat || kill $$