diff options
author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2002-12-02 07:57:17 +0000 |
---|---|---|
committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2002-12-02 07:57:17 +0000 |
commit | 90c4dae08fea47797b3ae574e5dfe35dc66f5631 (patch) | |
tree | 4198e3ccd0a5bab17db2a0f82ee7b6c643115c69 /wince/varargs.h | |
parent | e193fd8d665567c7f3b827c21a1b77af43e2c391 (diff) |
WinCE patch merged
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@3106 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'wince/varargs.h')
-rw-r--r-- | wince/varargs.h | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/wince/varargs.h b/wince/varargs.h new file mode 100644 index 0000000000..2d1d476ccd --- /dev/null +++ b/wince/varargs.h @@ -0,0 +1,34 @@ + +#ifndef VARARGS_H +#define VARARGS_H 1 + +#ifdef __cplusplus +extern "C" { +#endif + +#ifndef _VA_LIST_DEFINED +typedef char *va_list; +#define _VA_LIST_DEFINED +#endif + +//#ifdef MIPS +#define va_alist __va_alist, __va_alist2, __va_alist3, __va_alist4 +#define va_dcl int __va_alist, __va_alist2, __va_alist3, __va_alist4; +#define va_start(list) list = (char *) &__va_alist +#define va_end(list) +#define va_arg(list, mode) ((mode *)(list =\ + (char *) ((((int)list + (__builtin_alignof(mode)<=4?3:7)) &\ + (__builtin_alignof(mode)<=4?-4:-8))+sizeof(mode))))[-1] +#else +#define _INTSIZEOF(n) ( (sizeof(n) + sizeof(int) - 1) & ~(sizeof(int) - 1) ) +#define va_dcl va_list va_alist; +#define va_start(ap) ap = (va_list)&va_alist +#define va_arg(ap,t) ( *(t *)((ap += _INTSIZEOF(t)) - _INTSIZEOF(t)) ) +#define va_end(ap) ap = (va_list)0 +//#endif + +#ifdef __cplusplus +} +#endif + +#endif |