1 /*
2 * Code created by modifying scanf.c which has following copyright.
3 *
4 * Copyright (c) 1990 The Regents of the University of California.
5 * All rights reserved.
6 *
7 * Redistribution and use in source and binary forms are permitted
8 * provided that the above copyright notice and this paragraph are
9 * duplicated in all such forms and that any documentation,
10 * and/or other materials related to such
11 * distribution and use acknowledge that the software was developed
12 * by the University of California, Berkeley. The name of the
13 * University may not be used to endorse or promote products derived
14 * from this software without specific prior written permission.
15 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
16 * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
17 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
18 */
19 /* Doc in vfwscanf.c */
20
21 #define _DEFAULT_SOURCE
22 #include <_ansi.h>
23 #include <stdio.h>
24 #include <wchar.h>
25 #include <string.h>
26 #include <stdarg.h>
27 #include "local.h"
28
29 /*
30 * vsscanf
31 */
32
33 int
vswscanf(const wchar_t * str,const wchar_t * fmt,va_list ap)34 vswscanf ( const wchar_t *str, const wchar_t *fmt,
35 va_list ap)
36 {
37 FILE f;
38
39 f._flags = __SRD | __SSTR;
40 f._bf._base = f._p = (unsigned char *) str;
41 f._bf._size = f._r = wcslen (str) * sizeof (wchar_t);
42 f._read = __seofread;
43 f._ub._base = NULL;
44 f._lb._base = NULL;
45 f._flags2 = 0;
46 f._ur = 0;
47 f._file = -1; /* No file. */
48 return _ssvfwscanf ( &f, fmt, ap);
49 }
50