]> granicus.if.org Git - php/commitdiff
- Implemented alternative strategy for change in rev #304985 so as to
authorGustavo André dos Santos Lopes <cataphract@php.net>
Thu, 18 Nov 2010 12:10:17 +0000 (12:10 +0000)
committerGustavo André dos Santos Lopes <cataphract@php.net>
Thu, 18 Nov 2010 12:10:17 +0000 (12:10 +0000)
  not to break binary compatibility in the 5.3 branch.

ext/standard/file.c
ext/standard/file.h
ext/standard/ftp_fopen_wrapper.c
ext/standard/http_fopen_wrapper.c

index fc60cac1dfcbc29aae7c29b7cd47da4ee6257f1a..953ca7928d5b50b079761e32c01eba80a4811c47 100644 (file)
@@ -170,7 +170,7 @@ static void file_globals_dtor(php_file_globals *file_globals_p TSRMLS_DC)
 
 PHP_INI_BEGIN()
        STD_PHP_INI_ENTRY("user_agent", NULL, PHP_INI_ALL, OnUpdateString, user_agent, php_file_globals, file_globals)
-       STD_PHP_INI_ENTRY("from", NULL, PHP_INI_ALL, OnUpdateString, from_address, php_file_globals, file_globals)
+       PHP_INI_ENTRY("from", NULL, PHP_INI_ALL, NULL)
        STD_PHP_INI_ENTRY("default_socket_timeout", "60", PHP_INI_ALL, OnUpdateLong, default_socket_timeout, php_file_globals, file_globals)
        STD_PHP_INI_ENTRY("auto_detect_line_endings", "0", PHP_INI_ALL, OnUpdateLong, auto_detect_line_endings, php_file_globals, file_globals)
 PHP_INI_END()
index 7b4b22c936376a6aafef6d1468c05d26e6fcad7d..fc04709d9090c034126d9d2da37cdedd9486f962 100644 (file)
@@ -119,7 +119,6 @@ typedef struct {
        long auto_detect_line_endings;
        long default_socket_timeout;
        char *user_agent; /* for the http wrapper */
-       char *from_address; /* for the ftp and http wrappers */
        char *user_stream_current_filename; /* for simple recursion protection */
        php_stream_context *default_context;
        HashTable *stream_wrappers;                     /* per-request copy of url_stream_wrappers_hash */
index 6b858b6aed686312dd97fcb715349ddf5b452617..6b418157df9e6ce62239add8871a7c8479da0e86 100644 (file)
@@ -249,8 +249,9 @@ static php_stream *php_ftp_fopen_connect(php_stream_wrapper *wrapper, char *path
                } else {
                        /* if the user has configured who they are,
                           send that as the password */
-                       if (FG(from_address)) {
-                               php_stream_printf(stream TSRMLS_CC, "PASS %s\r\n", FG(from_address));
+                       char *from_address = php_ini_string("from", sizeof("from"), 0);
+                       if (from_address[0] != '\0') {
+                               php_stream_printf(stream TSRMLS_CC, "PASS %s\r\n", from_address);
                        } else {
                                php_stream_write_string(stream, "PASS anonymous\r\n");
                        }
index 931c8e6ce893b69fba5e0ea9f6bc030b00c3f3f2..afddc6282efd6f1d2e354e251f235f70d27b184c 100644 (file)
@@ -443,9 +443,12 @@ php_stream *php_stream_url_wrap_http_ex(php_stream_wrapper *wrapper, char *path,
        }
 
        /* if the user has configured who they are, send a From: line */
-       if (((have_header & HTTP_HEADER_FROM) == 0) && FG(from_address)) {
-               if (snprintf(scratch, scratch_len, "From: %s\r\n", FG(from_address)) > 0)
-                       php_stream_write(stream, scratch, strlen(scratch));
+       {
+               char *from_address = php_ini_string("from", sizeof("from"), 0);
+               if (((have_header & HTTP_HEADER_FROM) == 0) && from_address[0] != '\0') {
+                       if (snprintf(scratch, scratch_len, "From: %s\r\n", from_address) > 0)
+                               php_stream_write(stream, scratch, strlen(scratch));
+               }
        }
 
        /* Send Host: header so name-based virtual hosts work */