delorie.com/archives/browse.cgi | search |
X-Spam-Check-By: | sourceware.org |
Date: | Sun, 9 Apr 2006 21:34:15 -0400 |
From: | Christopher Faylor <cgf-no-personal-reply-please AT cygwin DOT com> |
To: | cygwin AT cygwin DOT com |
Subject: | Cygwin backwards compatibility break with WinMain and GetCommandLine (was Re: WinMain() not getting cl...) |
Message-ID: | <20060410013414.GA20557@trixie.casa.cgf.cx> |
Reply-To: | cygwin AT cygwin DOT com |
Mail-Followup-To: | cygwin AT cygwin DOT com |
References: | <20060404184447 DOT GA4824 AT tela DOT daveroth DOT dyndns DOT org> |
Mime-Version: | 1.0 |
In-Reply-To: | <20060404184447.GA4824@tela.daveroth.dyndns.org> |
User-Agent: | Mutt/1.5.11 |
Mailing-List: | contact cygwin-help AT cygwin DOT com; run by ezmlm |
List-Unsubscribe: | <mailto:cygwin-unsubscribe-archive-cygwin=delorie DOT com AT cygwin DOT com> |
List-Subscribe: | <mailto:cygwin-subscribe AT cygwin DOT com> |
List-Archive: | <http://sourceware.org/ml/cygwin/> |
List-Post: | <mailto:cygwin AT cygwin DOT com> |
List-Help: | <mailto:cygwin-help AT cygwin DOT com>, <http://sourceware.org/ml/#faqs> |
Sender: | cygwin-owner AT cygwin DOT com |
Mail-Followup-To: | cygwin AT cygwin DOT com |
Delivered-To: | mailing list cygwin AT cygwin DOT com |
On Tue, Apr 04, 2006 at 11:44:47AM -0700, David Rothenberger wrote: >WinMain() in a program compiled with cygwin1.dll is no longer >getting passed the command-line from bash correctly with the >20060403 snapshot. It works fine with the 20060329 snapshot. > >This is the same problem mentioned in ><http://cygwin.com/ml/cygwin/2005-09/msg00298.html>. > >The same test case is attached here again (winCmdLine.c). I compile >it with "gcc -o winCmdLine winCmdLine.c" (note no -mno-cygwin). This is due to recent changes which cause cygwin to stop filling out the command-line for cygwin1.dll using programs. We did this to fix the "long command line" problem. There is a crude workaround for the problem which reinstates the previous cygwin behavior but I really would rather not go that way. It would be nice if, just this once, we could make cygwin a little faster at the expense of programs which are using a non-linux-like interface. So, I'm thinking that if you want your WinMain or GetCommandLine using program to work with Cygwin 1.5.20 then you'll have to relink it. I realize that this is a major departure from previous stated goal of maintaining backwards compatibility but we've already broken that once in recent memory with the case of pure Windows environment variables so I think we probably will just take the logical next step and break things for WinMain and GetCommandLine as well. If there are a lot of programs out there which are using WinMain or GetCommandLine then I guess we'll hear about it. Otherwise, unless someone can convince me that this is a bad idea, Cygwin will start carrying a GetCommandLine substitute which regenerates the command line from the argv list. I have something ready to go in my sandbox now but I thought I'd hold off doing this in case someone had a valid objection to this approach. 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/
webmaster | delorie software privacy |
Copyright © 2019 by DJ Delorie | Updated Jul 2019 |