} else {
UErrorCode status = U_ZERO_ERROR;
char *dest;
- int destlen;
+ int destlen, num_conv;
+
+ num_conv = zend_convert_from_unicode(conv, &dest, &destlen, bucket->buf.u, bucket->buflen, &status);
+ if (U_FAILURE(status)) {
+ int32_t offset = u_countChar32(bucket->buf.u, num_conv)-1;
- zend_convert_from_unicode(conv, &dest, &destlen, bucket->buf.u, bucket->buflen, &status);
+ zend_raise_conversion_error_ex("Could not convert Unicode string to binary string", conv, offset, (UG(from_u_error_mode) & ZEND_CONV_ERROR_EXCEPTION) TSRMLS_CC);
+ }
if (bucket->own_buf) {
pefree(bucket->buf.u, bucket->is_persistent);
if (stream->output_encoding && buf_type == IS_UNICODE) {
char *dest;
- int destlen;
+ int destlen, num_conv;
UErrorCode status = U_ZERO_ERROR;
- zend_convert_from_unicode(stream->output_encoding, &dest, &destlen, buf.u, buflen, &status);
+ num_conv = zend_convert_from_unicode(stream->output_encoding, &dest, &destlen, buf.u, buflen, &status);
+ if (U_FAILURE(status)) {
+ int32_t offset = u_countChar32(buf.u, num_conv)-1;
+
+ zend_raise_conversion_error_ex("Could not convert Unicode string to binary string", stream->output_encoding, offset, (UG(from_u_error_mode) & ZEND_CONV_ERROR_EXCEPTION) TSRMLS_CC);
+ }
freeme = buf.s = dest;
buflen = destlen;
} else {