Main Page | Alphabetical List | Data Structures | Directories | File List | Data Fields | Globals

wsstream.h

Go to the documentation of this file.
00001 /* ==================================================================== 
00002  * The Kannel Software License, Version 1.0 
00003  * 
00004  * Copyright (c) 2001-2008 Kannel Group  
00005  * Copyright (c) 1998-2001 WapIT Ltd.   
00006  * All rights reserved. 
00007  * 
00008  * Redistribution and use in source and binary forms, with or without 
00009  * modification, are permitted provided that the following conditions 
00010  * are met: 
00011  * 
00012  * 1. Redistributions of source code must retain the above copyright 
00013  *    notice, this list of conditions and the following disclaimer. 
00014  * 
00015  * 2. Redistributions in binary form must reproduce the above copyright 
00016  *    notice, this list of conditions and the following disclaimer in 
00017  *    the documentation and/or other materials provided with the 
00018  *    distribution. 
00019  * 
00020  * 3. The end-user documentation included with the redistribution, 
00021  *    if any, must include the following acknowledgment: 
00022  *       "This product includes software developed by the 
00023  *        Kannel Group (http://www.kannel.org/)." 
00024  *    Alternately, this acknowledgment may appear in the software itself, 
00025  *    if and wherever such third-party acknowledgments normally appear. 
00026  * 
00027  * 4. The names "Kannel" and "Kannel Group" must not be used to 
00028  *    endorse or promote products derived from this software without 
00029  *    prior written permission. For written permission, please  
00030  *    contact org@kannel.org. 
00031  * 
00032  * 5. Products derived from this software may not be called "Kannel", 
00033  *    nor may "Kannel" appear in their name, without prior written 
00034  *    permission of the Kannel Group. 
00035  * 
00036  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED 
00037  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 
00038  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 
00039  * DISCLAIMED.  IN NO EVENT SHALL THE KANNEL GROUP OR ITS CONTRIBUTORS 
00040  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,  
00041  * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT  
00042  * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR  
00043  * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,  
00044  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE  
00045  * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,  
00046  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
00047  * ==================================================================== 
00048  * 
00049  * This software consists of voluntary contributions made by many 
00050  * individuals on behalf of the Kannel Group.  For more information on  
00051  * the Kannel Group, please see <http://www.kannel.org/>. 
00052  * 
00053  * Portions of this software are based upon software originally written at  
00054  * WapIT Ltd., Helsinki, Finland for the Kannel project.  
00055  */ 
00056 
00057 /*
00058  *
00059  * wsstream.h
00060  *
00061  * Author: Markku Rossi <mtr@iki.fi>
00062  *
00063  * Copyright (c) 1999-2000 WAPIT OY LTD.
00064  *       All rights reserved.
00065  *
00066  * Generic input / output stream.
00067  *
00068  */
00069 
00070 #ifndef WSSTREAM_H
00071 #define WSSTREAM_H
00072 
00073 /********************* Types and definitions ****************************/
00074 
00075 /* The generic input / output stream that is capable of handling
00076    ISO/IEC-10646 characters. */
00077 
00078 #define WS_STREAM_BUFFER_SIZE   1024
00079 
00080 /* Do IO to the stream instance `context'.  When reading, the function
00081    must read at most `buflen' characters to the buffer `buf' and it
00082    must return the number of characters read.  When writing, the
00083    buffer `buf' has `buflen' characters and the function must return
00084    the number of characters written.  In both operations, if the
00085    function reads or writes less that `buflen' characters, the EOF is
00086    assumed to been seen in the stream. */
00087 typedef size_t (*WsStreamIOProc)(void *context, WsUInt32 *buf, size_t buflen);
00088 
00089 /* Flush all buffered data of the stream instance `context'.  The
00090    function returns WS_TRUE if the flushing was successful or WS_FALSE
00091    otherwise. */
00092 typedef WsBool (*WsStreamFlushProc)(void *context);
00093 
00094 /* Close the stream instance `context'. */
00095 typedef void (*WsStreamCloseProc)(void *context);
00096 
00097 /* A stream handle. */
00098 struct WsStreamRec
00099 {
00100     /* The method functions of this stream. */
00101     WsStreamIOProc io;
00102     WsStreamFlushProc flush;
00103     WsStreamCloseProc close;
00104 
00105     /* The stream instance context. */
00106     void *context;
00107 
00108     /* The current buffered contents of the stream. */
00109     WsUInt32 buffer[WS_STREAM_BUFFER_SIZE];
00110     size_t buffer_pos;
00111     size_t data_in_buffer;
00112 
00113     /* The possible put-back character. */
00114     WsBool ungetch_valid;
00115     WsUInt32 ungetch;
00116 };
00117 
00118 typedef struct WsStreamRec WsStream;
00119 
00120 /********************* Stream access functions **************************/
00121 
00122 /* Get a character from the stream `stream'.  The character is
00123    returned in `ch_return'.  The function returns WS_FALSE if the end
00124    of stream has been encountered. */
00125 WsBool ws_stream_getc(WsStream *stream, WsUInt32 *ch_return);
00126 
00127 /* Put the character `ch' back to the stream `stream'. */
00128 void ws_stream_ungetc(WsStream *stream, WsUInt32 ch);
00129 
00130 /* Flush all buffered data to the stream back-end. */
00131 WsBool ws_stream_flush(WsStream *stream);
00132 
00133 /* Close the stream `stream'. */
00134 void ws_stream_close(WsStream *stream);
00135 
00136 /********************* Constructors for different streams ***************/
00137 
00138 /* A generic constructor to create the actual WsStream from the
00139    context and from the method functions.  The function returns NULL
00140    if the stream creation failed. */
00141 WsStream *ws_stream_new(void *context, WsStreamIOProc io,
00142                         WsStreamFlushProc flush, WsStreamCloseProc close);
00143 
00144 /* Create a new file stream to the file handle `fp'.  The argument
00145    `output' specifies whether the stream is an output or an input
00146    stream, respectively.  The argument `close' specifies whether the
00147    file handle `fp' is closed when the stream is closed.  It is
00148    basicly a good idea to set this argument to WS_FALSE when wrapping
00149    the system streams (stdin, stdout, stderr) in a WsStream.  The
00150    function returns NULL if the stream could not be created. */
00151 WsStream *ws_stream_new_file(FILE *fp, WsBool output, WsBool close);
00152 
00153 /* Create a new data input stream for `data_len' bytes of ISO-8859/1
00154    data in `data'.  The function returns NULL if the stream could not
00155    be created. */
00156 WsStream *ws_stream_new_data_input(const unsigned char *data, size_t data_len);
00157 
00158 #endif /* not WSSTREAM_H */
See file LICENSE for details about the license agreement for using, modifying, copying or deriving work from this software.