/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License, Version 1.0 only
* (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 1993 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
/*
* mbstowcs
*/
#pragma ident "%Z%%M% %I% %E% SMI"
#endif
#include "codeset.h"
#include "mbextern.h"
int
char *s;
size_t n;
{
int (*p)();
int num = 0;
int ret;
switch (_code_set_info.code_id) {
case CODESET_NONE:
/*
* default code set,
*/
while (*s && num < n) {
num++;
}
if (num < n)
*pwcs = 0;
return (num);
break;
case CODESET_EUC:
/*
* EUC code set
*/
return(_mbstowcs_euc(pwcs, s, n));
break;
case CODESET_XCCS:
/*
* XCCS code set
*/
return(_mbstowcs_xccs(pwcs, s, n));
break;
case CODESET_ISO2022:
/*
* ISO family
*/
return(_mbstowcs_iso(pwcs, s, n));
break;
default:
/*
* User defined code set
*/
handle = _ml_open_library();
return(ERROR_NO_LIB); /* No user library */
if (p == (int (*)()) NULL)
return(ERROR_NO_SYM);
return (ret);
break;
}
/* NOTREACHED */
}