]> Zhao Yanbai Git Server - minix.git/commitdiff
import NetBSD mkdir
authorVivek Prakash <vivek.cs.iitr@gmail.com>
Sun, 14 Aug 2011 14:49:39 +0000 (14:49 +0000)
committerBen Gras <ben@minix3.org>
Thu, 25 Aug 2011 14:35:12 +0000 (14:35 +0000)
. add symlink from old location /usr/bin/mkdir for
  for compatability

bin/Makefile
bin/mkdir/Makefile [new file with mode: 0644]
bin/mkdir/minix-port.patch [new file with mode: 0644]
bin/mkdir/mkdir.1 [new file with mode: 0644]
bin/mkdir/mkdir.c [new file with mode: 0644]
commands/Makefile
commands/mkdir/Makefile [deleted file]
commands/mkdir/mkdir.c [deleted file]
man/man1/Makefile
man/man1/mkdir.1 [deleted file]
tools/nbsd_ports

index 186d10d232d0942d259e340d22818f35f5c3f014..98c877ff5e6b2cc07be7a1151694b7ae1e902dec 100644 (file)
@@ -2,6 +2,6 @@
 
 .include <bsd.own.mk>
 
-SUBDIR=
+SUBDIR= mkdir
 
 .include <bsd.subdir.mk>
