AFAIK SetThreadLocale
does not change the current system Code Page, so won't affect the widestring
to ansistring
conversion in Delphi 7, which rely on GetACP
API call, i.e. the system Code Page.
The system Code Page is set e.g. in Windows Seven in the Control Panel, then Region Languages / Administrative tab / Code Page for non Unicode Applications. This needs a system restart.
Delphi 7 uses this system Code Page, supplying 0 to all conversion API calls. So AFAIR SetThreadLocale
won't affect the widestring
to ansistring
conversion in Delphi 7. It will change the locale (e.g. date/time and currency formatting), not the code page used by the system for its Ansi <-> Unicode conversion.
Newer versions of Delphi have a SetMultiByteConversionCodePage()
function, able to set the code page to be used for all AnsiString
handling.
But API calls (i.e. all ....A()
functions in Windows.pas which are mapped by ...()
in Delphi 7) will use this system code page. So you will have to call the ...W()
wide API after a conversion to Unicode if you want to handle another code page. That is, the Delphi 7 VCL will work only with the system code page, not the value specified by SetThreadLocale
.
Under Delphi 7, my advice is:
- Use
WideString
everywhere, and specific "Wide" API calls - there are several set of components for Delphi 7 which handle WideString
;
- Use your own types, with a dedicated charset, but you'll need an explicit conversion before using the VCL/RTL or "Ansi" API calls - e.g.
MyString = type AnsiString
(this is what we do in mORMot, by defining a custom RawUTF8
type for internal UTF-8 process).
This is much better handled with Delphi 2009 and up, since you can specify a code page to every AnsiString
type, and properly handle conversion to/from Unicode, for API calls or VCL process.
stringVar := wideStringVar;
will work. Second, the problem is that not all WideChars are directly convertible to an AnsiString; some are more than one character in width, and some have character values that are not representable in an AnsiChar, and some fonts don't contain all possible Unicode values. If you're seeing?
, it means you're displaying them, which could be the third problem - threads should not access GUI controls without usingSychronize
. Since you didn't post the display code, it's hard to say if that's it. – Dynamometry?
, you're displaying the text. You've provided zero code or information regarding how you're displaying it. – Dynamometry