Mailing-List: contact cygwin-help AT cygwin DOT com; run by ezmlm List-Subscribe: List-Archive: List-Post: List-Help: , Sender: cygwin-owner AT cygwin DOT com Mail-Followup-To: cygwin AT cygwin DOT com Delivered-To: mailing list cygwin AT cygwin DOT com X-Authentication-Warning: localhost.localdomain: ronald owned process doing -bs Date: Tue, 10 Jun 2003 11:18:38 +0200 (CEST) From: Ronald Landheer-Cieslak X-X-Sender: ronald AT localhost DOT localdomain To: cygwin AT cygwin DOT com Subject: Re: Slight patch for Cron In-Reply-To: <20030606071907.GA12547@cygbert.vinschen.de> Message-ID: MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Works like a charm :) Thanks! rlc On Fri, 6 Jun 2003, Corinna Vinschen wrote: > On Thu, Jun 05, 2003 at 01:01:19PM +0200, Ronald Landheer-Cieslak wrote: > > On Wed, 4 Jun 2003, Corinna Vinschen wrote: > > > On Wed, Jun 04, 2003 at 09:53:05AM +0200, Ronald Landheer-Cieslak wrote: > > > > On Tue, 3 Jun 2003, Corinna Vinschen wrote: > > > > > Does it help to set CYGWIN=notty before starting cron? > > > > Apparently not, no. > > > > > > > > Because I'm starting cron from the "startup" part of the start menu, I had > > > > to run it from a batch file ( > > > > set CYGWIN=notty > > > > cron.exe > > > > ) but I don't think that should make a difference. > > > Could you just for fun add a call to RegisterServiceProcess() (that > > > works on 9x/Me only) right before the setsid() call in the child code > > > and try again? > > I'd love to, but I have a Windows NT/4 box and thus don't have > > RegisterServiceProcess() (Windows NT Ver 4.0 Build 1381 Service Pack 6, as > > per cygcheck output attached to a previous message). > > As it seems to turn out, it's a problem in cron, not in Cygwin. What > you see is not the parent not being able to exit, it's the child which > has open console descriptors and so keeping the console open. If you > then try to close the console forcefully, you kill the child. > > Please apply the following patch to cron and report back whether cron > does for you what it's supposed to do (parent leaves, window can be > closed, cron still processes files), or not. > > Your positive feedback will trigger a new cron version asap :-) > > Thanks, > Corinna > > Index: cron.c > =================================================================== > RCS file: /home/cvs/cvsroot/src/cron/cron.c,v > retrieving revision 1.5 > diff -p -u -r1.5 cron.c > --- cron.c 11 Apr 2003 19:42:37 -0000 1.5 > +++ cron.c 6 Jun 2003 07:13:17 -0000 > @@ -26,6 +26,7 @@ static const char rcsid[] = "$Id: cron.c > #include "cron.h" > #ifdef __CYGWIN__ > #include > +#include > #else > #include > #endif > @@ -115,6 +116,21 @@ main(argc, argv) > } > > acquire_daemonlock(0); > + > +#ifdef __CYGWIN__ > + { > + int fd; > + if ((fd = open("/dev/null", O_RDWR, 0)) != -1) > + { > + (void)dup2(fd, STDIN_FILENO); > + (void)dup2(fd, STDOUT_FILENO); > + (void)dup2(fd, STDERR_FILENO); > + if (fd > 2) > + (void)close (fd); > + } > + } > +#endif > + > database.head = NULL; > database.tail = NULL; > database.mtime = (time_t) 0; > > -- Unsubscribe info: http://cygwin.com/ml/#unsubscribe-simple Problem reports: http://cygwin.com/problems.html Documentation: http://cygwin.com/docs.html FAQ: http://cygwin.com/faq/