/* * 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 * or http://www.opensolaris.org/os/licensing. * 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 2005 Sun Microsystems, Inc. All rights reserved. * Use is subject to license terms. */ #pragma ident "%Z%%M% %I% %E% SMI" #include "synonyms.h" #include "file64.h" #include #include #include #include #include #include #include #include #include "print.h" #include "stdiom.h" #include #include "libc.h" #include "mse.h" /* * 32-bit shadow functions _wprintf_c89(), _fwprintf_c89(), _swprintf_c89() * are included here. * When using the c89 compiler to build 32-bit applications, the size * of intmax_t is 32-bits, otherwise the size of intmax_t is 64-bits. * The shadow function uses 32-bit size of intmax_t for j conversion. * The #pragma redefine_extname in selects the proper routine * at compile time for the user application. * NOTE: the shadow functions only exist in the 32-bit library. */ int wprintf(const wchar_t *format, ...) { ssize_t count; rmutex_t *lk; va_list ap; va_start(ap, format); FLOCKFILE(lk, stdout); if (_set_orientation_wide(stdout, NULL, NULL, 0) == -1) { errno = EBADF; FUNLOCKFILE(lk); return (EOF); } if (!(stdout->_flag & _IOWRT)) { /* if no write flag */ if (stdout->_flag & _IORW) { /* if ok, cause read-write */ stdout->_flag |= _IOWRT; } else { /* else error */ errno = EBADF; FUNLOCKFILE(lk); return (EOF); } } count = _wndoprnt(format, ap, stdout, 0); va_end(ap); if (FERROR(stdout) || count == EOF) { FUNLOCKFILE(lk); return (EOF); } FUNLOCKFILE(lk); /* check for overflow */ if ((size_t)count > MAXINT) { errno = EOVERFLOW; return (EOF); } else { return ((int)count); } } int fwprintf(FILE *iop, const wchar_t *format, ...) { ssize_t count; rmutex_t *lk; va_list ap; va_start(ap, format); FLOCKFILE(lk, iop); if (_set_orientation_wide(iop, NULL, NULL, 0) == -1) { errno = EBADF; FUNLOCKFILE(lk); return (EOF); } if (!(iop->_flag & _IOWRT)) { /* if no write flag */ if (iop->_flag & _IORW) { /* if ok, cause read-write */ iop->_flag |= _IOWRT; } else { /* else error */ errno = EBADF; FUNLOCKFILE(lk); return (EOF); } } count = _wndoprnt(format, ap, iop, 0); va_end(ap); if (FERROR(iop) || count == EOF) { FUNLOCKFILE(lk); return (EOF); } FUNLOCKFILE(lk); /* check for overflow */ if ((size_t)count > MAXINT) { errno = EOVERFLOW; return (EOF); } else { return ((int)count); } } int swprintf(wchar_t *string, size_t n, const wchar_t *format, ...) { ssize_t count; FILE siop; wchar_t *wp; va_list ap; if (n == 0) return (EOF); siop._cnt = (ssize_t)n - 1; siop._base = siop._ptr = (unsigned char *)string; siop._flag = _IOREAD; va_start(ap, format); count = _wndoprnt(format, ap, &siop, 0); va_end(ap); wp = (wchar_t *)(uintptr_t)siop._ptr; *wp = L'\0'; if (count == EOF) { return (EOF); } /* check for overflow */ if ((size_t)count > MAXINT) { errno = EOVERFLOW; return (EOF); } else { return ((int)count); } } #ifndef _LP64 int _wprintf_c89(const wchar_t *format, ...) { ssize_t count; va_list ap; va_start(ap, format); count = _vwprintf_c89(format, ap); va_end(ap); return ((int)count); } int _fwprintf_c89(FILE *iop, const wchar_t *format, ...) { ssize_t count; va_list ap; va_start(ap, format); count = _vfwprintf_c89(iop, format, ap); va_end(ap); return ((int)count); } int _swprintf_c89(wchar_t *string, size_t n, const wchar_t *format, ...) { ssize_t count; va_list ap; va_start(ap, format); count = _vswprintf_c89(string, n, format, ap); va_end(ap); return ((int)count); } #endif /* _LP64 */