]> git.netwichtig.de Git - user/henk/code/snooze.git/blobdiff - snooze.c
Print duration and day of week with -n
[user/henk/code/snooze.git] / snooze.c
index a5df96767c541106a85deec9494c062ca0dd691a..73de94e1d7c5f0f01f53bab263e6f631a00ac81b 100644 (file)
--- a/snooze.c
+++ b/snooze.c
@@ -64,6 +64,34 @@ parse_int(char **s, size_t minn, size_t maxn)
        return n;
 }
 
+static long
+parse_dur(char *s)
+{
+       long n;
+       char *end;
+
+       errno = 0;
+       n = strtol(s, &end, 10);
+       if (errno) {
+               perror("strtol");
+               exit(1);
+       }
+       if (n < 0) {
+               fprintf(stderr, "negative duration\n");
+               exit(1);
+       }
+       switch (*end) {
+       case 'm': n *= 60; break;
+       case 'h': n *= 60*60; break;
+       case 'd': n *= 24*60*60; break;
+       case 0: break;
+       default:
+               fprintf(stderr, "junk after duration: %s\n", end);
+               exit(1);
+       }
+       return n;
+}
+
 static int
 parse(char *expr, char *buf, long bufsiz, int offset)
 {
@@ -229,10 +257,10 @@ int main(int argc, char *argv[])
                        break;
                case 'n': nflag++; break;
                case 'v': vflag++; break;
-               case 's': slack = atoi(optarg); break;
-               case 'T': timewait = atoi(optarg); break;
+               case 's': slack = parse_dur(optarg); break;
+               case 'T': timewait = parse_dur(optarg); break;
                case 't': timefile = optarg; break;
-               case 'R': randdelay = atoi(optarg); break;
+               case 'R': randdelay = parse_dur(optarg); break;
                default:
                         fprintf(stderr, "Usage: %s [-nv] [-t timefile] [-T timewait] [-R randdelay] [-s slack]\n"
                            "  [-d mday] [-m mon] [-w wday] [-D yday] [-W yweek] [-H hour] [-M min] [-S sec] COMMAND...\n"
@@ -290,8 +318,18 @@ int main(int argc, char *argv[])
                /* dry-run, just output the next 5 dates. */
                int i;
                for (i = 0; i < 5; i++) {
-                       if (t > 0)
-                               printf("%s\n", isotime(localtime(&t)));
+                       if (t > 0) {
+                               char weekstr[4];
+                               struct tm *tm = localtime(&t);
+                               strftime(weekstr, sizeof weekstr, "%a", tm);
+                               printf("%s %s %2ldd%3ldh%3ldm%3lds\n",
+                                   isotime(tm),
+                                   weekstr,
+                                   ((t - now) / (60*60*24)),
+                                   ((t - now) / (60*60)) % 24,
+                                   ((t - now) / 60) % 60,
+                                   (t - now) % 60);
+                       }
                        t = find_next(t + 1);
                }
                exit(0);