xref: /netbsd/sys/arch/vax/include/ansi.h (revision bf9ec67e)
1 /*	$NetBSD: ansi.h,v 1.16 2001/09/17 05:40:38 simonb 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_WINT_T_		int		/* wint_t */
74 #define	_BSD_CLOCKID_T_		int		/* clockid_t */
75 #define	_BSD_TIMER_T_		int		/* timer_t */
76 #define	_BSD_SUSECONDS_T_	int		/* suseconds_t */
77 #define	_BSD_USECONDS_T_	unsigned int	/* useconds_t */
78 
79 /*
80  * NOTE: rune_t is not covered by ANSI nor other standards, and should not
81  * be instantiated outside of lib/libc/locale.  use wchar_t.
82  *
83  * Runes (wchar_t) is declared to be an ``int'' instead of the more natural
84  * ``unsigned long'' or ``long''.  Two things are happening here.  It is not
85  * unsigned so that EOF (-1) can be naturally assigned to it and used.  Also,
86  * it looks like 10646 will be a 31 bit standard.  This means that if your
87  * ints cannot hold 32 bits, you will be in trouble.  The reason an int was
88  * chosen over a long is that the is*() and to*() routines take ints (says
89  * ANSI C), but they use _RUNE_T_ instead of int.  By changing it here, you
90  * lose a bit of ANSI conformance, but your programs will still work.
91  *
92  * Note that _WCHAR_T_ and _RUNE_T_ must be of the same type.  When wchar_t
93  * and rune_t are typedef'd, _WCHAR_T_ will be undef'd, but _RUNE_T remains
94  * defined for ctype.h.
95  */
96 #define	_BSD_WCHAR_T_		int		/* wchar_t */
97 #define	_BSD_WINT_T_		int		/* wint_t */
98 #define	_BSD_RUNE_T_		int		/* rune_t */
99 
100 /*
101  * mbstate_t is an opaque object to keep conversion state, during multibyte
102  * stream conversions.  The content must not be referenced by user programs.
103  */
104 typedef union {
105 	char __mbstate8[128];
106 	__int64_t __mbstateL;	/* for alignment */
107 } __mbstate_t;
108 #define	_BSD_MBSTATE_T_		__mbstate_t	/* mbstate_t */
109 
110 #endif  /* _ANSI_H_ */
111