X-Git-Url: http://git.marmaro.de/?p=mmh;a=blobdiff_plain;f=sbr%2Futils.c;h=8741b2086f7a023f01b1910d3ff451625b1bed2d;hp=7dfe900b6cdc674ddad9e54169b559042f772da2;hb=9a33ff618b5901a3af815650d4b84d39ee96e529;hpb=008837e090c008e3afe7a9c8667070bafa091e62 diff --git a/sbr/utils.c b/sbr/utils.c index 7dfe900..8741b20 100644 --- a/sbr/utils.c +++ b/sbr/utils.c @@ -9,10 +9,13 @@ * complete copyright information. */ -#include +#include #include #include +/* + * Safely call malloc + */ void * mh_xmalloc(size_t size) { @@ -28,6 +31,9 @@ mh_xmalloc(size_t size) return memory; } +/* + * Safely call realloc + */ void * mh_xrealloc(void *ptr, size_t size) { @@ -42,3 +48,66 @@ mh_xrealloc(void *ptr, size_t size) return memory; } + +/* + * Return the present working directory, if the current directory does not + * exist, or is too long, make / the pwd. + */ +char * +pwd(void) +{ + register char *cp; + static char curwd[PATH_MAX]; + + if (!getcwd (curwd, PATH_MAX)) { + admonish (NULL, "unable to determine working directory"); + if (!mypath || !*mypath + || (strcpy (curwd, mypath), chdir (curwd)) == -1) { + strcpy (curwd, "/"); + chdir (curwd); + } + return curwd; + } + + if ((cp = curwd + strlen (curwd) - 1) > curwd && *cp == '/') + *cp = '\0'; + + return curwd; +} + +/* + * add -- If "s1" is NULL, this routine just creates a + * -- copy of "s2" into newly malloc'ed memory. + * -- + * -- If "s1" is not NULL, then copy the concatenation + * -- of "s1" and "s2" (note the order) into newly + * -- malloc'ed memory. Then free "s1". + */ +char * +add (char *s2, char *s1) +{ + char *cp; + size_t len1 = 0, len2 = 0; + + if (s1) + len1 = strlen (s1); + if (s2) + len2 = strlen (s2); + + cp = mh_xmalloc (len1 + len2 + 1); + + /* Copy s1 and free it */ + if (s1) { + memcpy (cp, s1, len1); + free (s1); + } + + /* Copy s2 */ + if (s2) + memcpy (cp + len1, s2, len2); + + /* Now NULL terminate the string */ + cp[len1 + len2] = '\0'; + + return cp; +}