Oops. Forgot the usleep.c file.
[oweals/busybox.git] / touch.c
diff --git a/touch.c b/touch.c
index ca4b981081143b8bda4e2d98e07874dadafb19f7..a0f21acdd3c23372e6d5217ab49c6e99a139ee21 100644 (file)
--- a/touch.c
+++ b/touch.c
@@ -1,20 +1,81 @@
+/* vi: set sw=4 ts=4: */
+/*
+ * Mini touch implementation for busybox
+ *
+ *
+ * Copyright (C) 1999 by Lineo, inc.
+ * Written by Erik Andersen <andersen@lineo.com>, <andersee@debian.org>
+ *
+ * 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
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ *
+ */
+
 #include "internal.h"
-#include <sys/types.h>
 #include <stdio.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
 #include <utime.h>
+#include <errno.h>
+
+
+static const char touch_usage[] = "touch [-c] file [file ...]\n\n"
+
+       "Update the last-modified date on the given file[s].\n";
 
-const char     touch_usage[] = "touch [-c] file [file ...]\n"
-"\n"
-"\tUpdate the last-modified date on the given file[s].\n";
 
-extern int
-touch_fn(const struct FileInfo * i)
+
+extern int touch_main(int argc, char **argv)
 {
-       if ( (utime(i->source, 0) != 0) && (i->create != 1) ) {
-               if ( fopen(i->source, "w") == NULL ) {
-                       name_and_error(i->source);
-                       return 1;
+       int fd;
+       int create = TRUE;
+
+       if (argc < 2) {
+               usage(touch_usage);
+       }
+       argc--;
+       argv++;
+
+       /* Parse options */
+       while (**argv == '-') {
+               while (*++(*argv))
+                       switch (**argv) {
+                       case 'c':
+                               create = FALSE;
+                               break;
+                       default:
+                               usage(touch_usage);
+                               exit(FALSE);
+                       }
+               argc--;
+               argv++;
+       }
+
+       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);
                }
        }
-       return 0;
+       close(fd);
+       if (utime(*argv, NULL)) {
+               perror("touch");
+               exit(FALSE);
+       } else
+               exit(TRUE);
 }