Mailing-List: contact cygwin-help@sourceware.cygnus.com; run by ezmlm
List-Unsubscribe: <mailto:cygwin-unsubscribe-archive-cygwin=delorie.com@sourceware.cygnus.com>
List-Subscribe: <mailto:cygwin-subscribe@sourceware.cygnus.com>
List-Archive: <http://sourceware.cygnus.com/ml/cygwin/>
List-Post: <mailto:cygwin@sourceware.cygnus.com>
List-Help: <mailto:cygwin-help@sourceware.cygnus.com>, <http://sourceware.cygnus.com/ml/#faqs>
Sender: cygwin-owner@sourceware.cygnus.com
Delivered-To: mailing list cygwin@sourceware.cygnus.com
From: "Colin Peters" <colinp@ma.kcom.ne.jp>
To: "GNU-win32" <cygwin@sourceware.cygnus.com>
Cc: "Khan Mumit" <khan@xraylith.wisc.edu>, <uf657@victoria.tc.ca>
Subject: RE: mingw32 DLL getting main args? 
Date: Sun, 31 Oct 1999 22:39:29 +0900
Message-ID: <LOBBLDDPANDBNCLMBAGPKEDICCAA.colinp@ma.kcom.ne.jp>
MIME-Version: 1.0
Content-Type: text/plain;
	charset="iso-2022-jp"
Content-Transfer-Encoding: 7bit
X-Priority: 3 (Normal)
X-MSMail-Priority: Normal
X-Mailer: Microsoft Outlook IMO, Build 9.0.2416 (9.0.2910.0)
X-MimeOLE: Produced By Microsoft MimeOLE V4.72.3110.3
Importance: Normal
In-Reply-To: <199910291722.MAA18548@pluto.xraylith.wisc.edu>


Hello Mumit and Danny, I think this one is my fault, but I also think
I have (had?) an excuse. :)

The reason DLLs call getmainargs to parse the command line list
is so that they can provide the MS-like _argc and _argv variables for
access by functions within the DLL. Check init.c, which is #included
(yuck) in dllcrt1.c. If you like you can remove the declarations from
stdlib.h and work up a DLL version of init.c to remove the dependency
of your DLL on the C run-time library. (I suspect this hasn't changed
in Mumit's version, I must admit I only checked my source.)

I suppose the other reason I didn't worry much about this was that I
wasn't expecting people to write much DLL code without calling any
C library functions.

Mumit Khan [mailto:khan@nanotech.wisc.edu] wrote:
> Danny Sinclair <uf657@victoria.tc.ca> writes:
> > Why does a DLL, made with Mumit's mingw32 2.95 release, need to call
> > msvcrt.dll's __getmainargs?
> >
> > When the DLLMainCRTStartup function receives DLL_PROCESS_ATTACH it calls
> > _mingw32_init_mainargs, which then calls __getmainargs. I don't want my
> > DLL to be dynamicly linked to msvcrt.dll, but it is because of this. Why
> > does a DLL need to parse the command line?
> >
>
> Good point. I don't know why it's done that way (it was there when I first
> used it). MSVC does not seem to do this, but DLLs created with MSVC are
> linked dynamically to MSVCRT.DLL (if you have /MD). I'll do some checking,
> and remove the getmainargs if it's not needed.

Cheers,
Colin.


--
Want to unsubscribe from this list?
Send a message to cygwin-unsubscribe@sourceware.cygnus.com

