diff options
author | Lorry Tar Creator <lorry-tar-importer@baserock.org> | 2013-03-14 05:42:27 +0000 |
---|---|---|
committer | <> | 2013-04-03 16:25:08 +0000 |
commit | c4dd7a1a684490673e25aaf4fabec5df138854c4 (patch) | |
tree | 4d57c44caae4480efff02b90b9be86f44bf25409 /ext/intl/intl_convert.c | |
download | php2-master.tar.gz |
Imported from /home/lorry/working-area/delta_php2/php-5.4.13.tar.bz2.HEADphp-5.4.13master
Diffstat (limited to 'ext/intl/intl_convert.c')
-rw-r--r-- | ext/intl/intl_convert.c | 157 |
1 files changed, 157 insertions, 0 deletions
diff --git a/ext/intl/intl_convert.c b/ext/intl/intl_convert.c new file mode 100644 index 0000000..92cdc4c --- /dev/null +++ b/ext/intl/intl_convert.c @@ -0,0 +1,157 @@ +/* + +----------------------------------------------------------------------+ + | PHP Version 5 | + +----------------------------------------------------------------------+ + | This source file is subject to version 3.01 of the PHP license, | + | that is bundled with this package in the file LICENSE, and is | + | available through the world-wide-web at the following url: | + | http://www.php.net/license/3_01.txt | + | If you did not receive a copy of the PHP license and are unable to | + | obtain it through the world-wide-web, please send a note to | + | license@php.net so we can mail you a copy immediately. | + +----------------------------------------------------------------------+ + | Authors: Vadim Savchuk <vsavchuk@productengine.com> | + | Dmitry Lakhtyuk <dlakhtyuk@productengine.com> | + +----------------------------------------------------------------------+ + */ + +#ifdef HAVE_CONFIG_H +#include "config.h" +#endif + +#include <php.h> + +#include "intl_common.h" +#include "intl_convert.h" + +/* {{{ intl_convert_utf8_to_utf16 + * Convert given string from UTF-8 to UTF-16 to *target buffer. + * + * It *target is NULL then we allocate a large enough buffer, + * store the converted string into it, and make target point to it. + * + * Otherwise, if *target is non-NULL, we assume that it points to a + * dynamically allocated buffer of *target_len bytes length. + * In this case the buffer will be used to store the converted string to, + * and may be resized (made larger) if needed. + * + * @param target Where to place the result. + * @param target_len Result length. + * @param source String to convert. + * @param source_len Length of the source string. + * @param status Conversion status. + * + * @return void This function does not return anything. + */ +void intl_convert_utf8_to_utf16( + UChar** target, int* target_len, + const char* src, int src_len, + UErrorCode* status ) +{ + UChar* dst_buf = NULL; + int32_t dst_len = 0; + + /* If *target is NULL determine required destination buffer size (pre-flighting). + * Otherwise, attempt to convert source string; if *target buffer is not large enough + * it will be resized appropriately. + */ + *status = U_ZERO_ERROR; + + u_strFromUTF8( *target, *target_len, &dst_len, src, src_len, status ); + + if( *status == U_ZERO_ERROR ) + { + /* String is converted successfuly */ + (*target)[dst_len] = 0; + *target_len = dst_len; + return; + } + + /* Bail out if an unexpected error occurred. + * (U_BUFFER_OVERFLOW_ERROR means that *target buffer is not large enough). + * (U_STRING_NOT_TERMINATED_WARNING usually means that the input string is empty). + */ + if( *status != U_BUFFER_OVERFLOW_ERROR && *status != U_STRING_NOT_TERMINATED_WARNING ) + return; + + /* Allocate memory for the destination buffer (it will be zero-terminated). */ + dst_buf = eumalloc( dst_len + 1 ); + + /* Convert source string from UTF-8 to UTF-16. */ + *status = U_ZERO_ERROR; + u_strFromUTF8( dst_buf, dst_len+1, NULL, src, src_len, status ); + if( U_FAILURE( *status ) ) + { + efree( dst_buf ); + return; + } + + dst_buf[dst_len] = 0; + + if( *target ) + efree( *target ); + + *target = dst_buf; + *target_len = dst_len; +} +/* }}} */ + +/* {{{ intl_convert_utf16_to_utf8 + * Convert given string from UTF-16 to UTF-8. + * + * @param target Where to place the result. + * @param target_len Result length. + * @param source String to convert. + * @param source_len Length of the source string. + * @param status Conversion status. + * + * @return void This function does not return anything. + */ +void intl_convert_utf16_to_utf8( + char** target, int* target_len, + const UChar* src, int src_len, + UErrorCode* status ) +{ + char* dst_buf = NULL; + int32_t dst_len; + + /* Determine required destination buffer size (pre-flighting). */ + *status = U_ZERO_ERROR; + u_strToUTF8( NULL, 0, &dst_len, src, src_len, status ); + + /* Bail out if an unexpected error occurred. + * (U_BUFFER_OVERFLOW_ERROR means that *target buffer is not large enough). + * (U_STRING_NOT_TERMINATED_WARNING usually means that the input string is empty). + */ + if( *status != U_BUFFER_OVERFLOW_ERROR && *status != U_STRING_NOT_TERMINATED_WARNING ) + return; + + /* Allocate memory for the destination buffer (it will be zero-terminated). */ + dst_buf = emalloc( dst_len+1 ); + + /* Convert source string from UTF-8 to UTF-16. */ + *status = U_ZERO_ERROR; + u_strToUTF8( dst_buf, dst_len, NULL, src, src_len, status ); + if( U_FAILURE( *status ) ) + { + efree( dst_buf ); + return; + } + + /* U_STRING_NOT_TERMINATED_WARNING is OK for us => reset 'status'. */ + *status = U_ZERO_ERROR; + + dst_buf[dst_len] = 0; + *target = dst_buf; + *target_len = dst_len; +} +/* }}} */ + +/* + * Local variables: + * tab-width: 4 + * c-basic-offset: 4 + * End: + * vim600: noet sw=4 ts=4 fdm=marker + * vim<600: noet sw=4 ts=4 + */ |