|
|
1.1 root 1: /*-
2: * Copyright (c) 1990 The Regents of the University of California.
3: * All rights reserved.
4: *
5: * Redistribution and use in source and binary forms are permitted provided
6: * that: (1) source distributions retain this entire copyright notice and
7: * comment, and (2) distributions including binaries display the following
8: * acknowledgement: ``This product includes software developed by the
9: * University of California, Berkeley and its contributors'' in the
10: * documentation or other materials provided with the distribution and in
11: * all advertising materials mentioning features or use of this software.
12: * Neither the name of the University nor the names of its contributors may
13: * be used to endorse or promote products derived from this software without
14: * specific prior written permission.
15: * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
16: * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
17: * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
18: *
19: * @(#)stdarg.h 5.4 (Berkeley) 6/26/90
20: */
21:
22: typedef char *va_list;
23:
24: #define va_arg(ap, type) \
25: ((type *)(ap += sizeof(type) < sizeof(int) ? \
26: (abort(), 0) : sizeof(type)))[-1]
27:
28: #define va_end(ap)
29:
30: #define __va_promote(type) \
31: (((sizeof(type) + sizeof(int) - 1) / sizeof(int)) * sizeof(int))
32:
33: #define va_start(ap, last) \
34: (ap = ((char *)&(last) + __va_promote(last)))
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.