Mail Archives: cygwin/2011/12/07/13:07:46
On Dec 7 18:50, Bengt Larsson wrote:
> Corinna Vinschen wrote:
> >On Dec 7 18:00, Bengt Larsson wrote:
> >> Corinna Vinschen wrote:
> >>
> >> >- cygwin_conv_path and cygwin_conv_path_list: In CCP_WIN_A_TO_POSIX and
> >> > CCP_POSIX_TO_WIN_A conversions, use the current Windows ANSI or OEM
> >> > charset, depending on the return value of AreFileApisANSI. Up to Cygwin
> >> > 1.7.9, both conversions used the current Cygwin charset for the conversion.
> >>
> >> Is that the right thing to do? I have LANG=C.UTF-8. If I pass a
> >> Windows-style filename on the command line, it's passed as UTF-8. How do
> >> I then convert that to Unix-style, UTF-8?
> >
> >First of all, don't do that. Use POSIX paths.
> >
> >Second, it's not passed as UTF-8 if the called application is a
> >non-Cygwin application. In fact, Cygwin calls CreateProcessW, so all
> >strings are converted to UTF-16 (aka UNICODE) when starting a non-Cygwin
> >child process.
> >
> >Third, as for Cygwin apps, don't use WIN_A, use WIN_W instead, because
> >that's encoding agnostic:
>
> OK, thanks.
Just so it's clear why I did that, maybe you want to have a look into
the brief discussion on the cygwin-developers list:
http://cygwin.com/ml/cygwin-developers/2011-11/msg00000.html
Basically, apart from external sources, the multibyte Windows paths you
have are either returned from a Windows function, or they are supposed
to be put into a Windows function. Since the multibyte Windows file
access functions use the ANSI or OEM codepage, it makes sense to use the
current ANSI or OEM codepage for the WIN_A conversions as well. But in
fact I agree with Daniel's comment on the list:
http://cygwin.com/ml/cygwin-developers/2011-11/msg00002.html
Corinna
--
Corinna Vinschen Please, send mails regarding Cygwin to
Cygwin Project Co-Leader cygwin AT cygwin DOT com
Red Hat
--
Problem reports: http://cygwin.com/problems.html
FAQ: http://cygwin.com/faq/
Documentation: http://cygwin.com/docs.html
Unsubscribe info: http://cygwin.com/ml/#unsubscribe-simple
- Raw text -