CLEANUP: channel: use 'chn' instead of 'buf' as local variable names
It's too confusing to see buf->buf everywhere where the first buf is
a channel. Let's fix this now.
diff --git a/include/proto/channel.h b/include/proto/channel.h
index 2f2a913..37f5457 100644
--- a/include/proto/channel.h
+++ b/include/proto/channel.h
@@ -39,27 +39,27 @@
/* perform minimal intializations, report 0 in case of error, 1 if OK. */
int init_channel();
-unsigned long long channel_forward(struct channel *buf, unsigned long long bytes);
+unsigned long long channel_forward(struct channel *chn, unsigned long long bytes);
/* SI-to-channel functions working with buffers */
-int bi_putblk(struct channel *buf, const char *str, int len);
-int bi_putchr(struct channel *buf, char c);
-int bo_inject(struct channel *buf, const char *msg, int len);
-int bo_getline(struct channel *buf, char *str, int len);
-int bo_getblk(struct channel *buf, char *blk, int len, int offset);
+int bi_putblk(struct channel *chn, const char *str, int len);
+int bi_putchr(struct channel *chn, char c);
+int bo_inject(struct channel *chn, const char *msg, int len);
+int bo_getline(struct channel *chn, char *str, int len);
+int bo_getblk(struct channel *chn, char *blk, int len, int offset);
/* Initialize all fields in the channel. */
-static inline void channel_init(struct channel *buf)
+static inline void channel_init(struct channel *chn)
{
- buf->buf.o = 0;
- buf->buf.i = 0;
- buf->buf.p = buf->buf.data;
- buf->to_forward = 0;
- buf->total = 0;
- buf->pipe = NULL;
- buf->analysers = 0;
- buf->cons = NULL;
- buf->flags = 0;
+ chn->buf.o = 0;
+ chn->buf.i = 0;
+ chn->buf.p = chn->buf.data;
+ chn->to_forward = 0;
+ chn->total = 0;
+ chn->pipe = NULL;
+ chn->analysers = 0;
+ chn->cons = NULL;
+ chn->flags = 0;
}
/*********************************************************************/
@@ -81,36 +81,36 @@
* close to happen. The test is optimized to avoid as many operations as
* possible for the fast case and to be used as an "if" condition.
*/
-static inline int channel_full(const struct channel *b)
+static inline int channel_full(const struct channel *chn)
{
- int rem = b->buf.size;
+ int rem = chn->buf.size;
- rem -= b->buf.o;
- rem -= b->buf.i;
+ rem -= chn->buf.o;
+ rem -= chn->buf.i;
if (!rem)
return 1; /* buffer already full */
- if (b->to_forward >= b->buf.size ||
- (CHN_INFINITE_FORWARD < MAX_RANGE(typeof(b->buf.size)) && // just there to ensure gcc
- b->to_forward == CHN_INFINITE_FORWARD)) // avoids the useless second
- return 0; // test whenever possible
+ if (chn->to_forward >= chn->buf.size ||
+ (CHN_INFINITE_FORWARD < MAX_RANGE(typeof(chn->buf.size)) && // just there to ensure gcc
+ chn->to_forward == CHN_INFINITE_FORWARD)) // avoids the useless second
+ return 0; // test whenever possible
rem -= global.tune.maxrewrite;
- rem += b->buf.o;
- rem += b->to_forward;
+ rem += chn->buf.o;
+ rem += chn->to_forward;
return rem <= 0;
}
/* Returns true if the channel's input is already closed */
-static inline int channel_input_closed(struct channel *buf)
+static inline int channel_input_closed(struct channel *chn)
{
- return ((buf->flags & CF_SHUTR) != 0);
+ return ((chn->flags & CF_SHUTR) != 0);
}
/* Returns true if the channel's output is already closed */
-static inline int channel_output_closed(struct channel *buf)
+static inline int channel_output_closed(struct channel *chn)
{
- return ((buf->flags & CF_SHUTW) != 0);
+ return ((chn->flags & CF_SHUTW) != 0);
}
/* Check channel timeouts, and set the corresponding flags. The likely/unlikely
@@ -118,50 +118,50 @@
* set if there was activity on the channel. That way, we don't have to update
* the timeout on every I/O. Note that the analyser timeout is always checked.
*/
-static inline void channel_check_timeouts(struct channel *b)
+static inline void channel_check_timeouts(struct channel *chn)
{
- if (likely(!(b->flags & (CF_SHUTR|CF_READ_TIMEOUT|CF_READ_ACTIVITY|CF_READ_NOEXP))) &&
- unlikely(tick_is_expired(b->rex, now_ms)))
- b->flags |= CF_READ_TIMEOUT;
+ if (likely(!(chn->flags & (CF_SHUTR|CF_READ_TIMEOUT|CF_READ_ACTIVITY|CF_READ_NOEXP))) &&
+ unlikely(tick_is_expired(chn->rex, now_ms)))
+ chn->flags |= CF_READ_TIMEOUT;
- if (likely(!(b->flags & (CF_SHUTW|CF_WRITE_TIMEOUT|CF_WRITE_ACTIVITY))) &&
- unlikely(tick_is_expired(b->wex, now_ms)))
- b->flags |= CF_WRITE_TIMEOUT;
+ if (likely(!(chn->flags & (CF_SHUTW|CF_WRITE_TIMEOUT|CF_WRITE_ACTIVITY))) &&
+ unlikely(tick_is_expired(chn->wex, now_ms)))
+ chn->flags |= CF_WRITE_TIMEOUT;
- if (likely(!(b->flags & CF_ANA_TIMEOUT)) &&
- unlikely(tick_is_expired(b->analyse_exp, now_ms)))
- b->flags |= CF_ANA_TIMEOUT;
+ if (likely(!(chn->flags & CF_ANA_TIMEOUT)) &&
+ unlikely(tick_is_expired(chn->analyse_exp, now_ms)))
+ chn->flags |= CF_ANA_TIMEOUT;
}
/* Erase any content from channel <buf> and adjusts flags accordingly. Note
* that any spliced data is not affected since we may not have any access to
* it.
*/
-static inline void channel_erase(struct channel *buf)
+static inline void channel_erase(struct channel *chn)
{
- buf->buf.o = 0;
- buf->buf.i = 0;
- buf->to_forward = 0;
- buf->buf.p = buf->buf.data;
+ chn->buf.o = 0;
+ chn->buf.i = 0;
+ chn->to_forward = 0;
+ chn->buf.p = chn->buf.data;
}
/* marks the channel as "shutdown" ASAP for reads */
-static inline void channel_shutr_now(struct channel *buf)
+static inline void channel_shutr_now(struct channel *chn)
{
- buf->flags |= CF_SHUTR_NOW;
+ chn->flags |= CF_SHUTR_NOW;
}
/* marks the channel as "shutdown" ASAP for writes */
-static inline void channel_shutw_now(struct channel *buf)
+static inline void channel_shutw_now(struct channel *chn)
{
- buf->flags |= CF_SHUTW_NOW;
+ chn->flags |= CF_SHUTW_NOW;
}
/* marks the channel as "shutdown" ASAP in both directions */
-static inline void channel_abort(struct channel *buf)
+static inline void channel_abort(struct channel *chn)
{
- buf->flags |= CF_SHUTR_NOW | CF_SHUTW_NOW;
- buf->flags &= ~CF_AUTO_CONNECT;
+ chn->flags |= CF_SHUTR_NOW | CF_SHUTW_NOW;
+ chn->flags &= ~CF_AUTO_CONNECT;
}
/* Installs <func> as a hijacker on the channel <b> for session <s>. The hijack
@@ -170,56 +170,56 @@
* during this first call.
*/
static inline void channel_install_hijacker(struct session *s,
- struct channel *b,
+ struct channel *chn,
void (*func)(struct session *, struct channel *))
{
- b->hijacker = func;
- b->flags |= CF_HIJACK;
- func(s, b);
+ chn->hijacker = func;
+ chn->flags |= CF_HIJACK;
+ func(s, chn);
}
/* Releases the channel from hijacking mode. Often used by the hijack function */
-static inline void channel_stop_hijacker(struct channel *buf)
+static inline void channel_stop_hijacker(struct channel *chn)
{
- buf->flags &= ~CF_HIJACK;
+ chn->flags &= ~CF_HIJACK;
}
/* allow the consumer to try to establish a new connection. */
-static inline void channel_auto_connect(struct channel *buf)
+static inline void channel_auto_connect(struct channel *chn)
{
- buf->flags |= CF_AUTO_CONNECT;
+ chn->flags |= CF_AUTO_CONNECT;
}
/* prevent the consumer from trying to establish a new connection, and also
* disable auto shutdown forwarding.
*/
-static inline void channel_dont_connect(struct channel *buf)
+static inline void channel_dont_connect(struct channel *chn)
{
- buf->flags &= ~(CF_AUTO_CONNECT|CF_AUTO_CLOSE);
+ chn->flags &= ~(CF_AUTO_CONNECT|CF_AUTO_CLOSE);
}
/* allow the producer to forward shutdown requests */
-static inline void channel_auto_close(struct channel *buf)
+static inline void channel_auto_close(struct channel *chn)
{
- buf->flags |= CF_AUTO_CLOSE;
+ chn->flags |= CF_AUTO_CLOSE;
}
/* prevent the producer from forwarding shutdown requests */
-static inline void channel_dont_close(struct channel *buf)
+static inline void channel_dont_close(struct channel *chn)
{
- buf->flags &= ~CF_AUTO_CLOSE;
+ chn->flags &= ~CF_AUTO_CLOSE;
}
/* allow the producer to read / poll the input */
-static inline void channel_auto_read(struct channel *buf)
+static inline void channel_auto_read(struct channel *chn)
{
- buf->flags &= ~CF_DONT_READ;
+ chn->flags &= ~CF_DONT_READ;
}
/* prevent the producer from read / poll the input */
-static inline void channel_dont_read(struct channel *buf)
+static inline void channel_dont_read(struct channel *chn)
{
- buf->flags |= CF_DONT_READ;
+ chn->flags |= CF_DONT_READ;
}
@@ -232,13 +232,13 @@
* buffer, which ensures that once all pending data are forwarded, the
* buffer still has global.tune.maxrewrite bytes free. The result is
* between 0 and global.tune.maxrewrite, which is itself smaller than
- * any buf->size.
+ * any chn->size.
*/
-static inline int buffer_reserved(const struct channel *buf)
+static inline int buffer_reserved(const struct channel *chn)
{
- int ret = global.tune.maxrewrite - buf->to_forward - buf->buf.o;
+ int ret = global.tune.maxrewrite - chn->to_forward - chn->buf.o;
- if (buf->to_forward == CHN_INFINITE_FORWARD)
+ if (chn->to_forward == CHN_INFINITE_FORWARD)
return 0;
if (ret <= 0)
return 0;
@@ -247,11 +247,11 @@
/* Return the max number of bytes the buffer can contain so that once all the
* pending bytes are forwarded, the buffer still has global.tune.maxrewrite
- * bytes free. The result sits between buf->size - maxrewrite and buf->size.
+ * bytes free. The result sits between chn->size - maxrewrite and chn->size.
*/
-static inline int buffer_max_len(const struct channel *buf)
+static inline int buffer_max_len(const struct channel *chn)
{
- return buf->buf.size - buffer_reserved(buf);
+ return chn->buf.size - buffer_reserved(chn);
}
/* Return the amount of bytes that can be written into the buffer at once,
@@ -267,24 +267,24 @@
* is close to happen. The test is optimized to avoid as many operations as
* possible for the fast case.
*/
-static inline int bi_avail(const struct channel *b)
+static inline int bi_avail(const struct channel *chn)
{
- int rem = b->buf.size;
+ int rem = chn->buf.size;
int rem2;
- rem -= b->buf.o;
- rem -= b->buf.i;
+ rem -= chn->buf.o;
+ rem -= chn->buf.i;
if (!rem)
return rem; /* buffer already full */
- if (b->to_forward >= b->buf.size ||
- (CHN_INFINITE_FORWARD < MAX_RANGE(typeof(b->buf.size)) && // just there to ensure gcc
- b->to_forward == CHN_INFINITE_FORWARD)) // avoids the useless second
- return rem; // test whenever possible
+ if (chn->to_forward >= chn->buf.size ||
+ (CHN_INFINITE_FORWARD < MAX_RANGE(typeof(chn->buf.size)) && // just there to ensure gcc
+ chn->to_forward == CHN_INFINITE_FORWARD)) // avoids the useless second
+ return rem; // test whenever possible
rem2 = rem - global.tune.maxrewrite;
- rem2 += b->buf.o;
- rem2 += b->to_forward;
+ rem2 += chn->buf.o;
+ rem2 += chn->to_forward;
if (rem > rem2)
rem = rem2;
@@ -298,16 +298,16 @@
* forwarding is stopped. This is mainly to be used to send error messages
* after existing data.
*/
-static inline void bi_erase(struct channel *buf)
+static inline void bi_erase(struct channel *chn)
{
- if (!buf->buf.o)
- return channel_erase(buf);
+ if (!chn->buf.o)
+ return channel_erase(chn);
- buf->to_forward = 0;
- if (!buf->buf.i)
+ chn->to_forward = 0;
+ if (!chn->buf.i)
return;
- buf->buf.i = 0;
+ chn->buf.i = 0;
}
/*
@@ -315,48 +315,48 @@
* when data have been read directly from the buffer. It is illegal to call
* this function with <len> causing a wrapping at the end of the buffer. It's
* the caller's responsibility to ensure that <len> is never larger than
- * buf->o. Channel flag WRITE_PARTIAL is set.
+ * chn->o. Channel flag WRITE_PARTIAL is set.
*/
-static inline void bo_skip(struct channel *buf, int len)
+static inline void bo_skip(struct channel *chn, int len)
{
- buf->buf.o -= len;
+ chn->buf.o -= len;
- if (buffer_len(&buf->buf) == 0)
- buf->buf.p = buf->buf.data;
+ if (buffer_len(&chn->buf) == 0)
+ chn->buf.p = chn->buf.data;
/* notify that some data was written to the SI from the buffer */
- buf->flags |= CF_WRITE_PARTIAL;
+ chn->flags |= CF_WRITE_PARTIAL;
}
/* Tries to copy chunk <chunk> into the channel's buffer after length controls.
- * The buf->o and to_forward pointers are updated. If the channel's input is
+ * The chn->o and to_forward pointers are updated. If the channel's input is
* closed, -2 is returned. If the block is too large for this buffer, -3 is
* returned. If there is not enough room left in the buffer, -1 is returned.
* Otherwise the number of bytes copied is returned (0 being a valid number).
* Channel flag READ_PARTIAL is updated if some data can be transferred. The
* chunk's length is updated with the number of bytes sent.
*/
-static inline int bi_putchk(struct channel *buf, struct chunk *chunk)
+static inline int bi_putchk(struct channel *chn, struct chunk *chunk)
{
int ret;
- ret = bi_putblk(buf, chunk->str, chunk->len);
+ ret = bi_putblk(chn, chunk->str, chunk->len);
if (ret > 0)
chunk->len -= ret;
return ret;
}
/* Tries to copy string <str> at once into the channel's buffer after length
- * controls. The buf->o and to_forward pointers are updated. If the channel's
+ * controls. The chn->o and to_forward pointers are updated. If the channel's
* input is closed, -2 is returned. If the block is too large for this buffer,
* -3 is returned. If there is not enough room left in the buffer, -1 is
* returned. Otherwise the number of bytes copied is returned (0 being a valid
* number). Channel flag READ_PARTIAL is updated if some data can be
* transferred.
*/
-static inline int bi_putstr(struct channel *buf, const char *str)
+static inline int bi_putstr(struct channel *chn, const char *str)
{
- return bi_putblk(buf, str, strlen(str));
+ return bi_putblk(chn, str, strlen(str));
}
/*
@@ -364,17 +364,17 @@
* channel is closed, return -2. If the buffer is just empty, return -1. The
* buffer's pointer is not advanced, it's up to the caller to call bo_skip(buf,
* 1) when it has consumed the char. Also note that this function respects the
- * buf->o limit.
+ * chn->o limit.
*/
-static inline int bo_getchr(struct channel *buf)
+static inline int bo_getchr(struct channel *chn)
{
/* closed or empty + imminent close = -2; empty = -1 */
- if (unlikely((buf->flags & CF_SHUTW) || channel_is_empty(buf))) {
- if (buf->flags & (CF_SHUTW|CF_SHUTW_NOW))
+ if (unlikely((chn->flags & CF_SHUTW) || channel_is_empty(chn))) {
+ if (chn->flags & (CF_SHUTW|CF_SHUTW_NOW))
return -2;
return -1;
}
- return *buffer_wrap_sub(&buf->buf, buf->buf.p - buf->buf.o);
+ return *buffer_wrap_sub(&chn->buf, chn->buf.p - chn->buf.o);
}
diff --git a/src/channel.c b/src/channel.c
index 65fe665..7b0d44e 100644
--- a/src/channel.c
+++ b/src/channel.c
@@ -40,7 +40,7 @@
* into account is returned. Directly touching ->to_forward will cause lockups
* when buf->o goes down to zero if nobody is ready to push the remaining data.
*/
-unsigned long long channel_forward(struct channel *buf, unsigned long long bytes)
+unsigned long long channel_forward(struct channel *chn, unsigned long long bytes)
{
unsigned int new_forward;
unsigned int forwarded;
@@ -53,40 +53,40 @@
* once anyway.
*/
if (bytes <= ~0U) {
- if (bytes32 <= buf->buf.i) {
+ if (bytes32 <= chn->buf.i) {
/* OK this amount of bytes might be forwarded at once */
if (!bytes32)
return 0;
- b_adv(&buf->buf, bytes32);
+ b_adv(&chn->buf, bytes32);
return bytes;
}
}
- forwarded = buf->buf.i;
- b_adv(&buf->buf, buf->buf.i);
+ forwarded = chn->buf.i;
+ b_adv(&chn->buf, chn->buf.i);
/* Note: the case below is the only case where we may return
* a byte count that does not fit into a 32-bit number.
*/
- if (likely(buf->to_forward == CHN_INFINITE_FORWARD))
+ if (likely(chn->to_forward == CHN_INFINITE_FORWARD))
return bytes;
if (likely(bytes == CHN_INFINITE_FORWARD)) {
- buf->to_forward = bytes;
+ chn->to_forward = bytes;
return bytes;
}
- new_forward = buf->to_forward + bytes - forwarded;
+ new_forward = chn->to_forward + bytes - forwarded;
bytes = forwarded; /* at least those bytes were scheduled */
- if (new_forward <= buf->to_forward) {
+ if (new_forward <= chn->to_forward) {
/* integer overflow detected, let's assume no more than 2G at once */
new_forward = MID_RANGE(new_forward);
}
- if (new_forward > buf->to_forward) {
- bytes += new_forward - buf->to_forward;
- buf->to_forward = new_forward;
+ if (new_forward > chn->to_forward) {
+ bytes += new_forward - chn->to_forward;
+ chn->to_forward = new_forward;
}
return bytes;
}
@@ -98,14 +98,14 @@
* data. Note: this function appends data to the buffer's output and possibly
* overwrites any pending input data which are assumed not to exist.
*/
-int bo_inject(struct channel *buf, const char *msg, int len)
+int bo_inject(struct channel *chn, const char *msg, int len)
{
int max;
if (len == 0)
return -1;
- if (len > buf->buf.size) {
+ if (len > chn->buf.size) {
/* we can't write this chunk and will never be able to, because
* it is larger than the buffer. This must be reported as an
* error. Then we return -2 so that writers that don't care can
@@ -114,64 +114,64 @@
return -2;
}
- max = buffer_realign(&buf->buf);
+ max = buffer_realign(&chn->buf);
if (len > max)
return max;
- memcpy(buf->buf.p, msg, len);
- buf->buf.o += len;
- buf->buf.p = b_ptr(&buf->buf, len);
- buf->total += len;
+ memcpy(chn->buf.p, msg, len);
+ chn->buf.o += len;
+ chn->buf.p = b_ptr(&chn->buf, len);
+ chn->total += len;
return -1;
}
/* Tries to copy character <c> into the channel's buffer after some length
- * controls. The buf->o and to_forward pointers are updated. If the channel
+ * controls. The chn->o and to_forward pointers are updated. If the channel
* input is closed, -2 is returned. If there is not enough room left in the
* buffer, -1 is returned. Otherwise the number of bytes copied is returned
* (1). Channel flag READ_PARTIAL is updated if some data can be transferred.
*/
-int bi_putchr(struct channel *buf, char c)
+int bi_putchr(struct channel *chn, char c)
{
- if (unlikely(channel_input_closed(buf)))
+ if (unlikely(channel_input_closed(chn)))
return -2;
- if (channel_full(buf))
+ if (channel_full(chn))
return -1;
- *bi_end(&buf->buf) = c;
+ *bi_end(&chn->buf) = c;
- buf->buf.i++;
- buf->flags |= CF_READ_PARTIAL;
+ chn->buf.i++;
+ chn->flags |= CF_READ_PARTIAL;
- if (buf->to_forward >= 1) {
- if (buf->to_forward != CHN_INFINITE_FORWARD)
- buf->to_forward--;
- b_adv(&buf->buf, 1);
+ if (chn->to_forward >= 1) {
+ if (chn->to_forward != CHN_INFINITE_FORWARD)
+ chn->to_forward--;
+ b_adv(&chn->buf, 1);
}
- buf->total++;
+ chn->total++;
return 1;
}
/* Tries to copy block <blk> at once into the channel's buffer after length
- * controls. The buf->o and to_forward pointers are updated. If the channel
+ * controls. The chn->o and to_forward pointers are updated. If the channel
* input is closed, -2 is returned. If the block is too large for this buffer,
* -3 is returned. If there is not enough room left in the buffer, -1 is
* returned. Otherwise the number of bytes copied is returned (0 being a valid
* number). Channel flag READ_PARTIAL is updated if some data can be
* transferred.
*/
-int bi_putblk(struct channel *buf, const char *blk, int len)
+int bi_putblk(struct channel *chn, const char *blk, int len)
{
int max;
- if (unlikely(channel_input_closed(buf)))
+ if (unlikely(channel_input_closed(chn)))
return -2;
- max = buffer_max_len(buf);
- if (unlikely(len > max - buffer_len(&buf->buf))) {
+ max = buffer_max_len(chn);
+ if (unlikely(len > max - buffer_len(&chn->buf))) {
/* we can't write this chunk right now because the buffer is
* almost full or because the block is too large. Return the
* available space or -2 if impossible.
@@ -186,25 +186,25 @@
return 0;
/* OK so the data fits in the buffer in one or two blocks */
- max = buffer_contig_space_with_res(&buf->buf, buf->buf.size - max);
- memcpy(bi_end(&buf->buf), blk, MIN(len, max));
+ max = buffer_contig_space_with_res(&chn->buf, chn->buf.size - max);
+ memcpy(bi_end(&chn->buf), blk, MIN(len, max));
if (len > max)
- memcpy(buf->buf.data, blk + max, len - max);
+ memcpy(chn->buf.data, blk + max, len - max);
- buf->buf.i += len;
- buf->total += len;
- if (buf->to_forward) {
+ chn->buf.i += len;
+ chn->total += len;
+ if (chn->to_forward) {
unsigned long fwd = len;
- if (buf->to_forward != CHN_INFINITE_FORWARD) {
- if (fwd > buf->to_forward)
- fwd = buf->to_forward;
- buf->to_forward -= fwd;
+ if (chn->to_forward != CHN_INFINITE_FORWARD) {
+ if (fwd > chn->to_forward)
+ fwd = chn->to_forward;
+ chn->to_forward -= fwd;
}
- b_adv(&buf->buf, fwd);
+ b_adv(&chn->buf, fwd);
}
/* notify that some data was read from the SI into the buffer */
- buf->flags |= CF_READ_PARTIAL;
+ chn->flags |= CF_READ_PARTIAL;
return len;
}
@@ -218,7 +218,7 @@
* output are full. If either of them is full, the string may be returned
* as is, without the '\n'.
*/
-int bo_getline(struct channel *buf, char *str, int len)
+int bo_getline(struct channel *chn, char *str, int len)
{
int ret, max;
char *p;
@@ -227,16 +227,16 @@
max = len;
/* closed or empty + imminent close = -1; empty = 0 */
- if (unlikely((buf->flags & CF_SHUTW) || channel_is_empty(buf))) {
- if (buf->flags & (CF_SHUTW|CF_SHUTW_NOW))
+ if (unlikely((chn->flags & CF_SHUTW) || channel_is_empty(chn))) {
+ if (chn->flags & (CF_SHUTW|CF_SHUTW_NOW))
ret = -1;
goto out;
}
- p = bo_ptr(&buf->buf);
+ p = bo_ptr(&chn->buf);
- if (max > buf->buf.o) {
- max = buf->buf.o;
+ if (max > chn->buf.o) {
+ max = chn->buf.o;
str[max-1] = 0;
}
while (max) {
@@ -246,11 +246,11 @@
if (*p == '\n')
break;
- p = buffer_wrap_add(&buf->buf, p + 1);
+ p = buffer_wrap_add(&chn->buf, p + 1);
}
- if (ret > 0 && ret < len && ret < buf->buf.o &&
+ if (ret > 0 && ret < len && ret < chn->buf.o &&
*(str-1) != '\n' &&
- !(buf->flags & (CF_SHUTW|CF_SHUTW_NOW)))
+ !(chn->flags & (CF_SHUTW|CF_SHUTW_NOW)))
ret = 0;
out:
if (max)
@@ -266,32 +266,32 @@
* The channel status is not changed. The caller must call bo_skip() to
* update it.
*/
-int bo_getblk(struct channel *buf, char *blk, int len, int offset)
+int bo_getblk(struct channel *chn, char *blk, int len, int offset)
{
int firstblock;
- if (buf->flags & CF_SHUTW)
+ if (chn->flags & CF_SHUTW)
return -1;
- if (len + offset > buf->buf.o) {
- if (buf->flags & (CF_SHUTW|CF_SHUTW_NOW))
+ if (len + offset > chn->buf.o) {
+ if (chn->flags & (CF_SHUTW|CF_SHUTW_NOW))
return -1;
return 0;
}
- firstblock = buf->buf.data + buf->buf.size - bo_ptr(&buf->buf);
+ firstblock = chn->buf.data + chn->buf.size - bo_ptr(&chn->buf);
if (firstblock > offset) {
if (firstblock >= len + offset) {
- memcpy(blk, bo_ptr(&buf->buf) + offset, len);
+ memcpy(blk, bo_ptr(&chn->buf) + offset, len);
return len;
}
- memcpy(blk, bo_ptr(&buf->buf) + offset, firstblock - offset);
- memcpy(blk + firstblock - offset, buf->buf.data, len - firstblock + offset);
+ memcpy(blk, bo_ptr(&chn->buf) + offset, firstblock - offset);
+ memcpy(blk + firstblock - offset, chn->buf.data, len - firstblock + offset);
return len;
}
- memcpy(blk, buf->buf.data + offset - firstblock, len);
+ memcpy(blk, chn->buf.data + offset - firstblock, len);
return len;
}