at/at-3.1.10-dont_fork.patch

88 lines
2.0 KiB
Diff
Raw Normal View History

2007-01-30 10:32:28 +00:00
--- at-3.1.10/atd.c.dont_fork 2007-01-30 11:02:37.000000000 +0100
+++ at-3.1.10/atd.c 2007-01-30 11:07:23.000000000 +0100
@@ -1001,7 +1001,7 @@
run_as_daemon = 1;
batch_interval = BATCH_INTERVAL_DEFAULT;
- while ((c = getopt(argc, argv, "sdl:b:")) != EOF) {
2007-01-30 12:54:46 +00:00
+ while ((c = getopt(argc, argv, "sdl:b:n:")) != EOF) {
2007-01-30 10:32:28 +00:00
switch (c) {
case 'l':
if (sscanf(optarg, "%lf", &load_avg) != 1)
@@ -1014,10 +1014,15 @@
if (sscanf(optarg, "%ud", &batch_interval) != 1)
pabort("garbled option -b");
break;
+
case 'd':
daemon_debug++;
+ /* go through another option*/
2007-01-29 16:46:11 +00:00
+
2007-01-30 10:32:28 +00:00
+ case 'n':
+ daemon_nofork++;
break;
2007-01-29 16:46:11 +00:00
-
2007-01-30 10:32:28 +00:00
+
case 's':
2007-01-29 16:46:11 +00:00
run_as_daemon = 0;
break;
--- at-3.1.10/daemon.c.dont_fork 2005-08-05 05:16:01.000000000 +0200
2007-01-30 10:32:28 +00:00
+++ at-3.1.10/daemon.c 2007-01-30 11:06:19.000000000 +0100
2006-10-24 14:25:28 +00:00
@@ -50,7 +50,8 @@
static const char *svnid = "$Id$";
-int daemon_debug;
+int daemon_debug = 0;
+int daemon_nofork = 0;
static int
lock_fd(int fd)
@@ -119,15 +120,18 @@
(open("/dev/null", O_RDWR) != 2)) {
perr("Error redirecting I/O");
}
+ }
+ if (daemon_nofork) pid = getpid();
+ else {
pid = fork();
if (pid == -1) {
perr("Cannot fork");
} else if (pid != 0) {
exit(0);
}
+ (void) setsid();
}
old_umask = umask(S_IWGRP | S_IWOTH);
- (void) setsid();
PRIV_START
2007-01-29 16:46:11 +00:00
--- at-3.1.10/daemon.h.dont_fork 2005-08-05 05:16:01.000000000 +0200
2007-01-30 10:32:28 +00:00
+++ at-3.1.10/daemon.h 2007-01-30 11:07:54.000000000 +0100
2006-10-24 14:25:28 +00:00
@@ -14,3 +14,4 @@
perr (const char *fmt, ...);
extern int daemon_debug;
+extern int daemon_nofork;
2007-01-30 10:32:28 +00:00
--- at-3.1.8/atd.8.in.dontfork 2002-01-18 08:41:03.000000000 +0100
+++ at-3.1.8/atd.8.in 2007-01-30 10:51:51.000000000 +0100
@@ -10,6 +10,7 @@
.IR batch_interval ]
.RB [ -d ]
.RB [ -s ]
+.RB [ -n ]
.SH DESCRIPTION
.B atd
runs jobs queued by
@@ -46,6 +47,9 @@
is installed as
.B @prefix@/sbin/atrun
for backward compatibility.
+.TP 8
+.B -n
+Don't fork option.
.SH WARNING
.B atd
won't work if its spool directory is mounted via NFS even if