delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/2001/07/04/21:09:37

Mailing-List: contact cygwin-help AT sourceware DOT cygnus DOT com; run by ezmlm
List-Subscribe: <mailto:cygwin-subscribe AT sources DOT redhat DOT com>
List-Archive: <http://sources.redhat.com/ml/cygwin/>
List-Post: <mailto:cygwin AT sources DOT redhat DOT com>
List-Help: <mailto:cygwin-help AT sources DOT redhat DOT com>, <http://sources.redhat.com/ml/#faqs>
Sender: cygwin-owner AT sources DOT redhat DOT com
Delivered-To: mailing list cygwin AT sources DOT redhat DOT com
Message-ID: <3B43BE40.8040001@ece.gatech.edu>
Date: Wed, 04 Jul 2001 21:09:20 -0400
From: "Charles S. Wilson" <cwilson AT ece DOT gatech DOT edu>
User-Agent: Mozilla/5.0 (Windows; U; WinNT4.0; en-US; rv:0.9.1) Gecko/20010607 Netscape6/6.1b1
X-Accept-Language: en-us
MIME-Version: 1.0
To: Linus Tolke Y <linus AT lysator DOT liu DOT se>
CC: cygwin AT cygwin DOT com
Subject: Re: Confused by gettext on cygwin
References: <200107042249 DOT AAA26080 AT sandra DOT lysator DOT liu DOT se>

This is a good question, but it should be on list.  I've redirected this 
email to the list.  See below for commentary.

Linus Tolke Y wrote:

> Hi there!
> 
> I have a couple of hobby projects that I am trying to run with the gnu 
> tools (autoconf, automake, gettext...) to learn these tools. 
> 
> This week I tried to move the developing environment from Linux to
> cygwin since I don't have Linux installed on my laptop.
> 
> After checking out my project from cvs I run the gettextize command to
> get all the intl-files in place and what confused me was that the
> result of the gettextize command was different in Linux and in cygwin.
> Looking at the file intl/gettext.h that was created by gettextize, the
> file created in cygwin included some stuff within 
> #if defined(__CYGWIN__)
> #endif
> The version of gettextize was the same on both the cygwin and Linux
> systems.
> [lyskom AT linus intl]$ gettextize --version
> /usr/bin/gettextize (GNU gettext) 0.10.35
> Copyright (C) 1996, 1997, 1998 Free Software Foundation, Inc.
> This is free software; see the source for copying conditions.  There is NO
> warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR
> PURPOSE.
> Written by Ulrich Drepper
> [lyskom AT linus intl]$
> 
> What is the purpose of modifying these files for cygwin in this way?


Well, the gettext.h created by gettextize is made as a copy of a special 
gettext.h stored in /usr/share/gettext/intl/.  During my build process 
for cygwin, the /usr/share/gettext/intl/gettext.h file is created 
identical to the system gettext.h in /usr/include.  So, if the system 
file is different from some baseline, then the created file will also be 
different.

It was necessary to modify gettext.h on cygwin to support using the 
braindead windows shared library format (DLLs).  Functions and variables 
must be declared with special compile-time directives 
(__declspec(dllimport), __declspec(dllexport)) -- thus, the headers must 
be modified.

Now, I have corresponded with the "real" gettext people about this. 
Their response is that these changes are just too damn ugly to 
incorporate -- and there MAY be upcoming changes to GCC and binutils so 
that cygwin no longer requires this uglification.  Therefore, those guys 
are taking a wait-and-see approach.  We all hope that the uglification 
goes away at some point.

> I thought that the purpose of the created files were to generate them
> exactly in the same way independantly of what system they were
> generated on. The are probably not compiled on that system anyway.
> 
> What is it about gettext that I have missunderstood?


Nothing.

If you merely want to gettextize a package that will be built on another 
platform, or will be built on cygwin ALWAYS using the 
--with-included-gettext (that is, you'll never use the cygwin system 
libintl.a with your package), then just

copy the "linux" or "official" gettext.h into /usr/share/gettext/intl on 
your cygwin system.  In fact, that may not be a bad idea in ALL cases, 
because if somebody builds your package on cygwin and DOESN't specify 
--with-included-gettext, then the build will use the 
/usr/include/gettext.h and /usr/lib/libintl.a -- so no problems: your 
"official" gettextized gettext.h won't even get used in that case.

Hmmm...perhaps the cygwin gettext package should put the official 
gettext.h into /usr/share/gettext/intl, and only use the modified, 
DLL-supporting gettext.h for /usr/include...

--Chuck



--
Unsubscribe info:      http://cygwin.com/ml/#unsubscribe-simple
Bug reporting:         http://cygwin.com/bugs.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