ansi.h revision 1.15
1/*	$NetBSD: ansi.h,v 1.15 2001/07/28 07:43:07 matt Exp $	*/
2
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, with or without
8 * modification, are permitted provided that the following conditions
9 * are met:
10 * 1. Redistributions of source code must retain the above copyright
11 *    notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 *    notice, this list of conditions and the following disclaimer in the
14 *    documentation and/or other materials provided with the distribution.
15 * 3. All advertising materials mentioning features or use of this software
16 *    must display the following acknowledgement:
17 *      This product includes software developed by the University of
18 *      California, Berkeley and its contributors.
19 * 4. Neither the name of the University nor the names of its contributors
20 *    may be used to endorse or promote products derived from this software
21 *    without specific prior written permission.
22 *
23 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
24 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26 * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
27 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33 * SUCH DAMAGE.
34 *
35 *      @(#)ansi.h      7.1 (Berkeley) 3/9/91
36 */
37
38#ifndef _ANSI_H_
39#define _ANSI_H_
40
41#include <sys/cdefs.h>
42#include <machine/int_types.h>
43
44/*
45 * Types which are fundamental to the implementation and may appear in
46 * more than one standard header are defined here.  Standard headers
47 * then use:
48 *      #ifdef  _SIZE_T_
49 *      typedef _SIZE_T_ size_t;
50 *      #undef  _SIZE_T_
51 *      #endif
52 *
53 * Thanks, ANSI!
54 */
55#ifdef __ELF__
56#define	_BSD_CLOCK_T_		unsigned int	/* clock() */
57#define	_BSD_PTRDIFF_T_		long int	/* ptr1 - ptr2 */
58#define	_BSD_SIZE_T_		unsigned long int /* sizeof() */
59#define	_BSD_SSIZE_T_		long int	/* byte count or error */
60#define	_BSD_TIME_T_		int		/* time() */
61#else
62#define	_BSD_CLOCK_T_		unsigned long int /* clock() */
63#define	_BSD_PTRDIFF_T_		int		/* ptr1 - ptr2 */
64#define	_BSD_SIZE_T_		unsigned int	/* sizeof() */
65#define	_BSD_SSIZE_T_		int		/* byte count or error */
66#define	_BSD_TIME_T_		long		/* time() */
67#endif
68#if __GNUC_PREREQ__(2,96)
69#define	_BSD_VA_LIST_		__builtin_va_list /* va_list */
70#else
71#define	_BSD_VA_LIST_		char *		/* va_list */
72#endif
73#define	_BSD_WCHAR_T_		int		/* wchar_t */
74#define	_BSD_WINT_T_		int		/* wint_t */
75#define	_BSD_CLOCKID_T_		int		/* clockid_t */
76#define	_BSD_TIMER_T_		int		/* timer_t */
77#define	_BSD_SUSECONDS_T_	int		/* suseconds_t */
78#define	_BSD_USECONDS_T_	unsigned int	/* useconds_t */
79
80/*
81 * NOTE: rune_t is not covered by ANSI nor other standards, and should not
82 * be instantiated outside of lib/libc/locale.  use wchar_t.
83 *
84 * Runes (wchar_t) is declared to be an ``int'' instead of the more natural
85 * ``unsigned long'' or ``long''.  Two things are happening here.  It is not
86 * unsigned so that EOF (-1) can be naturally assigned to it and used.  Also,
87 * it looks like 10646 will be a 31 bit standard.  This means that if your
88 * ints cannot hold 32 bits, you will be in trouble.  The reason an int was
89 * chosen over a long is that the is*() and to*() routines take ints (says
90 * ANSI C), but they use _RUNE_T_ instead of int.  By changing it here, you
91 * lose a bit of ANSI conformance, but your programs will still work.
92 *
93 * Note that _WCHAR_T_ and _RUNE_T_ must be of the same type.  When wchar_t
94 * and rune_t are typedef'd, _WCHAR_T_ will be undef'd, but _RUNE_T remains
95 * defined for ctype.h.
96 */
97#define	_BSD_WCHAR_T_		int		/* wchar_t */
98#define	_BSD_WINT_T_		int		/* wint_t */
99#define	_BSD_RUNE_T_		int		/* rune_t */
100
101/*
102 * mbstate_t is an opaque object to keep conversion state, during multibyte
103 * stream conversions.  The content must not be referenced by user programs.
104 */
105typedef union {
106	char __mbstate8[128];
107	__int64_t __mbstateL;	/* for alignment */
108} __mbstate_t;
109#define	_BSD_MBSTATE_T_		__mbstate_t	/* mbstate_t */
110
111#endif  /* _ANSI_H_ */
112