Loading...
--- Libc/Libc-763.13/stdio/FreeBSD/local.h.patch
+++ Libc/Libc-498.1.5/stdio/FreeBSD/local.h.patch
@@ -1,7 +1,7 @@
---- local.h.orig 2011-02-15 10:44:57.000000000 -0800
-+++ local.h 2011-02-15 11:16:59.000000000 -0800
-@@ -33,8 +33,11 @@
- * $FreeBSD: src/lib/libc/stdio/local.h,v 1.33 2008/05/05 16:03:52 jhb Exp $
+--- local.h.orig 2004-11-25 11:38:35.000000000 -0800
++++ local.h 2005-02-23 17:26:30.000000000 -0800
+@@ -37,8 +37,11 @@
+ * $FreeBSD: src/lib/libc/stdio/local.h,v 1.26 2004/07/16 05:52:51 tjr Exp $
*/
+#include <sys/cdefs.h>
@@ -12,29 +12,18 @@
#include <string.h>
#include <wchar.h>
-@@ -50,36 +53,69 @@
+@@ -53,8 +56,8 @@
+ extern int _ftello(FILE *, fpos_t *);
extern int _fseeko(FILE *, off_t, int, int);
extern int __fflush(FILE *fp);
- extern void __fcloseall(void);
-extern wint_t __fgetwc(FILE *);
-extern wint_t __fputwc(wchar_t, FILE *);
+extern wint_t __fgetwc(FILE *, locale_t);
+extern wint_t __fputwc(wchar_t, FILE *, locale_t);
extern int __sflush(FILE *);
--extern FILE *__sfp(void);
-+extern FILE *__sfp(int);
-+extern void __sfprelease(FILE *); /* mark free and update count as needed */
+ extern FILE *__sfp(void);
extern int __slbexpand(FILE *, size_t);
- extern int __srefill(FILE *);
-+extern int __srefill0(FILE *);
-+extern int __srefill1(FILE *);
- extern int __sread(void *, char *, int);
- extern int __swrite(void *, char const *, int);
- extern fpos_t __sseek(void *, fpos_t, int);
- extern int __sclose(void *);
- extern void __sinit(void);
- extern void _cleanup(void);
-+extern void (*__cleanup)(void);
+@@ -69,16 +72,16 @@
extern void __smakebuf(FILE *);
extern int __swhatbuf(FILE *, size_t *, int *);
extern int _fwalk(int (*)(FILE *));
@@ -55,40 +44,15 @@
+extern int __vfwprintf(FILE *, locale_t, const wchar_t *, __va_list) __DARWIN_LDBL_COMPAT(__vfwprintf);
+extern int __vfwscanf(FILE * __restrict, locale_t, const wchar_t * __restrict,
+ __va_list) __DARWIN_LDBL_COMPAT(__vfwscanf);
- extern size_t __fread(void * __restrict buf, size_t size, size_t count,
- FILE * __restrict fp);
+
extern int __sdidinit;
+@@ -124,7 +127,7 @@
-+/* hold a buncha junk that would grow the ABI */
-+struct __sFILEX {
-+ unsigned char *up; /* saved _p when _p is doing ungetc data */
-+ pthread_mutex_t fl_mutex; /* used for MT-safety */
-+ pthread_t fl_owner; /* current owner */
-+ int fl_count; /* recursive lock count */
-+ int orientation:2; /* orientation for fwide() */
-+ int counted:1; /* stream counted against STREAM_MAX */
-+ mbstate_t mbstate; /* multibyte conversion state */
-+};
-+
-+#define _up _extra->up
-+#define _fl_mutex _extra->fl_mutex
-+#define _fl_owner _extra->fl_owner
-+#define _fl_count _extra->fl_count
-+#define _orientation _extra->orientation
-+#define _mbstate _extra->mbstate
-+#define _counted _extra->counted
-+
-+#define INITEXTRA(fp) do { \
-+ (fp)->_extra->up = NULL; \
+ #define INITEXTRA(fp) { \
+ (fp)->_extra->_up = NULL; \
+- (fp)->_extra->fl_mutex = PTHREAD_MUTEX_INITIALIZER; \
+ (fp)->_extra->fl_mutex = (pthread_mutex_t)PTHREAD_MUTEX_INITIALIZER; \
-+ (fp)->_extra->fl_owner = NULL; \
-+ (fp)->_extra->fl_count = 0; \
-+ (fp)->_extra->orientation = 0; \
-+ memset(&(fp)->_extra->mbstate, 0, sizeof(mbstate_t)); \
-+ (fp)->_extra->counted = 0; \
-+} while(0);
-+
- /*
- * Prepare the given FILE for writing, and return 0 iff it
- * can be written now. Otherwise, return EOF and set errno.
+ (fp)->_extra->fl_owner = NULL; \
+ (fp)->_extra->fl_count = 0; \
+ (fp)->_extra->orientation = 0; \