Browse Source

vcs-svn: replace buffer_read_string memory pool with a strbuf

obj_pool is inherently global and does not use the standard growing
factor alloc_nr, which makes it feel out of place in the git codebase.
Plus it is overkill for this application: all that is needed is a
buffer that can grow between requests to accomodate larger strings.
Use a strbuf instead.

As a side effect, this improves the error handling: allocation
failures will result in a clean exit instead of segfaults.  It would
be nice to add a test case (using ulimit or failmalloc) but that can
wait for another day.

Signed-off-by: Jonathan Nieder <jrnieder@gmail.com>
maint
Jonathan Nieder 14 years ago
parent
commit
deadcef4c1
  1. 16
      vcs-svn/line_buffer.c

16
vcs-svn/line_buffer.c

@ -5,15 +5,13 @@


#include "git-compat-util.h" #include "git-compat-util.h"
#include "line_buffer.h" #include "line_buffer.h"
#include "obj_pool.h" #include "strbuf.h"


#define LINE_BUFFER_LEN 10000 #define LINE_BUFFER_LEN 10000
#define COPY_BUFFER_LEN 4096 #define COPY_BUFFER_LEN 4096


/* Create memory pool for char sequence of known length */
obj_pool_gen(blob, char, 4096)

static char line_buffer[LINE_BUFFER_LEN]; static char line_buffer[LINE_BUFFER_LEN];
static struct strbuf blob_buffer = STRBUF_INIT;
static FILE *infile; static FILE *infile;


int buffer_init(const char *filename) int buffer_init(const char *filename)
@ -58,11 +56,9 @@ char *buffer_read_line(void)


char *buffer_read_string(uint32_t len) char *buffer_read_string(uint32_t len)
{ {
char *s; strbuf_reset(&blob_buffer);
blob_free(blob_pool.size); strbuf_fread(&blob_buffer, len, infile);
s = blob_pointer(blob_alloc(len + 1)); return ferror(infile) ? NULL : blob_buffer.buf;
s[fread(s, 1, len, infile)] = '\0';
return ferror(infile) ? NULL : s;
} }


void buffer_copy_bytes(uint32_t len) void buffer_copy_bytes(uint32_t len)
@ -94,5 +90,5 @@ void buffer_skip_bytes(uint32_t len)


void buffer_reset(void) void buffer_reset(void)
{ {
blob_reset(); strbuf_release(&blob_buffer);
} }

Loading…
Cancel
Save