1 /* Return the next element of a path.
2 Copyright (C) 1992 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 2, or (at your option)
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, write to the Free Software
16 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
20 /* Written by David MacKenzie <djm@gnu.ai.mit.edu>,
21 inspired by John P. Rouillard <rouilj@cs.umb.edu>. */
28 #if defined(HAVE_STRING_H) || defined(STDC_HEADERS)
36 #if defined(STDC_HEADERS)
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. */
48 next_element (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. */
59 end
= path
= strdup (new_path
);
69 return curdir_ok
? "." : NULL
;
75 final_colon
= 1; /* Maybe there will be one. */
77 end
= strchr (start
, ':');
80 /* An empty path element. */
82 return curdir_ok
? "." : NULL
;
86 /* The last path element. */
87 end
= strchr (start
, '\0');
102 next_element (getenv ("PATH"));
103 while (p
= next_element (NULL
))