Mailing-List: contact cygwin-help@cygwin.com; run by ezmlm
List-Subscribe: <mailto:cygwin-subscribe@cygwin.com>
List-Archive: <http://sourceware.org/ml/cygwin/>
List-Post: <mailto:cygwin@cygwin.com>
List-Help: <mailto:cygwin-help@cygwin.com>, <http://sourceware.org/ml/#faqs>
Sender: cygwin-owner@cygwin.com
Mail-Followup-To: cygwin@cygwin.com
Delivered-To: mailing list cygwin@cygwin.com
Date: Thu, 8 Jul 2004 10:54:52 -0400
From: Christopher Faylor <cgf-no-personal-reply-please@cygwin.com>
To: cygwin@cygwin.com
Subject: Re: negative error status: gcc vs. cl
Message-ID: <20040708145452.GA14402@trixie.casa.cgf.cx>
Reply-To: cygwin@cygwin.com
Mail-Followup-To: cygwin@cygwin.com
References: <Pine.WNT.4.21.0407081106020.247-100000@pc0197.nagra-kudelski.ch> <20040708100919.GB32001@cygbert.vinschen.de> <Pine.GSO.4.58.0407081018370.11665@slinky.cs.nyu.edu>
Mime-Version: 1.0
Content-Type: text/plain; charset=us-ascii
Content-Disposition: inline
In-Reply-To: <Pine.GSO.4.58.0407081018370.11665@slinky.cs.nyu.edu>
User-Agent: Mutt/1.4.1i

On Thu, Jul 08, 2004 at 10:25:09AM -0400, Igor Pechtchanski wrote:
>On Thu, 8 Jul 2004, Corinna Vinschen wrote:
>
>> On Jul  8 11:49, Daniel Lungu wrote:
>> > Feel like bash tcsh on Cygwin mess up with negative exit status from a cl
>> > compiled .exe
>>
>> The answer is "don't do that".  Use positive values in the range from
>> 0 to 255.  See
>> http://www.opengroup.org/onlinepubs/009695399/functions/exit.html
>
>Actually, it looks like another buglet in Cygwin.  The code in
>spawn_guts() in spawn.cc (line 847 in CVS HEAD) simply binary-ORs the
>exitcode value returned by GetExitCodeProcess with the "res" variable.
>However, the "res" variable is also used to carry some flags, and a
>negative exitcode, being a full DWORD, accidentally sets those, so all
>sorts of havoc can potentially occur (and I'm surprised that all that
>happens is the wrong exit code).

This is not a bug.  A cygwin program can't set a negative exit code.
Only the lower order 16 bits are used.  This is enforced by _exit.

If someone uses ExitProcess in a cygwin program, then well, err...

cgf

--
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/

