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