]> git.saurik.com Git - apple/libc.git/blobdiff - include/stdio.h
Libc-391.4.2.tar.gz
[apple/libc.git] / include / stdio.h
index f0d5047ccbb72084be4b4eae50dcb8cab83132be..b1a02df8e3ee7437ea1ac412ccd6d91771c3ead9 100644 (file)
@@ -3,8 +3,6 @@
  *
  * @APPLE_LICENSE_HEADER_START@
  * 
- * Copyright (c) 1999-2003 Apple Computer, Inc.  All Rights Reserved.
- * 
  * This file contains Original Code and/or Modifications of Original Code
  * as defined in and that are subject to the Apple Public Source License
  * Version 2.0 (the 'License'). You may not use this file except in
 #include <_types.h>
 #include <sys/cdefs.h>
 
-#ifndef _POSIX_SOURCE
-#include <stdarg.h>
-#else /* _POSIX_SOURCE */
-/* set __need___va_list to only define __gnuc_va_list */
-#define __need___va_list
-#include <stdarg.h>
-#ifdef __GNUC_VA_LIST
-#ifndef _VA_LIST_DEFINED
-#define _VA_LIST_DEFINED
-typedef __gnuc_va_list va_list;
-#endif /* _VA_LIST_DEFINED */
-#endif /* __GNUC_VA_LIST */
-#endif /* _POSIX_SOURCE */
-
-#ifndef        _BSD_SIZE_T_DEFINED_
-#define        _BSD_SIZE_T_DEFINED_
-typedef        __osx_size_t    size_t;
+#ifndef _VA_LIST
+#define _VA_LIST
+/* DO NOT REMOVE THIS COMMENT: fixincludes needs to see:
+ * __gnuc_va_list and include <stdarg.h> */
+typedef __darwin_va_list       va_list;
+#endif
+
+#ifndef        _SIZE_T
+#define        _SIZE_T
+typedef        __darwin_size_t         size_t;
 #endif
 
 #ifndef NULL
-#define NULL __OSX_NULL
+#define NULL __DARWIN_NULL
 #endif /* ! NULL */
 
 #if !defined(_ANSI_SOURCE) && !defined(__STRICT_ANSI__)
-typedef __osx_off_t fpos_t;
+typedef __darwin_off_t         fpos_t;
 #else
-typedef __int64_t fpos_t;
+typedef __int64_t              fpos_t;
 #endif
 
 #define        _FSTDIO                 /* Define for new stdio with functions. */
@@ -105,8 +96,8 @@ typedef __int64_t fpos_t;
 
 /* stdio buffers */
 struct __sbuf {
-       unsigned char *_base;
-       int     _size;
+       unsigned char   *_base;
+       int             _size;
 };
 
 /* hold a buncha junk that would grow the ABI */
@@ -172,7 +163,13 @@ typedef    struct __sFILE {
 } FILE;
 
 __BEGIN_DECLS
+#if __DARWIN_UNIX03
+extern FILE *__stdinp;
+extern FILE *__stdoutp;
+extern FILE *__stderrp;
+#else /* !__DARWIN_UNIX03 */
 extern FILE __sF[];
+#endif /* __DARWIN_UNIX03 */
 __END_DECLS
 
 #define        __SLBF  0x0001          /* line buffered */
@@ -235,9 +232,15 @@ __END_DECLS
 #define        SEEK_END        2       /* set file offset to EOF plus offset */
 #endif
 
+#if __DARWIN_UNIX03
+#define        stdin   __stdinp
+#define        stdout  __stdoutp
+#define        stderr  __stderrp
+#else /* !__DARWIN_UNIX03 */
 #define stdin  (&__sF[0])
 #define stdout (&__sF[1])
 #define stderr (&__sF[2])