diff --git a/bin/mkdir/Makefile b/bin/mkdir/Makefile
new file mode 100644 (file)
index 0000000..dd2e0c3
--- /dev/null
@@ -0,0 +1,7 @@
+#      $NetBSD: Makefile,v 1.8 1997/07/20 22:37:21 christos Exp $
+#      @(#)Makefile    8.1 (Berkeley) 5/31/93
+
+PROG=  mkdir
+SYMLINKS=      $(BINDIR)/$(PROG) /usr/bin/$(PROG)
+
+.include <bsd.prog.mk>
diff --git a/bin/mkdir/minix-port.patch b/bin/mkdir/minix-port.patch
new file mode 100644 (file)
index 0000000..e69de29
diff --git a/bin/mkdir/mkdir.1 b/bin/mkdir/mkdir.1
new file mode 100644 (file)
index 0000000..605126f
--- /dev/null
@@ -0,0 +1,94 @@
+.\"    $NetBSD: mkdir.1,v 1.16 2003/08/07 09:05:16 agc Exp $
+.\"
+.\" Copyright (c) 1989, 1990, 1993
+.\"    The Regents of the University of California.  All rights reserved.
+.\"
+.\" This code is derived from software contributed to Berkeley by
+.\" the Institute of Electrical and Electronics Engineers, Inc.
+.\"
+.\" Redistribution and use in source and binary forms, with or without
+.\" modification, are permitted provided that the following conditions
+.\" are met:
+.\" 1. Redistributions of source code must retain the above copyright
+.\"    notice, this list of conditions and the following disclaimer.
+.\" 2. Redistributions in binary form must reproduce the above copyright
+.\"    notice, this list of conditions and the following disclaimer in the
+.\"    documentation and/or other materials provided with the distribution.
+.\" 3. Neither the name of the University nor the names of its contributors
+.\"    may be used to endorse or promote products derived from this software
+.\"    without specific prior written permission.
+.\"
+.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
+.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
+.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+.\" SUCH DAMAGE.
+.\"
+.\"    @(#)mkdir.1     8.2 (Berkeley) 1/25/94
+.\"
+.Dd January 25, 1994
+.Dt MKDIR 1
+.Os
+.Sh NAME
+.Nm mkdir
+.Nd make directories
+.Sh SYNOPSIS
+.Nm
+.Op Fl p
+.Op Fl m Ar mode
+.Ar directory_name  ...
+.Sh DESCRIPTION
+.Nm
+creates the directories named as operands, in the order specified,
+using mode
+.Li rwxrwxrwx (\&0777)
+as modified by the current
+.Xr umask  2  .
+.Pp
+The options are as follows:
+.Pp
+.Bl -tag -width indent
+.It Fl m
+Set the file permission bits of the final created directory to
+the specified mode.
+The mode argument can be in any of the formats specified to the
+.Xr chmod 1
+utility.
+If a symbolic mode is specified, the operation characters
+.Dq +
+and
+.Dq -
+are interpreted relative to an initial mode of
+.Dq a=rwx .
+.It Fl p
+Create intermediate directories as required.
+If this option is not specified, the full path prefix of each
+operand must already exist.
+Intermediate directories are created with permission bits of
+.Li rwxrwxrwx (\&0777)
+as modified by the current umask, plus write and search
+permission for the owner.
+Do not consider it an error if the argument directory already exists.
+.El
+.Pp
+The user must have write permission in the parent directory.
+.Sh EXIT STATUS
+.Nm
+exits 0 if successful, and \*[Gt]0 if an error occurred.
+.Sh SEE ALSO
+.Xr chmod 1 ,
+.Xr rmdir 1 ,
+.Xr mkdir 2 ,
+.Xr umask 2
+.Sh STANDARDS
+The
+.Nm
+utility is expected to be
+.St -p1003.2
+compatible.
diff --git a/bin/mkdir/mkdir.c b/bin/mkdir/mkdir.c
new file mode 100644 (file)
index 0000000..78d4c3b
--- /dev/null
@@ -0,0 +1,224 @@
+/* $NetBSD: mkdir.c,v 1.37 2008/07/20 00:52:40 lukem Exp $ */
+
+/*
+ * Copyright (c) 1983, 1992, 1993
+ *     The Regents of the University of California.  All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ * 3. Neither the name of the University nor the names of its contributors
+ *    may be used to endorse or promote products derived from this software
+ *    without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#include <sys/cdefs.h>
+#ifndef lint
+__COPYRIGHT("@(#) Copyright (c) 1983, 1992, 1993\
+ The Regents of the University of California.  All rights reserved.");
+#endif /* not lint */
+
+#ifndef lint
+#if 0
+static char sccsid[] = "@(#)mkdir.c    8.2 (Berkeley) 1/25/94";
+#else
+__RCSID("$NetBSD: mkdir.c,v 1.37 2008/07/20 00:52:40 lukem Exp $");
+#endif
+#endif /* not lint */
+
+#include <sys/param.h>
+#include <sys/stat.h>
+#include <sys/types.h>
+
+#include <err.h>
+#include <errno.h>
+#include <locale.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <unistd.h>
+
+int    mkpath(char *, mode_t, mode_t);
+void   usage(void);
+int    main(int, char *[]);
+
+int
+main(int argc, char *argv[])
+{
+       int ch, exitval, pflag;
+       void *set;
+       mode_t mode, dir_mode;
+
+       setprogname(argv[0]);
+       (void)setlocale(LC_ALL, "");
+
+       /*
+        * The default file mode is a=rwx (0777) with selected permissions
+        * removed in accordance with the file mode creation mask.  For
+        * intermediate path name components, the mode is the default modified
+        * by u+wx so that the subdirectories can always be created.
+        */
+       mode = (S_IRWXU | S_IRWXG | S_IRWXO) & ~umask(0);
+       dir_mode = mode | S_IWUSR | S_IXUSR;
+
+       pflag = 0;
+       while ((ch = getopt(argc, argv, "m:p")) != -1)
+               switch (ch) {
+               case 'p':
+                       pflag = 1;
+                       break;
+               case 'm':
+                       if ((set = setmode(optarg)) == NULL) {
+                               err(EXIT_FAILURE, "Cannot set file mode `%s'",
+                                   optarg);
+                               /* NOTREACHED */
+                       }
+                       mode = getmode(set, S_IRWXU | S_IRWXG | S_IRWXO);
+                       free(set);
+                       break;
+               case '?':
+               default:
+                       usage();
+                       /* NOTREACHED */
+               }
+       argc -= optind;
+       argv += optind;
+
+       if (*argv == NULL) {
+               usage();
+               /* NOTREACHED */
+       }
+
+       for (exitval = EXIT_SUCCESS; *argv != NULL; ++argv) {
+#ifdef notdef
+               char *slash;
+
+               /* Kernel takes care of this */
+               /* Remove trailing slashes, per POSIX. */
+               slash = strrchr(*argv, '\0');
+               while (--slash > *argv && *slash == '/')
+                       *slash = '\0';
+#endif
+
+               if (pflag) {
+                       if (mkpath(*argv, mode, dir_mode) < 0)
+                               exitval = EXIT_FAILURE;
+               } else {
+                       if (mkdir(*argv, mode) < 0) {
+                               warn("%s", *argv);
+                               exitval = EXIT_FAILURE;
+                       } else {
+                               /*
+                                * The mkdir() and umask() calls both honor
+                                * only the file permission bits, so if you try
+                                * to set a mode including the sticky, setuid,
+                                * setgid bits you lose them. So chmod().
+                                */
+                               if ((mode & ~(S_IRWXU|S_IRWXG|S_IRWXO)) != 0 &&
+                                   chmod(*argv, mode) == -1) {
+                                       warn("%s", *argv);
+                                       exitval = EXIT_FAILURE;
+                               }
+                       }
+               }
+       }
+       exit(exitval);
+       /* NOTREACHED */
+}
+
+/*
+ * mkpath -- create directories.
+ *     path     - path
+ *     mode     - file mode of terminal directory
+ *     dir_mode - file mode of intermediate directories
+ */
+int
+mkpath(char *path, mode_t mode, mode_t dir_mode)
+{
+       struct stat sb;
+       char *slash;
+       int done, rv;
+
+       done = 0;
+       slash = path;
+
+       for (;;) {
+               slash += strspn(slash, "/");
+               slash += strcspn(slash, "/");
+
+               done = (*slash == '\0');
+               *slash = '\0';
+
+               rv = mkdir(path, done ? mode : dir_mode);
+               if (rv < 0) {
+                       /*
+                        * Can't create; path exists or no perms.
+                        * stat() path to determine what's there now.
+                        */
+                       int     sverrno;
+
+                       sverrno = errno;
+                       if (stat(path, &sb) < 0) {
+                                       /* Not there; use mkdir()s error */
+                               errno = sverrno;
+                               warn("%s", path);
+                               return -1;
+                       }
+                       if (!S_ISDIR(sb.st_mode)) {
+                                       /* Is there, but isn't a directory */
+                               errno = ENOTDIR;
+                               warn("%s", path);
+                               return -1;
+                       }
+               } else if (done) {
+                       /*
+                        * Created ok, and this is the last element
+                        */
+                       /*
+                        * The mkdir() and umask() calls both honor only the
+                        * file permission bits, so if you try to set a mode
+                        * including the sticky, setuid, setgid bits you lose
+                        * them. So chmod().
+                        */
+                       if ((mode & ~(S_IRWXU|S_IRWXG|S_IRWXO)) != 0 &&
+                           chmod(path, mode) == -1) {
+                               warn("%s", path);
+                               return -1;
+                       }
+               }
+
+               if (done) {
+                       break;
+               }
+               *slash = '/';
+       }
+
+       return 0;
+}
+
+void
+usage(void)
+{
+
+       (void)fprintf(stderr, "usage: %s [-p] [-m mode] dirname ...\n",
+           getprogname());
+       exit(EXIT_FAILURE);
+       /* NOTREACHED */
+}
index 8b348bdcf8b35bbc672ec7b73cd2417f2dadc699..29683f98a50c12eb0e5a25d5e7c0c73d28279859 100644 (file)
@@ -17,7 +17,7 @@ SUBDIR=       aal add_route adduser arp ash at autil awk \
        intr ipcrm ipcs irdpd isoread join kill last leave \
        less lex loadkeys loadramdisk logger login look lp \
        lpd ls lspci M mail make  MAKEDEV man \
