/* See LICENSE file for copyright and license details. */ #include #include #include #include #include #include #ifdef NOTIFY #include #endif /* NOTIFY */ #include "arg.h" char *argv0; /* macros */ #define LEN(a) (sizeof(a) / sizeof(a[0])) #define SPAWN(cmd) if (fork() == 0) {\ setsid();\ cmd;\ die("spt: spawn\n");\ perror(" failed");\ exit(0);\ } typedef struct { unsigned int tmr; char *cmt; } Timers; #include "config.h" static int i, timecount; /* function declarations */ static void die(const char *errstr, ...); static void notify_send(char *cmt); static void remaining_time(int sigint); static void usage(void); /* functions implementations */ void die(const char *errstr, ...) { va_list ap; va_start(ap, errstr); vfprintf(stderr, errstr, ap); va_end(ap); exit(EXIT_FAILURE); } void notify_send(char *cmt) { #ifdef NOTIFY notify_init("spt"); NotifyNotification *n = notify_notification_new("spt", cmt, \ "dialog-information"); notify_notification_show(n, NULL); g_object_unref(G_OBJECT(n)); notify_uninit(); #else if (strcmp(notifycmd, "")) /* TODO: call function in config.h */ SPAWN(execlp(notifycmd, notifycmd, "spt", cmt, NULL)) #endif /* NOTIFY */ if (strcmp(notifyext, "")) /* extra commands to use */ SPAWN(execvp("sh", (char *const []){"/bin/sh", "-c", notifyext, NULL})) } void remaining_time(int sigint) { char remainingtext[17]; if (signal(SIGUSR1, SIG_IGN) != SIG_IGN) signal(SIGUSR1, remaining_time); snprintf(remainingtext, 17, "Remaining: %02d:%02d\n", (timers[i].tmr - timecount) / 60, (timers[i].tmr - timecount) % 60); notify_send(remainingtext); } void usage(void) { die("usage: %s [-e notifyext] [-n notifycmd] [-v]\n", argv0); } int main(int argc, char *argv[]) { ARGBEGIN { case 'e': notifyext = EARGF(usage()); break; case 'n': notifycmd = EARGF(usage()); break; case 'v': die("spt " VERSION " © 2015 spt engineers, " "see LICENSE for details\n"); default: usage(); break; } ARGEND; if (signal(SIGUSR1, SIG_IGN) != SIG_IGN) signal(SIGUSR1, remaining_time); run: notify_send(timers[i].cmt); for (timecount = 0; timecount < timers[i].tmr; timecount++) sleep(1); i + 1 >= LEN(timers) ? i = 0 : i++; /* i infinal loop */ goto run; return 0; }