XBinder  Version 2.7.x
rtxStream.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2003-2020 Objective Systems, Inc.
3  *
4  * This software is furnished under a license and may be used and copied
5  * only in accordance with the terms of such license and with the
6  * inclusion of the above copyright notice. This software or any other
7  * copies thereof may not be provided or otherwise made available to any
8  * other person. No title to and ownership of the software is hereby
9  * transferred.
10  *
11  * The information in this software is subject to change without notice
12  * and should not be construed as a commitment by Objective Systems, Inc.
13  *
14  * PROPRIETARY NOTICE
15  *
16  * This software is an unpublished work subject to a confidentiality agreement
17  * and is protected by copyright and trade secret law. Unauthorized copying,
18  * redistribution or other use of this work is prohibited.
19  *
20  * The above notice of copyright on this source code product does not indicate
21  * any actual or intended publication of such source code.
22  *
23  *****************************************************************************/
28 #ifndef _RTXSTREAM_H_
29 #define _RTXSTREAM_H_
30 
31 #ifndef _NO_STREAM
32 
33 #include "rtxsrc/rtxContext.h"
34 #include "rtxsrc/rtxMemBuf.h"
35 
36 #ifdef __cplusplus
37 extern "C" {
38 #endif
39 
59 struct OSRTSTREAM;
60 
77 typedef long (*OSRTStreamReadProc)
78  (struct OSRTSTREAM* pStream, OSOCTET* pbuffer, size_t nocts);
79 
84 
90 typedef long (*OSRTStreamWriteProc)(struct OSRTSTREAM* pStream,
91  const OSOCTET* data, size_t numocts);
92 
98 typedef int (*OSRTStreamFlushProc)(struct OSRTSTREAM* pStream);
99 
105 typedef int (*OSRTStreamCloseProc)(struct OSRTSTREAM* pStream);
106 
112 typedef int (*OSRTStreamSkipProc)
113  (struct OSRTSTREAM* pStream, size_t skipBytes);
114 
120 typedef int (*OSRTStreamMarkProc)
121  (struct OSRTSTREAM* pStream, size_t readAheadLimit);
122 
128 typedef int (*OSRTStreamResetProc) (struct OSRTSTREAM* pStream);
129 
135 typedef int (*OSRTStreamGetPosProc)
136  (struct OSRTSTREAM* pStream, size_t* ppos);
137 
143 typedef int (*OSRTStreamSetPosProc)
144  (struct OSRTSTREAM* pStream, size_t pos);
145 
146 #define OSRTSTRMF_INPUT 0x0001
147 #define OSRTSTRMF_OUTPUT 0x0002
148 #define OSRTSTRMF_BUFFERED 0x8000 /* direct-buffer stream */
149 #define OSRTSTRMF_UNBUFFERED 0x4000 /* force unbuffered stream */
150 #define OSRTSTRMF_POSMARKED 0x2000 /* stream has marked position */
151 #define OSRTSTRMF_FIXINMEM 0x1000 /* disable flushing */
152 #define OSRTSTRMF_HEXTEXT 0x0800 /* do hex text / binary conversion */
153 
154 #define OSRTSTRMF_BUF_INPUT (OSRTSTRMF_INPUT|OSRTSTRMF_BUFFERED)
155 #define OSRTSTRMF_BUF_OUTPUT (OSRTSTRMF_OUTPUT|OSRTSTRMF_BUFFERED)
156 
157 
158 #define OSRTSTRMID_FILE 1
159 #define OSRTSTRMID_SOCKET 2
160 #define OSRTSTRMID_MEMORY 3
161 #define OSRTSTRMID_BUFFERED 4
162 #define OSRTSTRMID_DIRECTBUF 5
163 #define OSRTSTRMID_CTXTBUF 6
164 #define OSRTSTRMID_ZLIB 7
165 #define OSRTSTRMID_USER 1000
166 
167 #define OSRTSTRM_K_BUFSIZE 1024
168 
169 #define OSRTSTRM_K_INVALIDMARK ((size_t)-1)
170 
171 #define OSRTSTREAM_BYTEINDEX(pctxt) \
172 (((pctxt)->pStream->flags & OSRTSTRMF_BUFFERED) ? \
173  ((pctxt)->pStream->bytesProcessed + (pctxt)->buffer.byteIndex) : \
174  ((pctxt)->pStream->bytesProcessed /* was ioBytes */ ))
175 
176 #define OSRTSTREAM_ID(pctxt) ((pctxt)->pStream->id)
177 #define OSRTSTREAM_FLAGS(pctxt) ((pctxt)->pStream->flags)
178 
184 typedef struct OSRTSTREAM {
195  void* extra;
196  size_t bufsize;
200  size_t readAheadLimit;
202  size_t bytesProcessed;
206  size_t ioBytes;
208  size_t nextMarkOffset;
210  size_t segsize;
211  OSUINT32 id;
217  OSRTMEMBUF* pCaptureBuf;
218 
219  OSUINT16 flags;
220 } OSRTSTREAM;
221 
231 EXTERNRT int rtxStreamClose (OSCTXT* pctxt);
232 
243 EXTERNRT int rtxStreamFlush (OSCTXT* pctxt);
244 
266 EXTERNRT int rtxStreamLoadInputBuffer(OSCTXT* pctxt, OSSIZE nbytes);
267 
268 
278 EXTERNRT int rtxStreamInit (OSCTXT* pctxt);
279 
289 EXTERNRT int rtxStreamInitCtxtBuf (OSCTXT* pctxt);
290 
302 EXTERNRT int rtxStreamRemoveCtxtBuf (OSCTXT* pctxt);
303 
318 EXTERNRT long rtxStreamRead
319  (OSCTXT* pctxt, OSOCTET* pbuffer, size_t nocts);
320 
322 #define rtxStreamBlockingRead rtxStreamRead
323 
324 EXTERNRT long rtxStreamReadDirect
325 (OSCTXT* pctxt, OSOCTET* pbuffer, OSSIZE bufSize);
326 
327 
342 EXTERNRT int rtxStreamSkip (OSCTXT* pctxt, size_t skipBytes);
343 
356 EXTERNRT long rtxStreamWrite
357  (OSCTXT* pctxt, const OSOCTET* data, size_t numocts);
358 
373 EXTERNRT int rtxStreamGetIOBytes (OSCTXT* pctxt, size_t* pPos);
374 
389 EXTERNRT int rtxStreamMark (OSCTXT* pctxt, size_t readAheadLimit);
390 
400 EXTERNRT int rtxStreamReset (OSCTXT* pctxt);
401 
412 EXTERNRT OSBOOL rtxStreamMarkSupported (OSCTXT* pctxt);
413 
422 EXTERNRT OSBOOL rtxStreamIsOpened (OSCTXT* pctxt);
423 
432 EXTERNRT OSBOOL rtxStreamIsReadable (OSCTXT* pctxt);
433 
442 EXTERNRT OSBOOL rtxStreamIsWritable (OSCTXT* pctxt);
443 
453 EXTERNRT int rtxStreamRelease (OSCTXT* pctxt);
454 
465 EXTERNRT void rtxStreamSetCapture (OSCTXT* pctxt, OSRTMEMBUF* pmembuf);
466 
476 EXTERNRT OSRTMEMBUF* rtxStreamGetCapture (OSCTXT* pctxt);
477 
486 EXTERNRT int rtxStreamGetPos (OSCTXT* pctxt, size_t* ppos);
487 
496 EXTERNRT int rtxStreamSetPos (OSCTXT* pctxt, size_t pos);
497 
500 #ifdef __cplusplus
501 }
502 #endif
503 
504 #endif /* _NO_STREAM */
505 #endif /* _RTXSTREAM_H_ */
506 
EXTERNRT int rtxStreamGetPos(OSCTXT *pctxt, size_t *ppos)
Get the current position in input stream.
OSRTStreamGetPosProc getPos
pointer to getPos function
Definition: rtxStream.h:192
EXTERNRT long rtxStreamWrite(OSCTXT *pctxt, const OSOCTET *data, size_t numocts)
This function writes the specified amount of octets from the specified array to the output stream...
int(* OSRTStreamSkipProc)(struct OSRTSTREAM *pStream, size_t skipBytes)
Stream skip function pointer type.
Definition: rtxStream.h:113
size_t markedBytesProcessed
the marked number of bytes already processed
Definition: rtxStream.h:204
size_t readAheadLimit
read ahead limit (used by rtxStreamMark/rtxStreamReset
Definition: rtxStream.h:200
OSRTStreamReadProc OSRTStreamBlockingReadProc
OSRTStreamBlockingReadProc is deprecated.
Definition: rtxStream.h:83
EXTERNRT int rtxStreamInit(OSCTXT *pctxt)
This function initializes a stream part of the context block.
EXTERNRT void rtxStreamSetCapture(OSCTXT *pctxt, OSRTMEMBUF *pmembuf)
This function sets a capture buffer for the stream.
EXTERNRT OSBOOL rtxStreamMarkSupported(OSCTXT *pctxt)
Tests if this input stream supports the mark and reset methods.
EXTERNRT OSBOOL rtxStreamIsOpened(OSCTXT *pctxt)
Tests if this stream opened (for reading or writing).
OSUINT16 flags
flags (see OSRTSTRMF_* macros
Definition: rtxStream.h:219
int(* OSRTStreamCloseProc)(struct OSRTSTREAM *pStream)
Stream close function pointer type.
Definition: rtxStream.h:105
EXTERNRT int rtxStreamGetIOBytes(OSCTXT *pctxt, size_t *pPos)
This function returns the number of processed octets.
size_t segsize
size of decoded segment
Definition: rtxStream.h:210
long(* OSRTStreamReadProc)(struct OSRTSTREAM *pStream, OSOCTET *pbuffer, size_t nocts)
Stream read function pointer type.
Definition: rtxStream.h:78
OSUINT32 id
id of stream (see OSRTSTRMID_* macros)
Definition: rtxStream.h:211
OSRTStreamWriteProc write
pointer to write function
Definition: rtxStream.h:186
EXTERNRT int rtxStreamSetPos(OSCTXT *pctxt, size_t pos)
Set the current position in input stream.
size_t nextMarkOffset
offset of next appropriate mark position
Definition: rtxStream.h:208
OSRTMEMBUF * pCaptureBuf
Buffer into which data read from stream can be captured for debugging purposes.
Definition: rtxStream.h:217
int(* OSRTStreamSetPosProc)(struct OSRTSTREAM *pStream, size_t pos)
Stream set position function pointer type.
Definition: rtxStream.h:144
size_t bytesProcessed
the number of bytes processed by the application program
Definition: rtxStream.h:202
EXTERNRT int rtxStreamInitCtxtBuf(OSCTXT *pctxt)
This function initializes a stream to use the context memory buffer for stream buffering.
OSRTStreamSetPosProc setPos
pointer to setPos function
Definition: rtxStream.h:193
int(* OSRTStreamFlushProc)(struct OSRTSTREAM *pStream)
Stream flush function pointer type.
Definition: rtxStream.h:98
Common run-time context definitions.
EXTERNRT int rtxStreamFlush(OSCTXT *pctxt)
This function flushes the output stream and forces any buffered output octets to be written out...
EXTERNRT OSBOOL rtxStreamIsWritable(OSCTXT *pctxt)
Tests if this stream opened for writing.
long(* OSRTStreamWriteProc)(struct OSRTSTREAM *pStream, const OSOCTET *data, size_t numocts)
Stream write function pointer type.
Definition: rtxStream.h:90
EXTERNRT OSRTMEMBUF * rtxStreamGetCapture(OSCTXT *pctxt)
This function returns the capture buffer currently assigned to the stream.
OSRTStreamSkipProc skip
pointer to skip function
Definition: rtxStream.h:189
EXTERNRT int rtxStreamClose(OSCTXT *pctxt)
This function closes the input or output stream and releases any system resources associated with the...
int(* OSRTStreamResetProc)(struct OSRTSTREAM *pStream)
Stream reset function pointer type.
Definition: rtxStream.h:128
int(* OSRTStreamMarkProc)(struct OSRTSTREAM *pStream, size_t readAheadLimit)
Stream mark function pointer type.
Definition: rtxStream.h:121
EXTERNRT int rtxStreamSkip(OSCTXT *pctxt, size_t skipBytes)
This function skips over and discards the specified amount of data octets from this input stream...
size_t bufsize
physical size of pctxt->buffer.data buffer.
Definition: rtxStream.h:196
size_t ioBytes
the actual number of bytes read from or written to the stream
Definition: rtxStream.h:206
OSRTStreamMarkProc mark
pointer to mark function
Definition: rtxStream.h:190
EXTERNRT int rtxStreamRelease(OSCTXT *pctxt)
This function releases the stream's resources.
struct OSRTSTREAM OSRTSTREAM
The stream control block.
EXTERNRT int rtxStreamLoadInputBuffer(OSCTXT *pctxt, OSSIZE nbytes)
This is for meant for internal use by the runtime.
EXTERNRT OSBOOL rtxStreamIsReadable(OSCTXT *pctxt)
Tests if this stream opened for reading.
OSRTStreamReadProc read
pointer to read function
Definition: rtxStream.h:185
EXTERNRT int rtxStreamReset(OSCTXT *pctxt)
Repositions this stream to the position recorded by the last call to the rtxStreamMark function...
OSRTStreamCloseProc close
pointer to close function
Definition: rtxStream.h:188
OSRTStreamResetProc reset
pointer to reset function
Definition: rtxStream.h:191
Run-time context structure.
Definition: rtxContext.h:197
OSRTStreamFlushProc flush
pointer to flush function
Definition: rtxStream.h:187
The stream control block.
Definition: rtxStream.h:184
int(* OSRTStreamGetPosProc)(struct OSRTSTREAM *pStream, size_t *ppos)
Stream get position function pointer type.
Definition: rtxStream.h:136
EXTERNRT int rtxStreamRemoveCtxtBuf(OSCTXT *pctxt)
This function removes the use of a context memory buffer from a stream.
EXTERNRT int rtxStreamMark(OSCTXT *pctxt, size_t readAheadLimit)
Marks the current position in this input stream.
void * extra
pointer to stream-specific data
Definition: rtxStream.h:195
EXTERNRT long rtxStreamRead(OSCTXT *pctxt, OSOCTET *pbuffer, size_t nocts)
Read up to nocts bytes of data from the input stream into an array of octets.