-       mdb mdocml mesg mined ackmkdep mkdir mkfifo mkfs.mfs mknod \
+       mdb mdocml mesg mined ackmkdep mkfifo mkfs.mfs mknod \
        mkproto modem mount mt netconf newroot nice acknm nohup \
        nonamed od passwd paste patch pax \
        ping postinstall poweroff pr prep printf printroot \
diff --git a/commands/mkdir/Makefile b/commands/mkdir/Makefile
deleted file mode 100644 (file)
index 31dcaae..0000000
+++ /dev/null
@@ -1,4 +0,0 @@
-PROG=  mkdir
-MAN=
-
-.include <bsd.prog.mk>
diff --git a/commands/mkdir/mkdir.c b/commands/mkdir/mkdir.c
deleted file mode 100644 (file)
index e8df1e2..0000000
+++ /dev/null
@@ -1,269 +0,0 @@
-/* mkdir - Make directories            Author: V. Archer */
-
-/* Copyright 1991 by Vincent Archer
- *     You may freely redistribute this software, in source or binary
- *     form, provided that you do not alter this copyright mention in any
- *     way.
- */
-
-#include <sys/types.h>
-#include <sys/stat.h>
-#include <minix/minlib.h>
-#include <limits.h>
-#include <errno.h>
-#include <string.h>
-#include <stdlib.h>
-#include <unistd.h>
-#include <stdio.h>
-
-extern int optind, opterr;
-extern char *optarg;
-
-#define USR_MODES (S_ISUID|S_IRWXU)
-#define GRP_MODES (S_ISGID|S_IRWXG)
-#define EXE_MODES (S_IXUSR|S_IXGRP|S_IXOTH)
-#ifdef S_ISVTX
-#define ALL_MODES (USR_MODES|GRP_MODES|S_IRWXO|S_ISVTX)
-#else
-#define ALL_MODES (USR_MODES|GRP_MODES|S_IRWXO)
-#endif
-#define DEFAULT_MODE (S_IRWXU|S_IRWXG|S_IRWXO)
-#define USER_WX (S_IWUSR|S_IXUSR)
-
-
-/* Global variables */
-int pflag;
-char *symbolic;
-mode_t u_mask;
-struct stat st;
-
-_PROTOTYPE(int main, (int argc, char **argv));
-_PROTOTYPE(mode_t parsemode, (char *symbolic, mode_t oldmode));
-_PROTOTYPE(int makepath, (char *fordir));
-_PROTOTYPE(int makedir, (char *dirname));
-_PROTOTYPE(void usage, (void));
-
-/* Parse a P1003.2 4.7.7-conformant symbolic mode. */
-mode_t parsemode(char *symbolic, mode_t oldmode)
-{
-  mode_t who, mask, newmode, tmpmask;
-  char action;
-  char *end;
-  unsigned long octalmode;
-
-  octalmode = strtoul(symbolic, &end, 010);
-  if (octalmode < ALL_MODES && *end == 0 && end != symbolic) return octalmode;
-
-  newmode = oldmode & ALL_MODES;
-  while (*symbolic) {
-       who = 0;
-       for (; *symbolic; symbolic++) {
-               if (*symbolic == 'a') {
-                       who |= ALL_MODES;
-                       continue;
-               }
-               if (*symbolic == 'u') {
-                       who |= USR_MODES;
-                       continue;
-               }
-               if (*symbolic == 'g') {
-                       who |= GRP_MODES;
-                       continue;
-               }
-               if (*symbolic == 'o') {
-                       who |= S_IRWXO;
-                       continue;
-               }
-               break;
-       }
-       if (!*symbolic || *symbolic == ',') usage();
-       while (*symbolic) {
-               if (*symbolic == ',') break;
-               switch (*symbolic) {
-                   default:
-                       usage();
-                   case '+':
-                   case '-':
-                   case '=':   action = *symbolic++;
-               }
-               mask = 0;
-               for (; *symbolic; symbolic++) {
-                       if (*symbolic == 'u') {
-                               tmpmask = newmode & S_IRWXU;
-                               mask |= tmpmask | (tmpmask << 3) | (tmpmask << 6);
-                               symbolic++;
-                               break;
-                       }
-                       if (*symbolic == 'g') {
-                               tmpmask = newmode & S_IRWXG;
-                               mask |= tmpmask | (tmpmask >> 3) | (tmpmask << 3);
-                               symbolic++;
-                               break;
-                       }
-                       if (*symbolic == 'o') {
-                               tmpmask = newmode & S_IRWXO;
-                               mask |= tmpmask | (tmpmask >> 3) | (tmpmask >> 6);
-                               symbolic++;
-                               break;
-                       }
-                       if (*symbolic == 'r') {
-                               mask |= S_IRUSR | S_IRGRP | S_IROTH;
-                               continue;
-                       }
-                       if (*symbolic == 'w') {
-                               mask |= S_IWUSR | S_IWGRP | S_IWOTH;
-                               continue;
-                       }
-                       if (*symbolic == 'x') {
-                               mask |= EXE_MODES;
-                               continue;
-                       }
-                       if (*symbolic == 's') {
-                               mask |= S_ISUID | S_ISGID;
-                               continue;
-                       }
-                       if (*symbolic == 'X') {
-                               if (S_ISDIR(oldmode) || (oldmode & EXE_MODES))
-                                       mask |= EXE_MODES;
-                               continue;
-                       }
-#ifdef S_ISVTX
-                       if (*symbolic == 't') {
-                               mask |= S_ISVTX;
-                               who |= S_ISVTX;
-                               continue;
-                       }
-#endif
-                       break;
-               }
-               switch (action) {
-                   case '=':
-                       if (who)
-                               newmode &= ~who;
-                       else
-                               newmode = 0;
-                   case '+':
-                       if (who)
-                               newmode |= who & mask;
-                       else
-                               newmode |= mask & (~u_mask);
-                       break;
-                   case '-':
-                       if (who)
-                               newmode &= ~(who & mask);
-                       else
-                               newmode &= ~mask | u_mask;
-               }
-       }
-       if (*symbolic) symbolic++;
-  }
-  return(newmode);
-}
-
-
-/* Main module. */
-int main(argc, argv)
-int argc;
-char **argv;
-{
-  int error, c;
-
-  opterr = 0;
-  pflag = 0;
-  symbolic = (char *) 0;
-  u_mask = umask(0);
-  umask(u_mask);
-  while ((c = getopt(argc, argv, "m:p")) != EOF) switch (c) {
-           case 'm':   symbolic = optarg;      break;
-           case 'p':   pflag = 1;      break;
-           default:    usage();
-       }
-  if (optind >= argc) usage();
-
-  error = 0;
-  while (optind < argc) error |= makedir(argv[optind++]);
-  return(error);
-}
-
-
-/* P1003.2 requires that missing intermediate pathname components should be
- *     created if the -p option is specified (4.40.3).
- */
-int makepath(fordir)
-char *fordir;
-{
-  char parent[PATH_MAX + 1], *end, *last;
-
-  strcpy(parent, fordir);
-  do {
-         if (!(end = strrchr(parent, '/'))) return(0);
-         *end = '\0';
-         if (!parent[0] || !strcmp(parent, ".")) return(0);
-  } while((last = strrchr(parent, '/')) && !strcmp(last+1, "."));
-
-  if (!stat(parent, &st)) {
-       if (S_ISDIR(st.st_mode)) return(0);
-       errno = ENOTDIR;
-       perror(parent);
-       return(1);
-  }
-  if (mkdir(parent, DEFAULT_MODE)) {
-       if (makepath(parent)) return(1);
-       if (mkdir(parent, DEFAULT_MODE)) {
-               perror(parent);
-               return(1);
-       }
-  }
-
-/* P1003.2 states that, regardless of umask() value, intermediate paths
- *     should have at least write and search (x) permissions (4.40.10).
- */
-  if ((u_mask & USER_WX) &&
-      chmod(parent, ((~u_mask) | USER_WX)) & DEFAULT_MODE) {
-       perror(parent);
-       return(1);
-  }
-  return(0);
-}
-
-
-/* Actual directory creation, using a mkdir() system call. */
-int makedir(dirname)
-char *dirname;
-{
-  while (strlen(dirname) > 1 && dirname[strlen(dirname) - 1] == '/') {
-    dirname[strlen(dirname) - 1] = '\0'; /* trim trailing '/' */
-  }
-
-  if (mkdir(dirname, DEFAULT_MODE)) {
-       if (!pflag) {
-               perror(dirname);
-               return(1);
-       }
-       if (!stat(dirname, &st)) {
-               if (S_ISDIR(st.st_mode)) return(0);
-               errno = ENOTDIR;
-               perror(dirname);
-               return(1);
-       }
-       if (makepath(dirname)) return(1);
-       if (mkdir(dirname, DEFAULT_MODE)) {
-               perror(dirname);
-               return(1);
-       }
-  }
-  if (symbolic && (stat(dirname, &st) ||
-                chmod(dirname, parsemode(symbolic, st.st_mode)))) {
-       perror(dirname);
-       return(1);
-  }
-  return(0);
-}
-
-
-/* Posix command prototype. */
-void usage()
-{
-  std_err("Usage: mkdir [-p] [-m mode] dir...\n");
-  exit(1);
-}
index f4138fbd42056d6b5d2b87d54bca5e563fd21958..5d1c8b1afc9c8f75cfea13a03d1af39b91c793e9 100644 (file)
@@ -11,7 +11,7 @@ MAN=  acd.1 anm.1 ar.1 ash.1 asize.1 at.1 banner.1 basename.1 \
        install.1 isodir.1 isoinfo.1 isoread.1 join.1 kill.1 \
        last.1 leave.1 loadfont.1 loadkeys.1 logger.1 login.1 \
        look.1 lp.1 ls.1 lspci.1 M.1 mail.1  \
