From 10760e447f95a4b6dbeaae90456a7e9efd0a796c Mon Sep 17 00:00:00 2001 From: Hiltjo Posthuma Date: Sun, 21 Jun 2015 00:19:22 +0200 Subject: add xbasename for filename to feedname --- util.c | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/util.c b/util.c index 8e41a15..df0a114 100644 --- a/util.c +++ b/util.c @@ -1,6 +1,7 @@ #include #include #include +#include #include #include #include @@ -203,3 +204,24 @@ printcontent(const char *s, FILE *fp) } } } + +/* Some implementations of basename(3) return a pointer to a static + * internal buffer (OpenBSD). Others modify the contents of `path` (POSIX). + * This is a wrapper function that is compatible with both versions. + * The program will error out if basename(3) failed, this can only happen + * with the OpenBSD version. + */ +char * +xbasename(const char *path) +{ + char *p, *b; + + if(!(p = strdup(path))) + err(1, "strdup"); + if(!(b = basename(p))) + err(1, "basename"); + if(!(b = strdup(b))) + err(1, "strdup"); + free(p); + return b; +} -- cgit v1.2.3