From a0d34ce173b126c5e10798f9746f0975df1e77c2 Mon Sep 17 00:00:00 2001 From: Jim Meyering Date: Mon, 19 Aug 1996 01:41:53 +0000 Subject: . --- lib/path-concat.c | 58 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ lib/path-concat.h | 9 +++++++++ 2 files changed, 67 insertions(+) create mode 100644 lib/path-concat.c create mode 100644 lib/path-concat.h (limited to 'lib') diff --git a/lib/path-concat.c b/lib/path-concat.c new file mode 100644 index 000000000..ce74ed133 --- /dev/null +++ b/lib/path-concat.c @@ -0,0 +1,58 @@ +/* path-concat.c -- concatenate two arbitrary pathnames + Copyright (C) 1996 Free Software Foundation, Inc. + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2, or (at your option) + any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software Foundation, + Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + +/* Written by Jim Meyering. */ + +#ifdef HAVE_CONFIG_H +#include +#endif + +char *malloc (); +char *stpcpy (); + +/* Concatenate two pathname components, DIR and BASE, in newly-allocated + storage and return the result. Return 0 if out of memory. Add a slash + between DIR and BASE in the result if neither would contribute one. + If each would contribute at least one, elide one from the end of DIR. + Otherwise, simply concatenate DIR and BASE. In any case, if + BASE_IN_RESULT is non-NULL, set *BASE_IN_RESULT to point to the copy of + BASE in the returned concatenation. */ + +char * +path_concat (const char *dir, const char *base, char **base_in_result) +{ + char *p; + char *p_concat; + + p_concat = malloc (strlen (dir) + strlen (base) + 2); + if (!p_concat) + return 0; + + p = stpcpy (p_concat, dir); + + if (*(p - 1) == '/' && *base == '/') + --p; + else if (*(p - 1) != '/' && *base != '/') + p = stpcpy (p, "/"); + + if (base_in_result) + *base_in_result = p; + + stpcpy (p, base); + + return p_concat; +} diff --git a/lib/path-concat.h b/lib/path-concat.h new file mode 100644 index 000000000..0a19f053a --- /dev/null +++ b/lib/path-concat.h @@ -0,0 +1,9 @@ +#if __STDC__ +# undef __P +# define __P(args) args +#else +# define __P(args) () +#endif + +char * +path_concat _P ((const char *dir, const char *base, char **base_in_result)); -- cgit v1.2.3-70-g09d2