X-Git-Url: https://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Fconcat-filename.c;h=54a66f811945a8b8f98b6f989e2496d2105810bd;hb=ec60d8959e16a743f09704c397931f2621f511ae;hp=6ac5629d3d6c08ff5bf7985903aa1e9af9a7ac37;hpb=94a1038450d4bf8222e18b3d4b55b2084db42f26;p=gnulib.git
diff --git a/lib/concat-filename.c b/lib/concat-filename.c
index 6ac5629d3..54a66f811 100644
--- a/lib/concat-filename.c
+++ b/lib/concat-filename.c
@@ -1,9 +1,9 @@
-/* Construct a full pathname from a directory and a filename.
- Copyright (C) 2001-2004, 2006-2007 Free Software Foundation, Inc.
+/* Construct a full filename from a directory and a relative filename.
+ Copyright (C) 2001-2004, 2006-2008 Free Software Foundation, Inc.
- This program is free software; you can redistribute it and/or modify it
+ 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
+ Free Software Foundation; either version 3 of the License, or any
later version.
This program is distributed in the hope that it will be useful,
@@ -12,28 +12,29 @@
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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
- USA. */
+ along with this program. If not, see . */
/* Written by Bruno Haible . */
#include
/* Specification. */
-#include "filename.h"
+#include "concat-filename.h"
+#include
+#include
#include
-#include "xalloc.h"
+#include "filename.h"
/* Concatenate a directory filename, a relative filename and an optional
suffix. The directory may end with the directory separator. The second
argument may not start with the directory separator (it is relative).
- Return a freshly allocated filename. */
+ Return a freshly allocated filename. Return NULL and set errno
+ upon memory allocation failure. */
char *
concatenated_filename (const char *directory, const char *filename,
- const char *suffix)
+ const char *suffix)
{
char *result;
char *p;
@@ -41,27 +42,29 @@ concatenated_filename (const char *directory, const char *filename,
if (strcmp (directory, ".") == 0)
{
/* No need to prepend the directory. */
- result = XNMALLOC (strlen (filename)
- + (suffix != NULL ? strlen (suffix) : 0)
- + 1,
- char);
+ result = (char *) malloc (strlen (filename)
+ + (suffix != NULL ? strlen (suffix) : 0)
+ + 1);
+ if (result == NULL)
+ return NULL; /* errno is set here */
p = result;
}
else
{
size_t directory_len = strlen (directory);
int need_slash =
- (directory_len > FILE_SYSTEM_PREFIX_LEN (directory)
- && !ISSLASH (directory[directory_len - 1]));
- result = XNMALLOC (directory_len + need_slash
- + strlen (filename)
- + (suffix != NULL ? strlen (suffix) : 0)
- + 1,
- char);
+ (directory_len > FILE_SYSTEM_PREFIX_LEN (directory)
+ && !ISSLASH (directory[directory_len - 1]));
+ result = (char *) malloc (directory_len + need_slash
+ + strlen (filename)
+ + (suffix != NULL ? strlen (suffix) : 0)
+ + 1);
+ if (result == NULL)
+ return NULL; /* errno is set here */
memcpy (result, directory, directory_len);
p = result + directory_len;
if (need_slash)
- *p++ = '/';
+ *p++ = '/';
}
p = stpcpy (p, filename);
if (suffix != NULL)