iostream.h
来自「xen虚拟机源代码安装包」· C头文件 代码 · 共 270 行
H
270 行
/* * Copyright (C) 2001 - 2004 Mike Wray <mike.wray@hp.com> * * This library is free software; you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation; either version 2.1 of the License, or * (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */#ifndef _XUTIL_IOSTREAM_H_#define _XUTIL_IOSTREAM_H_#include <stdarg.h>#ifdef __KERNEL__#include <linux/config.h>#include <linux/types.h>#include <linux/errno.h>#else#include <errno.h>#include <stdint.h>#include <stddef.h>#endif#include "allocate.h"/** End of input return value (for getc). */#define IOSTREAM_EOF -1/** An input/output abstraction. */typedef struct IOStream IOStream;/** Record of the functions to use for operations on an * IOStream implementation. */typedef struct IOMethods { /** Read function. Called with the user data, buffer to read into * and number of bytes to read. Must return number of bytes read * on success, less than zero on error. */ int (*read)(IOStream *stream, void *buf, size_t n); /** Write function. Called with user data, buffer to write and * number of bytes to write. Must return number of bytes written on * success, less than zero otherwise. */ int (*write)(IOStream *stream, const void *buf, size_t n); int (*flush)(IOStream *s); int (*error)(IOStream *s); int (*close)(IOStream *s); void (*free)(IOStream *s); void (*lock)(IOStream *s); void (*unlock)(IOStream *s);} IOMethods;/** Abstract i/o object. */struct IOStream { /** Methods to use to implement operations. */ const IOMethods *methods; /** Private state for the implementation. */ const void *data; /** Flag indicating whether the stream is closed. */ int closed; /** Number of bytes written. */ int written; /** Number of bytes read. */ int read; /** Flag indicating whether not to free when closed. */ int nofree;};/** IOStream version of stdin. */extern IOStream *iostdin;/** IOStream version of stdout, */extern IOStream *iostdout;/** IOStream version of stderr. */extern IOStream *iostderr;extern int IOStream_print(IOStream *io, const char *format, ...);extern int IOStream_vprint(IOStream *io, const char *format, va_list args);/** Read from a stream. * * @param stream input * @param buf where to put input * @param n number of bytes to read * @return if ok, number of bytes read, otherwise negative error code */static inline int IOStream_read(IOStream *stream, void *buf, size_t n){ int result; if(stream->closed){ result = -EIO; goto exit; } if(!stream->methods || !stream->methods->read){ result = -EINVAL; goto exit; } result = (stream->methods->read)(stream, buf, n); if(result > 0){ stream->read += result; } exit: return result;}/** Write to a stream. * * @param stream input * @param buf where to put input * @param n number of bytes to write * @return if ok, number of bytes written, otherwise negative error code */static inline int IOStream_write(IOStream *stream, const void *buf, size_t n){ int result; if(stream->closed){ result = -EIO; goto exit; } if(!stream->methods || !stream->methods->write){ result = -EINVAL; goto exit; } result = (stream->methods->write)(stream, buf, n); if(result > 0){ stream->written += result; } exit: return result;}/** Flush the stream. * * @param stream stream * @return 0 on success, negative error code otherwise */static inline int IOStream_flush(IOStream *stream){ int result = 0; if(stream->closed){ result = -EIO; } else if(stream->methods->flush){ result = (stream->methods->flush)(stream); } return result;}/** Check whether the stream has an error. * * @param stream to check * @return 1 for error, 0 otherwise */static inline int IOStream_error(IOStream *stream){ int err = 0; if(stream->methods && stream->methods->error){ err = (stream->methods->error)(stream); } return err;}/** Close the stream. * * @param stream to close * @return 0 on success, negative error code otherwise */static inline int IOStream_close(IOStream *stream){ int err = 0; if(!stream || stream->closed){ err = -EIO; goto exit; } if(stream->methods && stream->methods->close){ err = (stream->methods->close)(stream); stream->closed = 1; } if(stream->nofree) goto exit; if(stream->methods && stream->methods->free){ (stream->methods->free)(stream); } *stream = (IOStream){}; deallocate(stream); exit: return err;}/** Test if the stream has been closed. * * @param stream to check * @return 1 if closed, 0 otherwise */static inline int IOStream_is_closed(IOStream *stream){ return stream->closed;}/** Print a character to a stream, like fputc(). * * @param stream to print to * @param c character to print * @return result code from the print */static inline int IOStream_putc(IOStream *stream, int c){ int err; unsigned char b = (unsigned char)c; err = IOStream_write(stream, &b, 1); if(err < 1){ err = IOSTREAM_EOF; } else { err = b; } return err;}/** Read from a stream, like fgetc(). * * @param stream to read from * @return IOSTREAM_EOF on error, character read otherwise */static inline int IOStream_getc(IOStream *stream){ int err, rc; unsigned char b; err = IOStream_read(stream, &b, 1); if(err < 1){ rc = IOSTREAM_EOF; } else { rc = b; } return rc;}/** Get number of bytes read. * * @param stream to get from * @return number of bytes read */static inline int IOStream_get_read(IOStream *stream){ return stream->read;}/** Get number of bytes written. * * @param stream to get from * @return number of bytes written */static inline int IOStream_get_written(IOStream *stream){ return stream->written;}#endif /* ! _XUTIL_IOSTREAM_H_ */
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?