Re: [AD] Windows unicode filename support |
[ Thread Index |
Date Index
| More lists.liballeg.org/allegro-developers Archives
]
- To: alleg-developers@xxxxxxxxxx
- Subject: Re: [AD] Windows unicode filename support
- From: Chris <chris.kcat@xxxxxxxxxx>
- Date: Sun, 30 Apr 2006 16:10:06 -0700
- Domainkey-signature: a=rsa-sha1; q=dns; c=nofws; s=beta; d=gmail.com; h=received:from:to:subject:date:user-agent:references:in-reply-to:mime-version:content-type:content-transfer-encoding:content-disposition:message-id; b=uTJ+Z4ST8+CpgwJ9tx90N5XgVwAE/ozikE1wqOL8eS+E9rqIyUhXk+nXW/qIzJCCxkn+djks4/+v3vrrgP2LV8xPYUntPQFEoBCppfqMOItcvBjcjkp1FLKnloQw87OTh4NC/suKEmrNjppEn4SdzGbSa5aPE5U13sp31ZwluNQ=
On Sunday 30 April 2006 15:34, Michal Molhanec wrote:
> Chris napsal(a):
> > Leave it to Windows to supply older systems with functions that don't do
> > anything for forwards "compatibility". Here's an alternative that uses
> > the original _stat/_findfirst/etc, but passes it UTF-8 data instead. I
> > doubt it'll work with the extended chars in Win9x (where I don't think
> > they can have extended chars), but hopefully it'll work in WinNT/2K/XP.
> > Can anyone test if it works properly with files that use extended
> > characters? If not, then I guess I'll either figure something else out.
>
> This patch makes no sense. ANSI Windows function expects strings in ANSI
> charset, not in UTF-8, so this patch does not work anywhere on Windows.
UTF-8 is fully compatible with 7-bit ASCII, so only characters with a value
greater than 127 will be affected. And since Allegro was converting it all to
ASCII before, nothing is lost from previous versions.
> If you really (but IMHO it's not important for a game library) want to
> it correctly, convert it to U_UNICODE and the result pass to the
> WideCharToMultiByte with first parameter CP_ACP and then the result pass
> to the _stat & co. functions
Isn't that basically what Allegro's convert functions already do? I don't
think using code pages is particularly right in this day and age, now that we
have Unicode. And given that coders aren't always native English speakers,
it'd be nice to assume they may want to use non-English filenames.