www.delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/2004/08/27/15:39:57

Mailing-List: contact cygwin-help AT cygwin DOT com; run by ezmlm
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
To: cygwin AT cygwin DOT com
From: Oliver <oliver DOT schoenborn AT utoronto DOT ca>
Subject: Re: questions about DLL's: .a, .def, and .dll
Date: Fri, 27 Aug 2004 19:39:41 +0000 (UTC)
Lines: 29
Message-ID: <loom.20040827T213303-567@post.gmane.org>
References: <loom DOT 20040827T173827-426 AT post DOT gmane DOT org> <Pine DOT GSO DOT 4 DOT 61 DOT 0408271423560 DOT 6181 AT slinky DOT cs DOT nyu DOT edu>
Mime-Version: 1.0
X-Complaints-To: usenet AT sea DOT gmane DOT org
X-Gmane-NNTP-Posting-Host: main.gmane.org
User-Agent: Loom/3.14 (http://gmane.org/)
X-Loom-IP: 132.246.8.44 (Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0))
X-IsSubscribed: yes

Igor Pechtchanski <pechtcha <at> cs.nyu.edu> writes:

> On Fri, 27 Aug 2004, Oliver wrote:
> 
> > creating a .a file, a .def file, and a .dll file, yet I can
> > build a program that links to, e.g., mylib.dll, with only "-L. -lmylib",
> > *wihtout* having the .def or .a available. So where and when are the .a and
> > .def files needed?
> 
> The newer versions of gcc apparently allow you to link directly to a .dll
> file.  The .def and .a are needed for older versions of gcc, and possibly
> for some other tools.

I guess the .def file might be used if you created your dll in cygwin/mingw but 
are creating your program with VC++ and linking to your non-VC++ dll. (?)

> ...a DLL built with C++ symbols won't be usable from
> other applications that try to call those functions.  The reason you want
> it for DllMain is that the Windows loader will be looking for the unmunged
> name "DllMain".  Are you sure that it's really invoked when the DLL is

Yes. I even tried it on the latest dllhelpers C++ example: just renamed 
dllinit.c to .cc and changed makeit.bat to use g++ instead of gcc, and 
everything still works. Perhaps g++ "knows" to leave DllMain alone? Or perhaps 
the APIENTRY macro that appears just in front of DllMain prevents munging? 

Oliver




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

- Raw text -


  webmaster     delorie software   privacy  
  Copyright © 2019   by DJ Delorie     Updated Jul 2019