X-Git-Url: http://git.marmaro.de/?a=blobdiff_plain;f=sbr%2Futils.c;h=64df443b22455688012af8890d7190d104783515;hb=b439ec143c4d2e2daf4b0a9c332123f24500cd9a;hp=c433e8f0fe72230d74d66a66bb9c5043e43cb9a6;hpb=0cebd8284370988c8b1807ef2544bd80804d074e;p=mmh diff --git a/sbr/utils.c b/sbr/utils.c index c433e8f..64df443 100644 --- a/sbr/utils.c +++ b/sbr/utils.c @@ -12,9 +12,16 @@ #include #include #include +#include #include /* + * We allocate space for messages (msgs array) + * this number of elements at a time. + */ +#define MAXMSGS 256 + +/* * Safely call malloc */ void * @@ -165,3 +172,32 @@ 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; +} + +/* Open a form or components file */ +int +open_form(char **form, char *def) +{ + int in; + if (*form) { + if ((in = open (etcpath (*form), O_RDONLY)) == NOTOK) + adios (*form, "unable to open form file"); + } else { + if ((in = open (etcpath (def), O_RDONLY)) == NOTOK) + adios (def, "unable to open default components file"); + *form = def; + } + return in; +}