#include <errno.h>
#endif
-#ifndef STDC_HEADERS
+#ifndef errno
extern int errno;
#endif
-#if defined(STDC_HEADERS) || defined(HAVE_STRING_H)
-#include <string.h>
-#ifndef index
-#define index strchr
-#endif
+#ifdef HAVE_STRING_H
+# include <string.h>
#else
-#include <strings.h>
+# include <strings.h>
+# ifndef strchr
+# define strchr index
+# endif
#endif
#ifdef __MSDOS__
#endif
#include "makepath.h"
-#include "safe-stat.h"
+
void error ();
/* Ensure that the directory ARGPATH exists.
Return 0 if ARGPATH exists as a directory with the proper
ownership and permissions when done, otherwise 1. */
+#if __STDC__
+int
+make_path (const char *argpath,
+ int mode,
+ int parent_mode,
+ uid_t owner,
+ gid_t group,
+ int preserve_existing,
+ const char *verbose_fmt_string)
+#else
int
make_path (argpath, mode, parent_mode, owner, group, preserve_existing,
verbose_fmt_string)
gid_t group;
int preserve_existing;
const char *verbose_fmt_string;
+#endif
{
char *dirpath; /* A copy we can scribble NULs on. */
struct stat stats;
dirpath = (char *) alloca (strlen (argpath) + 1);
strcpy (dirpath, argpath);
- if (SAFE_STAT (dirpath, &stats))
+ if (stat (dirpath, &stats))
{
char *slash;
int tmp_mode; /* Initial perms for leading dirs. */
slash = dirpath;
while (*slash == '/')
slash++;
- while ((slash = index (slash, '/')))
+ while ((slash = strchr (slash, '/')))
{
*slash = '\0';
- if (SAFE_STAT (dirpath, &stats))
+ if (stat (dirpath, &stats))
{
if (mkdir (dirpath, tmp_mode))
{
/* The path could end in "/." or contain "/..", so test
if we really have to create the directory. */
- if (SAFE_STAT (dirpath, &stats) && mkdir (dirpath, mode))
+ if (stat (dirpath, &stats) && mkdir (dirpath, mode))
{
error (0, errno, "cannot create directory `%s'", dirpath);
umask (oldmask);