diff options
author | Ray Lai <ray@cvs.openbsd.org> | 2006-04-11 00:49:50 +0000 |
---|---|---|
committer | Ray Lai <ray@cvs.openbsd.org> | 2006-04-11 00:49:50 +0000 |
commit | 6748bf3f1d552fd22e660a6d3ca52d46f0f87f84 (patch) | |
tree | 44018a7f0eeb4b101f7a33238435f595c66e11df | |
parent | f31c615d3f4c26fc619a5f39173d58e424d349de (diff) |
Change cvs_buf_grow() to return void, since it cannot fail, and
just use xrealloc, since it handles the case of an unallocated
buffer anyway. (b->cb_buf should be NULL if the space is unallocated.)
``Tested & looks OK to'' niallo@.
-rw-r--r-- | usr.bin/cvs/buf.c | 30 |
1 files changed, 11 insertions, 19 deletions
diff --git a/usr.bin/cvs/buf.c b/usr.bin/cvs/buf.c index e6734ddc567..3b40e7069a4 100644 --- a/usr.bin/cvs/buf.c +++ b/usr.bin/cvs/buf.c @@ -1,4 +1,4 @@ -/* $OpenBSD: buf.c,v 1.45 2006/04/10 19:49:44 joris Exp $ */ +/* $OpenBSD: buf.c,v 1.46 2006/04/11 00:49:49 ray Exp $ */ /* * Copyright (c) 2003 Jean-Francois Brousseau <jfb@openbsd.org> * All rights reserved. @@ -48,7 +48,7 @@ struct cvs_buf { #define SIZE_LEFT(b) (b->cb_size - (size_t)(b->cb_cur - b->cb_buf) \ - b->cb_len) -static ssize_t cvs_buf_grow(BUF *, size_t); +static void cvs_buf_grow(BUF *, size_t); /* * cvs_buf_alloc() @@ -177,9 +177,8 @@ cvs_buf_set(BUF *b, const void *src, size_t len, size_t off) size_t rlen = 0; if (b->cb_size < (len + off)) { - if ((b->cb_flags & BUF_AUTOEXT) && - (cvs_buf_grow(b, len + off - b->cb_size) < 0)) - fatal("cvs_buf_set failed"); + if ((b->cb_flags & BUF_AUTOEXT)) + cvs_buf_grow(b, len + off - b->cb_size); else rlen = b->cb_size - off; } else @@ -208,8 +207,9 @@ cvs_buf_putc(BUF *b, int c) bp = b->cb_cur + b->cb_len; if (bp == (b->cb_buf + b->cb_size)) { /* extend */ - if (!(b->cb_flags & BUF_AUTOEXT) || - (cvs_buf_grow(b, (size_t)BUF_INCR) < 0)) + if (b->cb_flags & BUF_AUTOEXT) + cvs_buf_grow(b, (size_t)BUF_INCR); + else fatal("cvs_buf_putc failed"); /* the buffer might have been moved */ @@ -253,8 +253,7 @@ cvs_buf_append(BUF *b, const void *data, size_t len) if (left < len) { if (b->cb_flags & BUF_AUTOEXT) { - if (cvs_buf_grow(b, len - left) < 0) - fatal("cvs_buf_append failed"); + cvs_buf_grow(b, len - left); bp = b->cb_cur + b->cb_len; } else rlen = bep - bp; @@ -397,27 +396,20 @@ cvs_buf_write_stmp(BUF *b, char *template, mode_t mode) * * Grow the buffer <b> by <len> bytes. The contents are unchanged by this * operation regardless of the result. - * Returns the new size on success, or -1 on failure. */ -static ssize_t +static void cvs_buf_grow(BUF *b, size_t len) { void *tmp; size_t diff; diff = b->cb_cur - b->cb_buf; - /* Buffer not allocated yet */ - if (b->cb_size == 0) - tmp = xmalloc(len); - else - tmp = xrealloc(b->cb_buf, 1, b->cb_size + len); - b->cb_buf = (u_char *)tmp; + tmp = xrealloc(b->cb_buf, 1, b->cb_size + len); + b->cb_buf = tmp; b->cb_size += len; /* readjust pointers in case the buffer moved in memory */ b->cb_cur = b->cb_buf + diff; - - return (ssize_t)b->cb_size; } #if !defined(RCSPROG) |