X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=coreutils%2Ftouch.c;h=f78fe5114c1b7a1c5472855c61a2cd978662e1b6;hb=07a79e75f502ebd41e5341aacc5de303d3ffaea0;hp=2076928263da0a540f0a86133c984221726d9a06;hpb=7ab9c7ee52db8759d457819f5480378fa3aa97cc;p=oweals%2Fbusybox.git diff --git a/coreutils/touch.c b/coreutils/touch.c index 207692826..f78fe5114 100644 --- a/coreutils/touch.c +++ b/coreutils/touch.c @@ -2,9 +2,7 @@ /* * Mini touch implementation for busybox * - * - * Copyright (C) 1999,2000 by Lineo, inc. - * Written by Erik Andersen , + * Copyright (C) 1999-2004 by Erik Andersen * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -22,62 +20,57 @@ * */ -#include "internal.h" +/* BB_AUDIT SUSv3 _NOT_ compliant -- options -a, -m, -r, -t not supported. */ +/* http://www.opengroup.org/onlinepubs/007904975/utilities/touch.html */ + +/* Mar 16, 2003 Manuel Novoa III (mjn3@codepoet.org) + * + * Previous version called open() and then utime(). While this will be + * be necessary to implement -r and -t, it currently only makes things bigger. + * Also, exiting on a failure was a bug. All args should be processed. + */ + #include #include -#include #include #include #include +#include +#include +#include "busybox.h" - -static const char touch_usage[] = "touch [-c] file [file ...]\n" -#ifndef BB_FEATURE_TRIVIAL_HELP - "\nUpdate the last-modified date on the given file[s].\n" -#endif - ; - - - -extern int touch_main(int argc, char **argv) +int touch_main(int argc, char **argv) { int fd; - int create = TRUE; + int flags; + int status = EXIT_SUCCESS; - if (argc < 2) { - usage(touch_usage); - } - argc--; - argv++; + flags = bb_getopt_ulflags(argc, argv, "c"); - /* Parse options */ - while (**argv == '-') { - while (*++(*argv)) - switch (**argv) { - case 'c': - create = FALSE; - break; - default: - usage(touch_usage); - exit(FALSE); - } - argc--; - argv++; + argv += optind; + + if (!*argv) { + bb_show_usage(); } - fd = open(*argv, (create == FALSE) ? O_RDWR : O_RDWR | O_CREAT, 0644); - if (fd < 0) { - if (create == FALSE && errno == ENOENT) - exit(TRUE); - else { - perror("touch"); - exit(FALSE); + do { + if (utime(*argv, NULL)) { + if (errno == ENOENT) { /* no such file*/ + if (flags & 1) { /* Creation is disabled, so ignore. */ + continue; + } + /* Try to create the file. */ + fd = open(*argv, O_RDWR | O_CREAT, + S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP | S_IROTH | S_IWOTH + ); + if ((fd >= 0) && !close(fd)) { + continue; + } + } + status = EXIT_FAILURE; + bb_perror_msg("%s", *argv); } - } - close(fd); - if (utime(*argv, NULL)) { - perror("touch"); - exit(FALSE); - } else - exit(TRUE); + } while (*++argv); + + return status; }