X-Git-Url: http://git.plutz.net/?p=cgilite;a=blobdiff_plain;f=cgilite.sh;h=86ad28073018c9a2626877e74426c0b2d4a95914;hp=ddad1d4811c7635c8032c08620666fec9a9b2232;hb=5b013b64b7bbc9a62775ed861e9c8b34ffb3dfaa;hpb=87f88f16edb809677be04464c15a6c89c3641724 diff --git a/cgilite.sh b/cgilite.sh index ddad1d4..86ad280 100755 --- a/cgilite.sh +++ b/cgilite.sh @@ -77,7 +77,9 @@ if [ -z "$REQUEST_METHOD" ]; then SERVER_PROTOCOL="${SERVER_PROTOCOL%${CR}}" PATH_INFO="$(HEX_DECODE "${REQUEST_URI%\?*}" |PATH)" - QUERY_STRING="${REQUEST_URI#*\?}" + [ "${REQUEST_URI}" = "${REQUEST_URI#*\?}" ] \ + && QUERY_STRING='' \ + || QUERY_STRING="${REQUEST_URI#*\?}" cgilite_headers=''; while read -r hl; do hl="${hl%${CR}}"; [ "$hl" ] || break case $hl in @@ -95,11 +97,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 $$