From: Sara Golemon Date: Sat, 25 Mar 2006 04:37:44 +0000 (+0000) Subject: Handle converter instantiation errors properly X-Git-Tag: RELEASE_1_3~266 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=e883cee0b1664b3b605ca9383eebadd1021593f0;p=php Handle converter instantiation errors properly --- diff --git a/main/streams/streams.c b/main/streams/streams.c index 06aed94693..d1315da90d 100755 --- a/main/streams/streams.c +++ b/main/streams/streams.c @@ -2277,45 +2277,47 @@ PHPAPI php_stream *_php_stream_open_wrapper_ex(char *path, char *mode, int optio UErrorCode status = U_ZERO_ERROR; stream->output_encoding = ucnv_open(encoding, &status); - switch (U_FAILURE(status)) { - case U_ZERO_ERROR: - /* UTODO: (Maybe?) Allow overriding the default error handlers on a per-stream basis via context params */ - zend_set_converter_error_mode(stream->output_encoding, UG(from_u_error_mode)); - zend_set_converter_subst_char(stream->output_encoding, UG(subst_char), UG(subst_char_len)); - break; - case U_MEMORY_ALLOCATION_ERROR: - php_stream_wrapper_log_error(wrapper, options ^ REPORT_ERRORS TSRMLS_CC, - "Unable to allocate memory for unicode output converter: %s", encoding); - break; - case U_FILE_ACCESS_ERROR: - php_stream_wrapper_log_error(wrapper, options ^ REPORT_ERRORS TSRMLS_CC, - "Error loading unicode output converter: %s", encoding); - break; - default: - php_stream_wrapper_log_error(wrapper, options ^ REPORT_ERRORS TSRMLS_CC, - "Unknown error starting unicode output converter: %s", encoding); + if (U_FAILURE(status)) { + switch (status) { + case U_MEMORY_ALLOCATION_ERROR: + php_stream_wrapper_log_error(wrapper, options ^ REPORT_ERRORS TSRMLS_CC, + "Unable to allocate memory for unicode output converter: %s", encoding); + break; + case U_FILE_ACCESS_ERROR: + php_stream_wrapper_log_error(wrapper, options ^ REPORT_ERRORS TSRMLS_CC, + "Error loading unicode output converter: %s", encoding); + break; + default: + php_stream_wrapper_log_error(wrapper, options ^ REPORT_ERRORS TSRMLS_CC, + "Unknown error starting unicode output converter: %s", encoding); + } + } else { + /* UTODO: (Maybe?) Allow overriding the default error handlers on a per-stream basis via context params */ + zend_set_converter_error_mode(stream->output_encoding, UG(from_u_error_mode)); + zend_set_converter_subst_char(stream->output_encoding, UG(subst_char), UG(subst_char_len)); } } if (strchr(implicit_mode, 'r') || strchr(implicit_mode, '+')) { char *encoding = (context && context->input_encoding) ? context->input_encoding : "utf8"; UErrorCode status = U_ZERO_ERROR; + stream->input_encoding = ucnv_open(encoding, &status); - switch (U_FAILURE(status)) { - case U_ZERO_ERROR: - /* UTODO: If/When Input error handling gets implemented, set the options here */ - break; - case U_MEMORY_ALLOCATION_ERROR: - php_stream_wrapper_log_error(wrapper, options ^ REPORT_ERRORS TSRMLS_CC, - "Unable to allocate memory for unicode input converter: %s", encoding); - break; - case U_FILE_ACCESS_ERROR: - php_stream_wrapper_log_error(wrapper, options ^ REPORT_ERRORS TSRMLS_CC, - "Error loading unicode input converter: %s", encoding); - break; - default: - php_stream_wrapper_log_error(wrapper, options ^ REPORT_ERRORS TSRMLS_CC, - "Unknown error starting unicode input converter: %s", encoding); + if (U_FAILURE(status)) { + switch (status) { + case U_MEMORY_ALLOCATION_ERROR: + php_stream_wrapper_log_error(wrapper, options ^ REPORT_ERRORS TSRMLS_CC, + "Unable to allocate memory for unicode input converter: %s", encoding); + break; + case U_FILE_ACCESS_ERROR: + php_stream_wrapper_log_error(wrapper, options ^ REPORT_ERRORS TSRMLS_CC, + "Error loading unicode input converter: %s", encoding); + break; + default: + php_stream_wrapper_log_error(wrapper, options ^ REPORT_ERRORS TSRMLS_CC, + "Unknown error starting unicode input converter: %s", encoding); + } } + /* UTODO: If/When Input error handling gets implemented, set the options on success */ } }