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
|
/*
buffer.c - functions for handling buffers
Copyright (C) 2002 Arthur de Jong
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2, or (at your option)
any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software Foundation,
Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
#ifndef _BUFFER_H
#define _BUFFER_H 1
/* structure for holding a string */
struct buffer
{
char *buf; /* pointer to allocated memory */
int alloc; /* size of allocated memory */
int len; /* amount of memory in use */
};
/* intialize struct buffer and allocate memory for it */
void buffer_init(struct buffer *line,int alloc);
/* change the size of the line */
void buffer_grow(struct buffer *line,int alloc);
/* free allocated memory */
void buffer_free(struct buffer *line);
/* make a copy of the sc line into dst line
optionaly growing of allocationg dst
the orriginal content of dst is lost and a pointer
to the result (dst or a new line if dst==NULL) */
struct buffer *buffer_copy(struct buffer *dst,struct buffer *src);
/* read a single line from the file
this function returns a struct buffer structure containing
the read line with newline or NULL on EOF
lines are delimited by the delim char */
struct buffer *buffer_readline(FILE *in,struct buffer *line,char delim);
/* read a complete file into a buffer */
struct buffer *buffer_readfile(FILE *in,struct buffer *buf);
#endif /* _BUFFER_H */
|