delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/2009/03/18/06:09:06

X-Recipient: archive-cygwin AT delorie DOT com
X-SWARE-Spam-Status: No, hits=-1.8 required=5.0 tests=AWL,BAYES_00
X-Spam-Check-By: sourceware.org
Message-ID: <49C0D63C.4040005@sbcglobal.net>
Date: Wed, 18 Mar 2009 11:08:44 +0000
From: Greg Chicares <gchicares AT sbcglobal DOT net>
User-Agent: Thunderbird 2.0.0.19 (Windows/20081209)
MIME-Version: 1.0
To: cygwin AT cygwin DOT com
Subject: Re: _set_fmode?
References: <49C04B2D DOT 2090703 AT cwilson DOT fastmail DOT fm> <20090318094323 DOT GA12824 AT calimero DOT vinschen DOT de>
In-Reply-To: <20090318094323.GA12824@calimero.vinschen.de>
X-IsSubscribed: yes
Mailing-List: contact cygwin-help AT cygwin DOT com; run by ezmlm
List-Id: <cygwin.cygwin.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 2009-03-18 09:43Z, Corinna Vinschen wrote:
> On Mar 17 21:15, Charles Wilson wrote:
>> Is there a cygwin analogue to the msvc _set_fmode()? That is, a function
>> that sets the default mode of fopen, even if you don't explicitly
>> specify it "rb" or whatever.
>> 
>> Obviously, there's "use binary (or text) mounts".  Less obviously, you
>> can link against /usr/lib/binary.o (or -lbinmode), or text.o (or
>> automode.o or textreadmode.o and the similar .a's).  But I'm looking for
>> an actual function call to replace the following code in libarchive:
>> 
>> +#if defined(_WIN32) && !defined(__CYGWIN__)
> 
> The !defined(__CYGWIN__) is not necessary because gcc for Cygwin doesn't
> define _WIN32.
> 
>>    /* Make sure open() function will be used with a binary mode. */
>>    /* on cygwin, we need something similar, but instead link against */
>>    /* a special startup object, binmode.o */
>>    _set_fmode(_O_BINARY);
>>  #endif
>> 
>> I'm using binmode.o at present, but I'd prefer to just make a func call
>> at the same place the WIN32-specific code does.  (FWIW, you can't call
>> the w32api _set_fmode() function and expect it to work; the msvc runtime
>> and cygwin maintain different default _fmode variables).
> 
> Cygwin has no such function call except for the per-descriptor function
> setmode (fd, mode).  IMHO using binmode.o is much more elegant.  The
> only other choice you have is this:
> 
>   extern int _fmode;
>   _fmode = O_BINARY;
> 
> _fmode is defined in crt0.o so you can simply access it if you like.
> But anyway, using binmode.o is much more elegant, IMHO.  I don't see
> what speaks against using it.

If a drop-in replacement for _set_fmode() is nonetheless still wanted,
then _mingw32_init_fmode() here:
  http://cygwin.com/cgi-bin/cvsweb.cgi/src/winsup/mingw/crt1.c?cvsroot=src
might provide ideas for implementing it (or reasons to avoid it: for
example, standard streams would already have been opened before such a
function could be called).

An alternative that keeps all toolchains working the same way is to
link with 'binmode.o' for Cygwin, and 'Binmode.obj' for msvc:
  http://msdn.microsoft.com/en-us/library/ee2849wt(VS.80).aspx
if it's acceptable to change the upstream package.

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