]> granicus.if.org Git - php/commitdiff
partial MFH: avoid problems with auto_detect_line_endings.
authorWez Furlong <wez@php.net>
Thu, 13 Feb 2003 13:42:31 +0000 (13:42 +0000)
committerWez Furlong <wez@php.net>
Thu, 13 Feb 2003 13:42:31 +0000 (13:42 +0000)
ext/standard/http_fopen_wrapper.c

index fd3ad826c4783a2e88267419188a66b8bde5b5f4..096819c0583e2778817c1d308a849187da9cf2a2 100644 (file)
@@ -100,6 +100,7 @@ php_stream *php_stream_url_wrap_http(php_stream_wrapper *wrapper, char *path, ch
        char *http_header_line = NULL;
        char tmp_line[128];
        size_t chunk_size = 0, file_size = 0;
+       int eol_detect;
 
        if (strchr(mode, 'a') || strchr(mode, '+') || strchr(mode, 'w')) {
                php_stream_wrapper_log_error(wrapper, options TSRMLS_CC, "HTTP wrapper does not support writeable connections.");
@@ -127,6 +128,11 @@ php_stream *php_stream_url_wrap_http(php_stream_wrapper *wrapper, char *path, ch
           we'll accept the unexpected behavior of filtered http streams in favor of improved performance. */
        if (options & STREAM_WILL_CAST)
                chunk_size = php_stream_set_chunk_size(stream, 1);
+
+       /* avoid problems with auto-detecting when reading the headers -> the headers
+        * are always in canonical \r\n format */
+       eol_detect = stream->flags & (PHP_STREAM_FLAG_DETECT_EOL | PHP_STREAM_FLAG_EOL_MAC);
+       stream->flags &= ~(PHP_STREAM_FLAG_DETECT_EOL | PHP_STREAM_FLAG_EOL_MAC);
        
        php_stream_context_set(stream, context);
 
@@ -405,6 +411,10 @@ out:
                /* Restore original chunk size now that we're done with headers (if applicable) */
                if (options & STREAM_WILL_CAST)
                        php_stream_set_chunk_size(stream, chunk_size);
+
+               /* restore the users auto-detect-line-endings setting */
+               stream->flags |= eol_detect;
+
                /* as far as streams are concerned, we are now at the start of
                 * the stream */
                stream->position = 0;