d83c6e
diff -up at-3.1.18/atd.c.noabort at-3.1.18/atd.c
d83c6e
--- at-3.1.18/atd.c.noabort	2016-03-23 12:49:15.147520116 +0100
d83c6e
+++ at-3.1.18/atd.c	2016-03-23 12:49:15.148520138 +0100
d83c6e
@@ -349,9 +349,12 @@ run_file(const char *filename, uid_t uid
d83c6e
      */
d83c6e
 
d83c6e
     pid = fork();
d83c6e
-    if (pid == -1)
d83c6e
-	perr("Cannot fork");
d83c6e
-
d83c6e
+    if (pid == -1) {
d83c6e
+	lerr("Cannot fork for job execution");
d83c6e
+	free(mailname);
d83c6e
+	free(newname);
d83c6e
+	return;
d83c6e
+    }
d83c6e
     else if (pid != 0) {
d83c6e
 	free(mailname);
d83c6e
 	free(newname);
d83c6e
@@ -669,15 +672,19 @@ run_loop()
d83c6e
      * up.
d83c6e
      */
d83c6e
 
d83c6e
-    if (stat(".", &buf) == -1)
d83c6e
-	perr("Cannot stat " ATJOB_DIR);
d83c6e
+    if (stat(".", &buf) == -1) {
d83c6e
+	lerr("Cannot stat " ATJOB_DIR);
d83c6e
+        return next_job;
d83c6e
+    }
d83c6e
 
d83c6e
     if (nothing_to_do && buf.st_mtime <= last_chg)
d83c6e
 	return next_job;
d83c6e
     last_chg = buf.st_mtime;
d83c6e
 
d83c6e
-    if ((spool = opendir(".")) == NULL)
d83c6e
-	perr("Cannot read " ATJOB_DIR);
d83c6e
+    if ((spool = opendir(".")) == NULL) {
d83c6e
+	lerr("Cannot read " ATJOB_DIR);
d83c6e
+        return next_job;
d83c6e
+    }
d83c6e
 
d83c6e
     run_batch = 0;
d83c6e
     nothing_to_do = 1;