/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License (the "License").
* You may not use this file except in compliance with the License.
*
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information: Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*/
/*
* Copyright 2009 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
/*
* Unicode conversions (yet more)
*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <errno.h>
#include <iconv.h>
#include <libintl.h>
#include <sys/u8_textprep.h>
#include "charsets.h"
/*
* Number of unicode symbols in the string,
* not including the 2-byte null terminator.
* (multiply by two for storage size)
*/
{
while (*us++)
len++;
return (len);
}
/*
* Convert (native) Unicode string to UTF-8.
* Returns allocated memory.
*/
char *
{
/* Get conversion descriptor (to, from) */
}
/*
* Convert little-endian Unicode string to UTF-8.
* Returns allocated memory.
*/
char *
{
/* Get conversion descriptor (to, from) */
}
static char *
{
const char *iptr;
return (NULL);
}
/* Worst-case output size is 2x input size. */
if (!obuf)
return (NULL);
*optr = '\0';
}
if (ileft) {
/*
* XXX: What's better? return NULL?
* The truncated string? << for now
*/
}
return (obuf);
}
/*
* Convert UTF-8 string to Unicode.
* Returns allocated memory.
*/
uint16_t *
{
/* Get conversion descriptor (to, from) */
}
/*
* Convert UTF-8 string to little-endian Unicode.
* Returns allocated memory.
*/
uint16_t *
{
/* Get conversion descriptor (to, from) */
}
static uint16_t *
{
const char *iptr;
return (NULL);
}
iptr = utf8_string;
/* Worst-case output size is 2x input size. */
if (!obuf)
return (NULL);
*optr = '\0';
}
if (ileft) {
/*
* XXX: What's better? return NULL?
* The truncated string? << for now
*/
}
return (obuf);
}
/*
* A simple wrapper around u8_textprep_str() that returns the Unicode
* upper-case version of some string. Returns memory from malloc.
* Borrowed from idmapd.
*/
static char *
{
char *outs;
/*
* u8_textprep_str() does not allocate memory. The input and
* output buffers may differ in size (though that would be more
* likely when normalization is done). We have to loop over it...
*
* To improve the chances that we can avoid looping we add 10
* bytes of output buffer room the first go around.
*/
return (NULL);
return (NULL);
/* adjust outbleft and outlen */
}
if (rc < 0) {
return (NULL);
}
return (res);
}
char *
utf8_str_toupper(const char *s)
{
return (utf8_str_to_upper_or_lower(s, U8_TEXTPREP_TOUPPER));
}
char *
utf8_str_tolower(const char *s)
{
return (utf8_str_to_upper_or_lower(s, U8_TEXTPREP_TOLOWER));
}