Applied patch from Jim Meyering; rename dirfd to dir_fd to avoid shadowing problem
[findutils.git] / lib / nextelem.c
bloba4bd8dd6a661732af4e6d0f92cbd262e4da2092d
1 /* Return the next element of a path.
2 Copyright (C) 1992,2005 Free Software Foundation, Inc.
4 This program is free software: you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation, either version 3 of the License, or
7 (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
14 You should have received a copy of the GNU General Public License
15 along with this program. If not, see <http://www.gnu.org/licenses/>.
18 /* Written by David MacKenzie <djm@gnu.org>,
19 inspired by John P. Rouillard <rouilj@cs.umb.edu>. */
21 #include <config.h>
24 #include <stdio.h>
25 #if defined HAVE_STRING_H || defined STDC_HEADERS
26 #include <string.h>
27 #else
28 #include <strings.h>
29 #ifndef strchr
30 #define strchr index
31 #endif
32 #endif
33 #if defined STDC_HEADERS
34 #include <stdlib.h>
35 #endif
37 #include "nextelem.h"
40 /* Return the next element of a colon-separated path.
41 A null entry in the path is equivalent to "." (the current directory).
43 If NEW_PATH is non-NULL, set the path and return NULL.
44 If NEW_PATH is NULL, return the next item in the string, or
45 return NULL if there are no more elements. */
47 char *
48 next_element (const char *new_path, int curdir_ok)
50 static char *path = NULL; /* Freshly allocated copy of NEW_PATH. */
51 static char *end; /* Start of next element to return. */
52 static int final_colon; /* If zero, path didn't end with a colon. */
53 char *start; /* Start of path element to return. */
55 if (new_path)
57 if (path)
58 free (path);
59 end = path = strdup (new_path);
60 final_colon = 0;
61 return NULL;
64 if (*end == '\0')
66 if (final_colon)
68 final_colon = 0;
69 return curdir_ok ? "." : "";
71 return NULL;
74 start = end;
75 final_colon = 1; /* Maybe there will be one. */
77 end = strchr (start, ':');
78 if (end == start)
80 /* An empty path element. */
81 *end++ = '\0';
82 return curdir_ok ? "." : "";
84 else if (end == NULL)
86 /* The last path element. */
87 end = strchr (start, '\0');
88 final_colon = 0;
90 else
91 *end++ = '\0';
93 return start;
96 #ifdef TEST
97 int
98 main ()
100 char *p;
102 next_element (getenv ("PATH"));
103 while (p = next_element (NULL))
104 puts (p);
105 exit (0);
107 #endif /* TEST */