X-Git-Url: http://git.marmaro.de/?p=mmh;a=blobdiff_plain;f=sbr%2Futils.c;h=8aba5b6ad63036e45e6cfbc0bd69e47fe2c937eb;hp=c433e8f0fe72230d74d66a66bb9c5043e43cb9a6;hb=174d375bb4b9bcaa0c3f28c422216f68703494a8;hpb=0be3869967792be6b129fc34e8f72a88fc3352bb diff --git a/sbr/utils.c b/sbr/utils.c index c433e8f..8aba5b6 100644 --- a/sbr/utils.c +++ b/sbr/utils.c @@ -15,6 +15,12 @@ #include /* + * We allocate space for messages (msgs array) + * this number of elements at a time. + */ +#define MAXMSGS 256 + +/* * Safely call malloc */ void * @@ -165,3 +171,16 @@ num_digits (int n) return ndigits; } + +/* + * Append a message arg to an array of them, resizing it if necessary. + * The function is written to suit the arg parsing code it was extracted + * from, and will probably be changed when the other code is cleaned up. + */ +void +app_msgarg(struct msgs_array *msgs, char *cp) +{ + if(msgs->size >= msgs->max) + msgs->msgs = mh_xrealloc(msgs->msgs, (msgs->max+=MAXMSGS)*sizeof(*msgs->msgs)); + msgs->msgs[msgs->size++] = cp; +}