+#endif /* __DARWIN_UNIX03 */
 
 /*
  * Functions defined in ANSI C standard.
@@ -252,46 +255,46 @@ int        fgetc(FILE *);
 int     fgetpos(FILE * __restrict, fpos_t *);
 char   *fgets(char * __restrict, int, FILE *);
 FILE   *fopen(const char * __restrict, const char * __restrict);
-int     fprintf(FILE * __restrict, const char * __restrict, ...);
+int     fprintf(FILE * __restrict, const char * __restrict, ...) __DARWIN_LDBL_COMPAT(fprintf);
 int     fputc(int, FILE *);
 int     fputs(const char * __restrict, FILE * __restrict);
 size_t  fread(void * __restrict, size_t, size_t, FILE * __restrict);
 FILE   *freopen(const char * __restrict, const char * __restrict,
-           FILE * __restrict);
-int     fscanf(FILE * __restrict, const char * __restrict, ...);
+           FILE * __restrict) __DARWIN_ALIAS(freopen);
+int     fscanf(FILE * __restrict, const char * __restrict, ...) __DARWIN_LDBL_COMPAT(fscanf);
 int     fseek(FILE *, long, int);
 int     fsetpos(FILE *, const fpos_t *);
 long    ftell(FILE *);
-size_t  fwrite(const void * __restrict, size_t, size_t, FILE * __restrict);
+size_t  fwrite(const void * __restrict, size_t, size_t, FILE * __restrict) __DARWIN_ALIAS(fwrite);
 int     getc(FILE *);
 int     getchar(void);
 char   *gets(char *);
-#if !defined(_ANSI_SOURCE) && !defined(_POSIX_SOURCE)
+#if !defined(_ANSI_SOURCE) && !defined(_POSIX_C_SOURCE)
 extern __const int sys_nerr;           /* perror(3) external variables */
 extern __const char *__const sys_errlist[];
 #endif
 void    perror(const char *);
-int     printf(const char * __restrict, ...);
+int     printf(const char * __restrict, ...) __DARWIN_LDBL_COMPAT(printf);
 int     putc(int, FILE *);
 int     putchar(int);
 int     puts(const char *);
 int     remove(const char *);
 int     rename (const char *, const char *);
 void    rewind(FILE *);
-int     scanf(const char * __restrict, ...);
+int     scanf(const char * __restrict, ...) __DARWIN_LDBL_COMPAT(scanf);
 void    setbuf(FILE * __restrict, char * __restrict);
 int     setvbuf(FILE * __restrict, char * __restrict, int, size_t);
-int     sprintf(char * __restrict, const char * __restrict, ...);
-int     sscanf(const char * __restrict, const char * __restrict, ...);
+int     sprintf(char * __restrict, const char * __restrict, ...) __DARWIN_LDBL_COMPAT(sprintf);
+int     sscanf(const char * __restrict, const char * __restrict, ...) __DARWIN_LDBL_COMPAT(sscanf);
 FILE   *tmpfile(void);
 char   *tmpnam(char *);
 int     ungetc(int, FILE *);
-int     vfprintf(FILE * __restrict, const char * __restrict, va_list);
-int     vprintf(const char * __restrict, va_list);
-int     vsprintf(char * __restrict, const char * __restrict, va_list);
-#if !defined(_ANSI_SOURCE) && !defined(_POSIX_SOURCE)
-int     asprintf(char **, const char *, ...);
-int     vasprintf(char **, const char *, va_list);
+int     vfprintf(FILE * __restrict, const char * __restrict, va_list) __DARWIN_LDBL_COMPAT(vfprintf);
+int     vprintf(const char * __restrict, va_list) __DARWIN_LDBL_COMPAT(vprintf);
+int     vsprintf(char * __restrict, const char * __restrict, va_list) __DARWIN_LDBL_COMPAT(vsprintf);
+#if !defined(_ANSI_SOURCE) && !defined(_POSIX_C_SOURCE)
+int     asprintf(char **, const char *, ...) __DARWIN_LDBL_COMPAT(asprintf);
+int     vasprintf(char **, const char *, va_list) __DARWIN_LDBL_COMPAT(vasprintf);
 #endif
 __END_DECLS
 
@@ -304,16 +307,16 @@ __END_DECLS
 
 __BEGIN_DECLS
 char   *ctermid(char *);
-#ifndef _POSIX_SOURCE
+#ifndef _POSIX_C_SOURCE
 char   *ctermid_r(char *);
 #endif /* not POSIX */
 FILE   *fdopen(int, const char *);
