Mercurial > noffle
diff src/dynamicstring.c @ 43:2842f50feb55 noffle
[svn] * client.c, client.h, common.h, config.c, config.h, content.c, content.h,
control.c, control.h, database.c, database.h, dynamicstring.c,
dynamicstring.h, fetch.c, fetch.h, fetchlist.c, fetchlist.h, group.c,
group.h, itemlist.c, itemlist.h, lock.c, lock.h, log.c, log.h, noffle.c,
online.c, online.h, outgoing.c, outgoing.h, over.c, over.h, post.c, post.h,
protocol.c, protocol.h, pseudo.c, pseudo.h, request.c, request.h, server.c,
server.h, util.c, util.h, wildmat.c, wildmat.h: Moved files to the
subdirectory src/
* Makefile.am, acconfig.h, configure.in, docs/Makefile.am, src/Makefile.am,
Makefile.in, aclocal.m4, config.h.in, configure, install-sh, missing,
mkinstalldirs, stamp-h.in, docs/Makefile.in, src/Makefile.in: Added files.
They are used by aclocal, autoheader, autoconf and automake.
* src/config.c, src/config.h: Renamed to configfile.c and configfile.h,
because configure will generate a config.h file itself.
* src/client.c, src/content.c, src/database.c, src/fetch.c, src/fetchlist.c,
src/group.c, src/lock.c, src/noffle.c, src/online.c, src/outgoing.c,
src/over.c, src/pseudo.c, src/request.c, src/server.c, src/util.c:
Changed '#include "config.h"' to '#include "configfile.h"'.
* src/client.c, src/content.c, src/database.c, src/fetch.c, src/fetchlist.c,
src/group.c, src/lock.c, src/online.c, src/outgoing.c, src/post.c,
src/protocol.c, src/request.c, src/server.c: Files now #include <config.h>.
Added missing <stdio.h>. This removes the warnings about snprintf() not
being declared.
* Makefile: Removed. This is now generated by configure.
author | uh1763 |
---|---|
date | Fri, 05 May 2000 22:45:56 +0100 |
parents | |
children | 32ba1198c6fa |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/dynamicstring.c Fri May 05 22:45:56 2000 +0100 @@ -0,0 +1,120 @@ +/* + dynamicstring.c + + $Id: dynamicstring.c 49 2000-05-05 21:45:56Z uh1763 $ +*/ + +#include "dynamicstring.h" + +#include <sys/types.h> +#include "log.h" + +struct DynStr +{ + size_t len; /* Current length (without trailing '\0') */ + size_t max; /* Max length that fits into buffer (incl. trailing '\0') */ + char *str; +}; + +static void +reallocStr( DynStr *self, size_t max ) +{ + if ( max <= self->max ) + return; + if ( ! ( self->str = (char *)realloc( self->str, max ) ) ) + { + Log_err( "Realloc of DynStr failed" ); + exit( EXIT_FAILURE ); + } + if ( self->max == 0 ) /* First allocation? */ + *(self->str) = '\0'; + self->max = max; +} + +DynStr * +new_DynStr( size_t reserve ) +{ + DynStr *s; + + if ( ! ( s = (DynStr *) malloc( sizeof( DynStr ) ) ) ) + { + Log_err( "Allocation of DynStr failed" ); + exit( EXIT_FAILURE ); + } + s->len = 0; + s->max = 0; + s->str = NULL; + if ( reserve > 0 ) + reallocStr( s, reserve + 1 ); + return s; +} + +void +del_DynStr( DynStr *self ) +{ + if ( ! self ) + return; + free( self->str ); + self->str = NULL; + free( self ); +} + +size_t +DynStr_len( const DynStr *self ) +{ + return self->len; +} + +const char * +DynStr_str( const DynStr *self ) +{ + return self->str; +} + +void +DynStr_app( DynStr *self, const char *s ) +{ + size_t len; + + len = strlen( s ); + if ( self->len + len + 1 > self->max ) + reallocStr( self, self->len * 2 + len + 1 ); + strcpy( self->str + self->len, s ); + self->len += len; +} + +void +DynStr_appDynStr( DynStr *self, const DynStr *s ) +{ + if ( self->len + s->len + 1 > self->max ) + reallocStr( self, self->len * 2 + s->len + 1 ); + memcpy( self->str + self->len, s->str, s->len + 1 ); + self->len += s->len; +} + +void +DynStr_appLn( DynStr *self, const char *s ) +{ + DynStr_app( self, s ); + DynStr_app( self, "\n" ); +} + +void +DynStr_appN( DynStr *self, const char *s, size_t n ) +{ + size_t len = self->len; + + if ( len + n + 1 > self->max ) + reallocStr( self, len * 2 + n + 1 ); + strncat( self->str + len, s, n ); + self->len = len + strlen( self->str + len ); +} + +void +DynStr_clear( DynStr *self ) +{ + self->len = 0; + if ( self->max > 0 ) + *(self->str) = '\0'; +} +