/usr/include/cctools/chirp_stream.h is in coop-computing-tools-dev 4.0-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 | /*
Copyright (C) 2008- The University of Notre Dame
This software is distributed under the GNU General Public License.
See the file COPYING for details.
*/
#ifndef CHIRP_STREAM_H
#define CHIRP_STREAM_H
#include <sys/time.h>
#include <stdio.h>
/** @file chirp_stream.h
Streaming I/O interface.
This module implements <i>streaming I/O</i> against a Chirp server.
In this model, the user can read and write small amounts of data
in a continuous stream to or from a remote file.
This interface gives higher data throughput than the @ref chirp_reli.h
interface, but it is <i>unreliable</i>. If a streaming connection is
lost, the client must close it and start all over again. If reliability
is more important than performance, use the @ref chirp_reli.h interface instead.
*/
/** Indicates what mode to be used for opening a stream.*/
typedef enum {
CHIRP_STREAM_READ, /**< Open the stream for reading. */
CHIRP_STREAM_WRITE, /**< Open the stream for writing. */
} chirp_stream_mode_t;
/** Open a new stream for reading or writing.
Connects to a named server and creates a stream for reading or writing to the given file.
@param hostport The host and optional port number of the Chirp server.
@param path The pathname of the file to access.
@param mode The mode of the stream, either @ref CHIRP_STREAM_READ or @ref CHIRP_STREAM_WRITE.
@param stoptime The absolute time at which to abort.
@return On success, returns a handle to a chirp_stream. On failure, returns zero and sets errno appropriately.
*/
struct chirp_stream *chirp_stream_open(const char *hostport, const char *path, chirp_stream_mode_t mode, time_t stoptime);
/** Print formatted data to a stream with buffering.
Writes formatted data to a stream, just like a standard Unix printf.
@param stream A stream created by @ref chirp_stream_open.
@param stoptime The absolute time at which to abort.
@param fmt A printf-style format string, followed by the data to transmit.
@return On success, returns the number of characters written to the stream. On failure, returns less than zero and sets errno appropriately.
*/
int chirp_stream_printf(struct chirp_stream *stream, time_t stoptime, const char *fmt, ...);
/** Read a single line from a stream with buffering.
Reads a single line terminated by a linefeed (ASCII byte 10). Carriage returns (ASCII byte 13) are ignored and removed from the input.
@param stream A stream created by @ref chirp_stream_open.
@param line A pointer to a buffer where the line can be placed.
@param length The size of the buffer in bytes.
@param stoptime The absolute time at which to abort.
@return On success, the number of bytes actually read. On end-of-stream, returns zero. On failure, returns less than zero and sets errno appropriately.
*/
int chirp_stream_readline(struct chirp_stream *stream, char *line, int length, time_t stoptime);
/** Write data to a stream.
@param stream A stream created by @ref chirp_stream_open.
@param data A pointer to a buffer of data to write.
@param length The size of the buffer in bytes.
@param stoptime The absolute time at which to abort.
@return On success, the number of bytes actually written. On failure, returns less than zero and sets errno appropriately.
*/
int chirp_stream_write(struct chirp_stream *stream, const void *data, int length, time_t stoptime);
/** Read data from a stream.
@param stream A stream created by @ref chirp_stream_open.
@param data A pointer to a buffer where data can be placed.
@param length The size of the buffer in bytes.
@param stoptime The absolute time at which to abort.
@return On success, the number of bytes actually read. On end-of-stream, returns zero. On failure, returns less than zero and sets errno appropriately.
*/
int chirp_stream_read(struct chirp_stream *stream, void *data, int length, time_t stoptime);
/** Flush buffered data to the stream.
@param stream A stream created by @ref chirp_stream_open.
@param stoptime The absolute time at which to abort.
@return On success, returns the number of characters written to the stream. On failure, returns less than zero and sets errno appropriately.
*/
int chirp_stream_flush(struct chirp_stream *stream, time_t stoptime);
/** Closes a stream.
This routine closes and deallocates all state associated with a stream.
Note that a stream may buffer data internally, so the called does not know if all data has been written successfully unless this function returns success.
@param stream A stream created by @ref chirp_stream_open.
@param stoptime The absolute time at which to abort.
@return On success, returns greater than or equal to zero. On failure, returns less than zero and sets errno appropriately.
*/
int chirp_stream_close(struct chirp_stream *stream, time_t stoptime);
#endif
|