Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/lib/libc/gen Factor out the basename and dirname code into b...
details: https://anonhg.NetBSD.org/src/rev/9c8c658e53d2
branches: trunk
changeset: 330590:9c8c658e53d2
user: christos <christos%NetBSD.org@localhost>
date: Mon Jul 14 20:44:45 2014 +0000
description:
Factor out the basename and dirname code into basename_r and dirname_r
which are static for now. Inspired by similar changes to android(bionic).
diffstat:
lib/libc/gen/basename.c | 64 ++++++++++++++++++++++++--------------
lib/libc/gen/dirname.c | 79 ++++++++++++++++++++++++++----------------------
2 files changed, 83 insertions(+), 60 deletions(-)
diffs (218 lines):
diff -r b4c6d269b8e1 -r 9c8c658e53d2 lib/libc/gen/basename.c
--- a/lib/libc/gen/basename.c Mon Jul 14 20:20:31 2014 +0000
+++ b/lib/libc/gen/basename.c Mon Jul 14 20:44:45 2014 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: basename.c,v 1.9 2009/11/24 13:34:20 tnozaki Exp $ */
+/* $NetBSD: basename.c,v 1.10 2014/07/14 20:44:45 christos Exp $ */
/*-
* Copyright (c) 1997, 2002 The NetBSD Foundation, Inc.
@@ -31,11 +31,13 @@
#include <sys/cdefs.h>
#if defined(LIBC_SCCS) && !defined(lint)
-__RCSID("$NetBSD: basename.c,v 1.9 2009/11/24 13:34:20 tnozaki Exp $");
+__RCSID("$NetBSD: basename.c,v 1.10 2014/07/14 20:44:45 christos Exp $");
#endif /* !LIBC_SCCS && !lint */
#include "namespace.h"
+#include <sys/param.h>
#include <libgen.h>
+#include <string.h>
#include <limits.h>
#include <string.h>
@@ -43,43 +45,57 @@
__weak_alias(basename,_basename)
#endif
-#if !HAVE_BASENAME
-char *
-basename(char *path)
+static size_t
+basename_r(const char *path, char *buf, size_t buflen)
{
- static char result[PATH_MAX];
- const char *p, *lastp;
+ const char *startp, *endp;
size_t len;
/*
* If `path' is a null pointer or points to an empty string,
* return a pointer to the string ".".
*/
- if ((path == NULL) || (*path == '\0')) {
- result[0] = '.';
- result[1] = '\0';
-
- return (result);
+ if (path == NULL || *path == '\0') {
+ startp = ".";
+ len = 1;
+ goto out;
}
/* Strip trailing slashes, if any. */
- lastp = path + strlen(path) - 1;
- while (lastp != path && *lastp == '/')
- lastp--;
+ endp = path + strlen(path) - 1;
+ while (endp != path && *endp == '/')
+ endp--;
+
+ /* Only slashes -> "/" */
+ if (endp == path && *endp == '/') {
+ startp = "/";
+ len = 1;
+ goto out;
+ }
/* Now find the beginning of this (final) component. */
- p = lastp;
- while (p != path && *(p - 1) != '/')
- p--;
+ for (startp = endp; startp > path && *(startp - 1) != '/'; startp--)
+ continue;
/* ...and copy the result into the result buffer. */
- len = (lastp - p) + 1 /* last char */;
- if (len > (PATH_MAX - 1))
- len = PATH_MAX - 1;
+ len = (endp - startp) + 1 /* last char */;
+out:
+ if (buf != NULL && buflen != 0) {
+ buflen = MIN(len, buflen - 1);
+ memcpy(buf, startp, buflen);
+ buf[buflen] = '\0';
+ }
+ return len;
+}
- memcpy(result, p, len);
- result[len] = '\0';
+#if !HAVE_BASENAME
+
+char *
+basename(char *path) {
+ static char result[PATH_MAX];
- return (result);
+ (void)basename_r(path, result, sizeof(result));
+ return result;
}
+
#endif
diff -r b4c6d269b8e1 -r 9c8c658e53d2 lib/libc/gen/dirname.c
--- a/lib/libc/gen/dirname.c Mon Jul 14 20:20:31 2014 +0000
+++ b/lib/libc/gen/dirname.c Mon Jul 14 20:44:45 2014 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: dirname.c,v 1.11 2009/11/24 13:34:20 tnozaki Exp $ */
+/* $NetBSD: dirname.c,v 1.12 2014/07/14 20:44:45 christos Exp $ */
/*-
* Copyright (c) 1997, 2002 The NetBSD Foundation, Inc.
@@ -31,10 +31,11 @@
#include <sys/cdefs.h>
#if defined(LIBC_SCCS) && !defined(lint)
-__RCSID("$NetBSD: dirname.c,v 1.11 2009/11/24 13:34:20 tnozaki Exp $");
+__RCSID("$NetBSD: dirname.c,v 1.12 2014/07/14 20:44:45 christos Exp $");
#endif /* !LIBC_SCCS && !lint */
#include "namespace.h"
+#include <sys/param.h>
#include <libgen.h>
#include <limits.h>
#include <string.h>
@@ -43,51 +44,57 @@
__weak_alias(dirname,_dirname)
#endif
-#if !HAVE_DIRNAME
-char *
-dirname(char *path)
+static size_t
+dirname_r(const char *path, char *buf, size_t buflen)
{
- static char result[PATH_MAX];
- const char *lastp;
+ const char *endp;
size_t len;
/*
* If `path' is a null pointer or points to an empty string,
* return a pointer to the string ".".
*/
- if ((path == NULL) || (*path == '\0'))
- goto singledot;
-
+ if (path == NULL || *path == '\0') {
+ path = ".";
+ len = 1;
+ goto out;
+ }
/* Strip trailing slashes, if any. */
- lastp = path + strlen(path) - 1;
- while (lastp != path && *lastp == '/')
- lastp--;
+ endp = path + strlen(path) - 1;
+ while (endp != path && *endp == '/')
+ endp--;
+
+ /* Find the start of the dir */
+ while (endp > path && *endp != '/')
+ endp--;
- /* Terminate path at the last occurence of '/'. */
- do {
- if (*lastp == '/') {
- /* Strip trailing slashes, if any. */
- while (lastp != path && *lastp == '/')
- lastp--;
+ if (endp == path) {
+ path = *endp == '/' ? "/" : ".";
+ len = 1;
+ goto out;
+ }
+
+ do
+ endp--;
+ while (endp > path && *endp == '/');
- /* ...and copy the result into the result buffer. */
- len = (lastp - path) + 1 /* last char */;
- if (len > (PATH_MAX - 1))
- len = PATH_MAX - 1;
-
- memcpy(result, path, len);
- result[len] = '\0';
+ len = endp - path + 1;
+out:
+ if (buf != NULL && buflen != 0) {
+ buflen = MIN(len, buflen - 1);
+ memcpy(buf, path, buflen);
+ buf[buflen] = '\0';
+ }
+ return len;
+}
- return (result);
- }
- } while (--lastp >= path);
-
- /* No /'s found, return a pointer to the string ".". */
-singledot:
- result[0] = '.';
- result[1] = '\0';
-
- return (result);
+#if !HAVE_DIRNAME
+char *
+dirname(char *path)
+{
+ static char result[PATH_MAX];
+ (void)dirname_r(path, result, sizeof(result));
+ return result;
}
#endif
Home |
Main Index |
Thread Index |
Old Index