-       mesg.1 mixer.1 ackmkdep.1 mkdir.1 mkfs.1 \
+       mesg.1 mixer.1 ackmkdep.1 mkfs.1 \
        mkproto.1 modem.1 mount.1 mt.1 nice.1 nm.1 nohup.1 od.1 \
        ossinfo.1 ossmix.1 ossplay.1 ossrecord.1 osstest.1 passwd.1 \
        paste.1 ping.1 playwave.1 postmort.1 pr.1 prep.1 \
diff --git a/man/man1/mkdir.1 b/man/man1/mkdir.1
deleted file mode 100644 (file)
index 8e7e21b..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-.TH MKDIR 1
-.SH NAME
-mkdir \- make a directory
-.SH SYNOPSIS
-\fBmkdir [\fB\-p\fR] [\fB\-m \fImode\fR] \fIdirectory ...\fR
-.br
-.de FL
-.TP
-\\fB\\$1\\fR
-\\$2
-..
-.de EX
-.TP 20
-\\fB\\$1\\fR
-# \\$2
-..
-.SH OPTIONS
-.FL "\-m" "Create directory with mode"
-.FL "\-p" "Create missing intermediate directories"
-.SH EXAMPLES
-.EX "mkdir dir" "Create \fIdir\fP in the current directory"
-.EX "mkdir \-p /user/ast/dir" "Create the \fI/user/ast\fP and \fI/user/ast/dir\fP"
-.SH DESCRIPTION
-.PP
-The specified directory or directories are created and initialized. If any
-intermediate directory is missing and \fB\-p\fR is specified, the missing
-component will be created and no error displayed if directory already
-exists. If the \fB\-m\fR flag is used, this will be equivalent to a chmod
-on the directory after its creation.
-.SH "SEE ALSO"
-.BR chmod (1),
-.BR rmdir (1),
-.BR mkdir (2).
index 882f26f53fb9f464649d0e081f9ccf3658e7b080..b468594a90784456ac324069030bfed93e8a8463 100644 (file)
@@ -5,6 +5,7 @@ lib/libcrypt            src/lib/libcrypt
 lib/libterminfo                src/lib/libterminfo
 lib/libcurses          src/lib/libcurses
 nbsd_include           src/include
+bin/mkdir              src/bin/mkdir
 usr.bin/m4             src/usr.bin/m4
 usr.bin/indent         src/usr.bin/indent
 usr.bin/sed            src/usr.bin/sed