diff options
author | paul <paul> | 2005-05-03 11:07:56 +0200 |
---|---|---|
committer | paul <paul> | 2005-05-03 11:07:56 +0200 |
commit | 0dab930314e215a627f848ffa824ed995eb2e13c (patch) | |
tree | f84189f12990561a616c65be59d8cb6ebef94569 /lib/stream.h | |
parent | 2005-04-29 Paul Jakma <paul.jakma@sun.com> (diff) | |
download | frr-0dab930314e215a627f848ffa824ed995eb2e13c.tar.xz frr-0dab930314e215a627f848ffa824ed995eb2e13c.zip |
2005-05-03 Paul Jakma <paul@dishone.st>
* stream.h: Add comment about the special zero-ing ability of
stream_put.
(stream_recvmsg, stream_write) should return ssize_t and size_t
respectively. Should both be extern linkage.
(stream_recvfrom) Stream aware wrapper around recvfrom, in style
of stream_read_try.
* stream.c: (stream_recvfrom) new function, wrapper around recvfrom.
(stream_recvmsg, stream_write) ssize_t and size_t return values
Diffstat (limited to 'lib/stream.h')
-rw-r--r-- | lib/stream.h | 15 |
1 files changed, 8 insertions, 7 deletions
diff --git a/lib/stream.h b/lib/stream.h index 1f6c3772b..7565fac84 100644 --- a/lib/stream.h +++ b/lib/stream.h @@ -86,10 +86,9 @@ * use stream_forward_endp() to effectively create arbitrary zero-fill * padding. However, note that stream_reset() does *not* zero-out the * stream. This property should **not** be relied upon. - * - * A Good stream user should ensure it writes all bytes. (the zero-fill - * guarantee may be removed in future, however, the zero-filling may - * possibly be moved to stream_forward_endp() instead, maybe..) + * + * Best practice is to use stream_put (<stream *>, NULL, <size>) to zero out + * any part of a stream which isn't otherwise written to. */ /* Stream buffer. */ @@ -143,7 +142,7 @@ void stream_set_getp (struct stream *, size_t); void stream_forward_getp (struct stream *, size_t); void stream_forward_endp (struct stream *, size_t); -void stream_put (struct stream *, void *, size_t); +void stream_put (struct stream *, void *, size_t); /* NULL source zeroes */ int stream_putc (struct stream *, u_char); int stream_putc_at (struct stream *, size_t, u_char); int stream_putw (struct stream *, u_int16_t); @@ -184,9 +183,11 @@ int stream_read_unblock (struct stream *, int, size_t); */ extern ssize_t stream_read_try(struct stream *s, int fd, size_t size); -int stream_recvmsg (struct stream *s, int fd, struct msghdr *, +extern ssize_t stream_recvmsg (struct stream *s, int fd, struct msghdr *, int flags, size_t size); -int stream_write (struct stream *, u_char *, size_t); +extern ssize_t stream_recvfrom (struct stream *s, int fd, size_t len, int flags, + struct sockaddr *from, socklen_t *fromlen); +size_t stream_write (struct stream *, u_char *, size_t); void stream_reset (struct stream *); /* reset the stream. See Note above */ int stream_flush (struct stream *, int); |