mbstowcs.c (bad3b6889aecd4b42701fd9b1e63f3cefa1595a4) | mbstowcs.c (7438fc3aa8a196e1af28f4b09418a6733af0d69a) |
---|---|
1/*- | 1/*- |
2 * Copyright (c) 2002-2004 Tim J. Robbins. 3 * All rights reserved. | 2 * Copyright (c) 1993 3 * The Regents of the University of California. All rights reserved. |
4 * | 4 * |
5 * This code is derived from software contributed to Berkeley by 6 * Paul Borman at Krystal Technologies. 7 * |
|
5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions 7 * are met: 8 * 1. Redistributions of source code must retain the above copyright 9 * notice, this list of conditions and the following disclaimer. 10 * 2. Redistributions in binary form must reproduce the above copyright 11 * notice, this list of conditions and the following disclaimer in the 12 * documentation and/or other materials provided with the distribution. | 8 * Redistribution and use in source and binary forms, with or without 9 * modification, are permitted provided that the following conditions 10 * are met: 11 * 1. Redistributions of source code must retain the above copyright 12 * notice, this list of conditions and the following disclaimer. 13 * 2. Redistributions in binary form must reproduce the above copyright 14 * notice, this list of conditions and the following disclaimer in the 15 * documentation and/or other materials provided with the distribution. |
16 * 3. All advertising materials mentioning features or use of this software 17 * must display the following acknowledgement: 18 * This product includes software developed by the University of 19 * California, Berkeley and its contributors. 20 * 4. Neither the name of the University nor the names of its contributors 21 * may be used to endorse or promote products derived from this software 22 * without specific prior written permission. |
|
13 * | 23 * |
14 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND | 24 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND |
15 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 16 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE | 25 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
17 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE | 27 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE |
18 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24 * SUCH DAMAGE. 25 */ 26 27#include <sys/cdefs.h> 28__FBSDID("$FreeBSD$"); 29 | 28 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 30 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 31 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 32 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 33 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 34 * SUCH DAMAGE. 35 */ 36 37#include <sys/cdefs.h> 38__FBSDID("$FreeBSD$"); 39 |
30#include <limits.h> | |
31#include <stdlib.h> | 40#include <stdlib.h> |
32#include <wchar.h> 33#include "mblocal.h" | 41#include <limits.h> 42#include <stddef.h> 43#include <rune.h> |
34 35size_t | 44 45size_t |
36mbstowcs(wchar_t * __restrict pwcs, const char * __restrict s, size_t n) | 46mbstowcs(pwcs, s, n) 47 wchar_t *pwcs; 48 const char *s; 49 size_t n; |
37{ | 50{ |
38 static const mbstate_t initial; 39 mbstate_t mbs; 40 const char *sp; | 51 char const *e; 52 int cnt = 0; |
41 | 53 |
42 mbs = initial; 43 sp = s; 44 return (__mbsnrtowcs(pwcs, &sp, SIZE_T_MAX, n, &mbs)); | 54 if (!pwcs || !s) 55 return (-1); 56 57 while (n-- > 0) { 58 *pwcs = sgetrune(s, MB_LEN_MAX, &e); 59 if (*pwcs == _INVALID_RUNE) 60 return (-1); 61 if (*pwcs++ == 0) 62 break; 63 s = e; 64 ++cnt; 65 } 66 return (cnt); |
45} | 67} |