Annotation of embedaddon/php/ext/intl/intl_convert.c, revision 1.1

1.1     ! misho       1: /*
        !             2:    +----------------------------------------------------------------------+
        !             3:    | PHP Version 5                                                        |
        !             4:    +----------------------------------------------------------------------+
        !             5:    | This source file is subject to version 3.01 of the PHP license,      |
        !             6:    | that is bundled with this package in the file LICENSE, and is        |
        !             7:    | available through the world-wide-web at the following url:           |
        !             8:    | http://www.php.net/license/3_01.txt                                  |
        !             9:    | If you did not receive a copy of the PHP license and are unable to   |
        !            10:    | obtain it through the world-wide-web, please send a note to          |
        !            11:    | license@php.net so we can mail you a copy immediately.               |
        !            12:    +----------------------------------------------------------------------+
        !            13:    | Authors: Vadim Savchuk <vsavchuk@productengine.com>                  |
        !            14:    |          Dmitry Lakhtyuk <dlakhtyuk@productengine.com>               |
        !            15:    +----------------------------------------------------------------------+
        !            16:  */
        !            17: 
        !            18: #ifdef HAVE_CONFIG_H
        !            19: #include "config.h"
        !            20: #endif
        !            21: 
        !            22: #include <php.h>
        !            23: 
        !            24: #include "intl_common.h"
        !            25: #include "intl_convert.h"
        !            26: 
        !            27: /* {{{ intl_convert_utf8_to_utf16
        !            28:  * Convert given string from UTF-8 to UTF-16 to *target buffer.
        !            29:  *
        !            30:  * It *target is NULL then we allocate a large enough buffer,
        !            31:  * store the converted string into it, and make target point to it.
        !            32:  *
        !            33:  * Otherwise, if *target is non-NULL, we assume that it points to a
        !            34:  * dynamically allocated buffer of *target_len bytes length.
        !            35:  * In this case the buffer will be used to store the converted string to,
        !            36:  * and may be resized (made larger) if needed.
        !            37:  *
        !            38:  * @param target      Where to place the result.
        !            39:  * @param target_len  Result length.
        !            40:  * @param source      String to convert.
        !            41:  * @param source_len  Length of the source string.
        !            42:  * @param status      Conversion status.
        !            43:  *
        !            44:  * @return void       This function does not return anything.
        !            45:  */
        !            46: void intl_convert_utf8_to_utf16(
        !            47:        UChar**     target, int* target_len,
        !            48:        const char* src,    int  src_len,
        !            49:        UErrorCode* status )
        !            50: {
        !            51:        UChar*      dst_buf = NULL;
        !            52:        int32_t     dst_len = 0;
        !            53: 
        !            54:        /* If *target is NULL determine required destination buffer size (pre-flighting).
        !            55:         * Otherwise, attempt to convert source string; if *target buffer is not large enough
        !            56:         * it will be resized appropriately.
        !            57:         */
        !            58:        *status = U_ZERO_ERROR;
        !            59: 
        !            60:        u_strFromUTF8( *target, *target_len, &dst_len, src, src_len, status );
        !            61: 
        !            62:        if( *status == U_ZERO_ERROR )
        !            63:        {
        !            64:                /* String is converted successfuly */
        !            65:                (*target)[dst_len] = 0;
        !            66:                *target_len = dst_len;
        !            67:                return;
        !            68:        }
        !            69: 
        !            70:        /* Bail out if an unexpected error occured.
        !            71:         * (U_BUFFER_OVERFLOW_ERROR means that *target buffer is not large enough).
        !            72:         * (U_STRING_NOT_TERMINATED_WARNING usually means that the input string is empty).
        !            73:         */
        !            74:        if( *status != U_BUFFER_OVERFLOW_ERROR && *status != U_STRING_NOT_TERMINATED_WARNING )
        !            75:                return;
        !            76: 
        !            77:        /* Allocate memory for the destination buffer (it will be zero-terminated). */
        !            78:        dst_buf = eumalloc( dst_len + 1 );
        !            79: 
        !            80:        /* Convert source string from UTF-8 to UTF-16. */
        !            81:        *status = U_ZERO_ERROR;
        !            82:        u_strFromUTF8( dst_buf, dst_len+1, NULL, src, src_len, status );
        !            83:        if( U_FAILURE( *status ) )
        !            84:        {
        !            85:                efree( dst_buf );
        !            86:                return;
        !            87:        }
        !            88: 
        !            89:        dst_buf[dst_len] = 0;
        !            90: 
        !            91:        if( *target )
        !            92:                efree( *target );
        !            93: 
        !            94:        *target     = dst_buf;
        !            95:        *target_len = dst_len;
        !            96: }
        !            97: /* }}} */
        !            98: 
        !            99: /* {{{ intl_convert_utf16_to_utf8
        !           100:  * Convert given string from UTF-16 to UTF-8.
        !           101:  *
        !           102:  * @param target      Where to place the result.
        !           103:  * @param target_len  Result length.
        !           104:  * @param source      String to convert.
        !           105:  * @param source_len  Length of the source string.
        !           106:  * @param status      Conversion status.
        !           107:  *
        !           108:  * @return void       This function does not return anything.
        !           109:  */
        !           110: void intl_convert_utf16_to_utf8(
        !           111:        char**       target, int* target_len,
        !           112:        const UChar* src,    int  src_len,
        !           113:        UErrorCode*  status )
        !           114: {
        !           115:        char*       dst_buf = NULL;
        !           116:        int32_t     dst_len;
        !           117: 
        !           118:        /* Determine required destination buffer size (pre-flighting). */
        !           119:        *status = U_ZERO_ERROR;
        !           120:        u_strToUTF8( NULL, 0, &dst_len, src, src_len, status );
        !           121: 
        !           122:        /* Bail out if an unexpected error occured.
        !           123:         * (U_BUFFER_OVERFLOW_ERROR means that *target buffer is not large enough).
        !           124:         * (U_STRING_NOT_TERMINATED_WARNING usually means that the input string is empty).
        !           125:         */
        !           126:        if( *status != U_BUFFER_OVERFLOW_ERROR && *status != U_STRING_NOT_TERMINATED_WARNING )
        !           127:                return;
        !           128: 
        !           129:        /* Allocate memory for the destination buffer (it will be zero-terminated). */
        !           130:        dst_buf = emalloc( dst_len+1 );
        !           131: 
        !           132:        /* Convert source string from UTF-8 to UTF-16. */
        !           133:        *status = U_ZERO_ERROR;
        !           134:        u_strToUTF8( dst_buf, dst_len, NULL, src, src_len, status );
        !           135:        if( U_FAILURE( *status ) )
        !           136:        {
        !           137:                efree( dst_buf );
        !           138:                return;
        !           139:        }
        !           140: 
        !           141:        /* U_STRING_NOT_TERMINATED_WARNING is OK for us => reset 'status'. */
        !           142:        *status = U_ZERO_ERROR;
        !           143: 
        !           144:        dst_buf[dst_len] = 0;
        !           145:        *target     = dst_buf;
        !           146:        *target_len = dst_len;
        !           147: }
        !           148: /* }}} */
        !           149: 
        !           150: /*
        !           151:  * Local variables:
        !           152:  * tab-width: 4
        !           153:  * c-basic-offset: 4
        !           154:  * End:
        !           155:  * vim600: noet sw=4 ts=4 fdm=marker
        !           156:  * vim<600: noet sw=4 ts=4
        !           157:  */

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>