]> granicus.if.org Git - php/commitdiff
Fix bin2hex() to work on binary data and return strings of correct type.
authorAndrei Zmievski <andrei@php.net>
Wed, 17 Aug 2005 17:39:04 +0000 (17:39 +0000)
committerAndrei Zmievski <andrei@php.net>
Wed, 17 Aug 2005 17:39:04 +0000 (17:39 +0000)
ext/standard/string.c

index 9beab1212345dc789ede93b734d0e01601e13978..f554b9d4dff2d0925d2ac31660ecbd7bfbb5cf6e 100644 (file)
@@ -185,22 +185,28 @@ PHP_MSHUTDOWN_FUNCTION(localeconv)
    Converts the binary representation of data to hex */
 PHP_FUNCTION(bin2hex)
 {
-       zval **data;
+       unsigned char *data;
+       int data_len;
        char *result;
        size_t newlen;
 
-       if (ZEND_NUM_ARGS() != 1 || zend_get_parameters_ex(1, &data) == FAILURE) {
-               WRONG_PARAM_COUNT;
+       if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "y", &data, &data_len) == FAILURE) {
+               return;
        }
-       convert_to_string_ex(data);
 
-       result = php_bin2hex(Z_STRVAL_PP(data), Z_STRLEN_PP(data), &newlen);
+       result = php_bin2hex(data, data_len, &newlen);
        
        if (!result) {
                RETURN_FALSE;
        }
 
-       RETURN_STRINGL(result, newlen, 0);
+       if (UG(unicode)) {
+               UChar *u_temp = zend_ascii_to_unicode(result, newlen+1 ZEND_FILE_LINE_CC);
+               efree(result);
+               RETVAL_UNICODEL(u_temp, newlen, 0);
+       } else {
+               RETURN_STRINGL(result, newlen, 0);
+       }
 }
 /* }}} */