From c9ed52730b352448c7c644f6942d310dd3509bf6 Mon Sep 17 00:00:00 2001 From: Russ Cox Date: Mon, 17 Nov 2014 11:21:06 -0500 Subject: cmd: rename *.C to *.c These were *.C back in 2003, before the 9 script, to avoid conflicts with the system utilities. A later change renamed them, but that change seems to have been lost during the hg->git conversion because I ran the conversion on a case-insensitive file system. Change-Id: Id32c99cb9571ef0e185c3cc9e8c8d6d5b48ca195 --- src/cmd/mkdir.c | 80 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 80 insertions(+) create mode 100644 src/cmd/mkdir.c (limited to 'src/cmd/mkdir.c') diff --git a/src/cmd/mkdir.c b/src/cmd/mkdir.c new file mode 100644 index 00000000..1c16565d --- /dev/null +++ b/src/cmd/mkdir.c @@ -0,0 +1,80 @@ +#include +#include + +char *e; +ulong mode = 0777L; + +void +usage(void) +{ + fprint(2, "usage: mkdir [-p] [-m mode] dir...\n"); + exits("usage"); +} + +int +makedir(char *s) +{ + int f; + + if(access(s, AEXIST) == 0){ + fprint(2, "mkdir: %s already exists\n", s); + e = "error"; + return -1; + } + f = create(s, OREAD, DMDIR | mode); + if(f < 0){ + fprint(2, "mkdir: can't create %s: %r\n", s); + e = "error"; + return -1; + } + close(f); + return 0; +} + +void +mkdirp(char *s) +{ + char *p; + + for(p=strchr(s+1, '/'); p; p=strchr(p+1, '/')){ + *p = 0; + if(access(s, AEXIST) != 0 && makedir(s) < 0) + return; + *p = '/'; + } + if(access(s, AEXIST) != 0) + makedir(s); +} + + +void +main(int argc, char *argv[]) +{ + int i, pflag; + char *m; + + pflag = 0; + ARGBEGIN{ + default: + usage(); + case 'm': + m = ARGF(); + if(m == nil) + usage(); + mode = strtoul(m, &m, 8); + if(mode > 0777) + usage(); + break; + case 'p': + pflag = 1; + break; + }ARGEND + + for(i=0; i