|
|
1.1 root 1: /*
2: * Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
3: *
4: * @APPLE_LICENSE_HEADER_START@
5: *
6: * The contents of this file constitute Original Code as defined in and
7: * are subject to the Apple Public Source License Version 1.1 (the
8: * "License"). You may not use this file except in compliance with the
9: * License. Please obtain a copy of the License at
10: * http://www.apple.com/publicsource and read it before using this file.
11: *
12: * This Original Code and all software distributed under the License are
13: * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
14: * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
15: * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
16: * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the
17: * License for the specific language governing rights and limitations
18: * under the License.
19: *
20: * @APPLE_LICENSE_HEADER_END@
21: */
22: /*-
23: * Copyright (c) 1990, 1993
24: * The Regents of the University of California. All rights reserved.
25: *
26: * Redistribution and use in source and binary forms, with or without
27: * modification, are permitted provided that the following conditions
28: * are met:
29: * 1. Redistributions of source code must retain the above copyright
30: * notice, this list of conditions and the following disclaimer.
31: * 2. Redistributions in binary form must reproduce the above copyright
32: * notice, this list of conditions and the following disclaimer in the
33: * documentation and/or other materials provided with the distribution.
34: * 3. All advertising materials mentioning features or use of this software
35: * must display the following acknowledgement:
36: * This product includes software developed by the University of
37: * California, Berkeley and its contributors.
38: * 4. Neither the name of the University nor the names of its contributors
39: * may be used to endorse or promote products derived from this software
40: * without specific prior written permission.
41: *
42: * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
43: * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
44: * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
45: * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
46: * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
47: * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
48: * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
49: * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
50: * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
51: * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
52: * SUCH DAMAGE.
53: *
54: * @(#)stdlib.h 8.5 (Berkeley) 5/19/95
55: */
56:
57: #ifndef _STDLIB_H_
58: #define _STDLIB_H_
59:
60: #include <machine/ansi.h>
61:
62: #ifndef _BSD_SIZE_T_DEFINED_
63: #define _BSD_SIZE_T_DEFINED_
64: typedef _BSD_SIZE_T_ size_t;
65: #endif
66:
67: #ifndef _BSD_WCHAR_T_DEFINED_
68: #define _BSD_WCHAR_T_DEFINED_
69: #ifndef _ANSI_SOURCE
70: typedef _BSD_WCHAR_T_ rune_t;
71: #endif
72: typedef _BSD_WCHAR_T_ wchar_t;
73: #endif
74:
75: typedef struct {
76: int quot; /* quotient */
77: int rem; /* remainder */
78: } div_t;
79:
80: typedef struct {
81: long quot; /* quotient */
82: long rem; /* remainder */
83: } ldiv_t;
84:
85: #ifndef NULL
86: #define NULL 0
87: #endif
88:
89: #define EXIT_FAILURE 1
90: #define EXIT_SUCCESS 0
91:
92: #define RAND_MAX 0x7fffffff
93:
94: extern int __mb_cur_max;
95: #define MB_CUR_MAX __mb_cur_max
96:
97: #include <sys/cdefs.h>
98:
99: __BEGIN_DECLS
100: __dead void
101: abort __P((void));
102: __pure int
103: abs __P((int));
104: int atexit __P((void (*)(void)));
105: double atof __P((const char *));
106: int atoi __P((const char *));
107: long atol __P((const char *));
108: void *bsearch __P((const void *, const void *, size_t,
109: size_t, int (*)(const void *, const void *)));
110: void *calloc __P((size_t, size_t));
111: __pure div_t
112: div __P((int, int));
113: __dead void
114: exit __P((int));
115: void free __P((void *));
116: char *getenv __P((const char *));
117: __pure long
118: labs __P((long));
119: __pure ldiv_t
120: ldiv __P((long, long));
121: void *malloc __P((size_t));
122: void qsort __P((void *, size_t, size_t,
123: int (*)(const void *, const void *)));
124: int rand __P((void));
125: void *realloc __P((void *, size_t));
126: void srand __P((unsigned));
127: double strtod __P((const char *, char **));
128: long strtol __P((const char *, char **, int));
129: unsigned long
130: strtoul __P((const char *, char **, int));
131: int system __P((const char *));
132:
133: /* These are currently just stubs. */
134: int mblen __P((const char *, size_t));
135: size_t mbstowcs __P((wchar_t *, const char *, size_t));
136: int wctomb __P((char *, wchar_t));
137: int mbtowc __P((wchar_t *, const char *, size_t));
138: size_t wcstombs __P((char *, const wchar_t *, size_t));
139:
140: #ifndef _ANSI_SOURCE
141: int putenv __P((const char *));
142: int setenv __P((const char *, const char *, int));
143: #endif
144:
145: #if !defined(_ANSI_SOURCE) && !defined(_POSIX_SOURCE)
146: void *alloca __P((size_t)); /* built-in for gcc */
147: /* getcap(3) functions */
148: char *getbsize __P((int *, long *));
149: char *cgetcap __P((char *, char *, int));
150: int cgetclose __P((void));
151: int cgetent __P((char **, char **, char *));
152: int cgetfirst __P((char **, char **));
153: int cgetmatch __P((char *, char *));
154: int cgetnext __P((char **, char **));
155: int cgetnum __P((char *, char *, long *));
156: int cgetset __P((char *));
157: int cgetstr __P((char *, char *, char **));
158: int cgetustr __P((char *, char *, char **));
159:
160: int daemon __P((int, int));
161: char *devname __P((int, int));
162: int getloadavg __P((double [], int));
163:
164: char *group_from_gid __P((unsigned long, int));
165: int heapsort __P((void *, size_t, size_t,
166: int (*)(const void *, const void *)));
167: char *initstate __P((unsigned long, char *, long));
168: int mergesort __P((void *, size_t, size_t,
169: int (*)(const void *, const void *)));
170: int radixsort __P((const unsigned char **, int, const unsigned char *,
171: unsigned));
172: int sradixsort __P((const unsigned char **, int, const unsigned char *,
173: unsigned));
174: long random __P((void));
175: char *realpath __P((const char *, char resolved_path[]));
176: char *setstate __P((char *));
177: void srandom __P((unsigned long));
178: char *user_from_uid __P((unsigned long, int));
179: #ifndef __STRICT_ANSI__
180: long long
181: strtoq __P((const char *, char **, int));
182: unsigned long long
183: strtouq __P((const char *, char **, int));
184: #endif
185: void unsetenv __P((const char *));
186: #endif
187: __END_DECLS
188:
189: #endif /* _STDLIB_H_ */
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.