1N/A/***********************************************************************
1N/A* *
1N/A* This software is part of the ast package *
1N/A* Copyright (c) 1985-2011 AT&T Intellectual Property *
1N/A* and is licensed under the *
1N/A* Common Public License, Version 1.0 *
1N/A* by AT&T Intellectual Property *
1N/A* *
1N/A* A copy of the License is available at *
1N/A* http://www.opensource.org/licenses/cpl1.0.txt *
1N/A* (with md5 checksum 059e8cd6165cb4c31e351f2b69388fd9) *
1N/A* *
1N/A* Information and Software Systems Research *
1N/A* AT&T Research *
1N/A* Florham Park NJ *
1N/A* *
1N/A* Glenn Fowler <gsf@research.att.com> *
1N/A* David Korn <dgk@research.att.com> *
1N/A* Phong Vo <kpv@research.att.com> *
1N/A* *
1N/A***********************************************************************/
1N/A#pragma prototyped
1N/A
1N/A#ifndef _STDHDR_H
1N/A#define _STDHDR_H 1
1N/A
1N/A#ifndef _NO_LARGEFILE64_SOURCE
1N/A#define _NO_LARGEFILE64_SOURCE 1
1N/A#endif
1N/A#undef _LARGEFILE64_SOURCE
1N/A
1N/A#define _ast_fseeko ______fseeko
1N/A#define _ast_ftello ______ftello
1N/A#include "sfhdr.h"
1N/A#undef _ast_fseeko
1N/A#undef _ast_ftello
1N/A
1N/A#include "stdio.h"
1N/A
1N/A#define SF_MB 010000
1N/A#define SF_WC 020000
1N/A
1N/A#if _UWIN
1N/A
1N/A#define STDIO_TRANSFER 1
1N/A
1N/Atypedef int (*Fun_f)();
1N/A
1N/Atypedef struct Funvec_s
1N/A{
1N/A const char* name;
1N/A Fun_f vec[2];
1N/A} Funvec_t;
1N/A
1N/Aextern int _stdfun(Sfio_t*, Funvec_t*);
1N/A
1N/A#define STDIO_INT(p,n,t,f,a) \
1N/A { \
1N/A typedef t (*_s_f)f; \
1N/A int _i; \
1N/A static Funvec_t _v = { n }; \
1N/A if ((_i = _stdfun(p, &_v)) < 0) \
1N/A return -1; \
1N/A else if (_i > 0) \
1N/A return ((_s_f)_v.vec[_i])a; \
1N/A }
1N/A
1N/A#define STDIO_PTR(p,n,t,f,a) \
1N/A { \
1N/A typedef t (*_s_f)f; \
1N/A int _i; \
1N/A static Funvec_t _v = { n }; \
1N/A if ((_i = _stdfun(p, &_v)) < 0) \
1N/A return 0; \
1N/A else if (_i > 0) \
1N/A return ((_s_f)_v.vec[_i])a; \
1N/A }
1N/A
1N/A#define STDIO_VOID(p,n,t,f,a) \
1N/A { \
1N/A typedef t (*_s_f)f; \
1N/A int _i; \
1N/A static Funvec_t _v = { n }; \
1N/A if ((_i = _stdfun(p, &_v)) < 0) \
1N/A return; \
1N/A else if (_i > 0) \
1N/A { \
1N/A ((_s_f)_v.vec[_i])a; \
1N/A return; \
1N/A } \
1N/A }
1N/A
1N/A#else
1N/A
1N/A#define STDIO_INT(p,n,t,f,a)
1N/A#define STDIO_PTR(p,n,t,f,a)
1N/A#define STDIO_VOID(p,n,t,f,a)
1N/A
1N/A#endif
1N/A
1N/A#define FWIDE(f,r) \
1N/A do \
1N/A { \
1N/A if (fwide(f, 0) < 0) \
1N/A return r; \
1N/A f->bits |= SF_WC; \
1N/A } while (0)
1N/A
1N/A#ifdef __EXPORT__
1N/A#define extern __EXPORT__
1N/A#endif
1N/A
1N/Aextern int sfdcwide(Sfio_t*);
1N/A
1N/A#endif