-#ifndef _POSIX_SOURCE
+#ifndef _POSIX_C_SOURCE
 char   *fgetln(FILE *, size_t *);
 #endif /* not POSIX */
 int     fileno(FILE *);
 void    flockfile(FILE *);
-#ifndef _POSIX_SOURCE
+#ifndef _POSIX_C_SOURCE
 __const char 
        *fmtcheck(const char *, const char *);
 int     fpurge(FILE *);
@@ -324,25 +327,25 @@ int        ftrylockfile(FILE *);
 void    funlockfile(FILE *);
 int     getc_unlocked(FILE *);
 int     getchar_unlocked(void);
-#ifndef _POSIX_SOURCE
+#ifndef _POSIX_C_SOURCE
 int     getw(FILE *);
 #endif /* not POSIX */
 int     pclose(FILE *);
 FILE   *popen(const char *, const char *);
 int     putc_unlocked(int, FILE *);
 int     putchar_unlocked(int);
-#ifndef _POSIX_SOURCE
+#ifndef _POSIX_C_SOURCE
 int     putw(int, FILE *);
 void    setbuffer(FILE *, char *, int);
 int     setlinebuf(FILE *);
 #endif /* not POSIX */
-int     snprintf(char * __restrict, size_t, const char * __restrict, ...);
+int     snprintf(char * __restrict, size_t, const char * __restrict, ...) __DARWIN_LDBL_COMPAT(snprintf);
 char   *tempnam(const char *, const char *);
-int     vfscanf(FILE * __restrict, const char * __restrict, va_list);
-int     vscanf(const char * __restrict, va_list);
-int     vsnprintf(char * __restrict, size_t, const char * __restrict, va_list);
-int     vsscanf(const char * __restrict, const char * __restrict, va_list);
-#ifndef _POSIX_SOURCE
+int     vfscanf(FILE * __restrict, const char * __restrict, va_list) __DARWIN_LDBL_COMPAT(vfscanf);
+int     vscanf(const char * __restrict, va_list) __DARWIN_LDBL_COMPAT(vscanf);
+int     vsnprintf(char * __restrict, size_t, const char * __restrict, va_list) __DARWIN_LDBL_COMPAT(vsnprintf);
+int     vsscanf(const char * __restrict, const char * __restrict, va_list) __DARWIN_LDBL_COMPAT(vsscanf);
+#ifndef _POSIX_C_SOURCE
 FILE   *zopen(const char *, const char *, int);
 #endif /* not POSIX */
 __END_DECLS
@@ -350,7 +353,7 @@ __END_DECLS
 /*
  * Stdio function-access interface.
  */
-#ifndef _POSIX_SOURCE
+#ifndef _POSIX_C_SOURCE
 __BEGIN_DECLS
 FILE   *funopen(const void *,
                int (*)(void *, char *, int),
@@ -368,7 +371,7 @@ __END_DECLS
  */
 __BEGIN_DECLS
 int    __srget(FILE *);
-int    __svfscanf(FILE *, const char *, va_list);
+int    __svfscanf(FILE *, const char *, va_list) __DARWIN_LDBL_COMPAT(__svfscanf);
 int    __swbuf(int, FILE *);
 __END_DECLS
 
@@ -404,7 +407,7 @@ static __inline int __sputc(int _c, FILE *_p) {
 #define        __sfileno(p)    ((p)->_file)
 
 #ifndef _ANSI_SOURCE
-#ifndef _POSIX_SOURCE
+#ifndef _POSIX_C_SOURCE
 #define        feof_unlocked(p)        __sfeof(p)
 #define        ferror_unlocked(p)      __sferror(p)
 #define        clearerr_unlocked(p)    __sclearerr(p)
@@ -420,4 +423,8 @@ static __inline int __sputc(int _c, FILE *_p) {
 #define        putchar_unlocked(x)     putc_unlocked(x, stdout)
 #endif /* not ANSI */
 
+#ifdef _USE_EXTENDED_LOCALES_
+#include <xlocale/_stdio.h>
+#endif /* _USE_EXTENDED_LOCALES_ */
+
 #endif /* _STDIO_H_ */