I've tried the test with winelib and got:
$ winegcc test.c
$ ./a.out > nya
$ od -x nya
0000000 3f3f 3f3f 3f3f 3f3f 0066
0000011
This output differs from previous. I tried this under several locales, the
results are the same.
When I applied the patch, EXE version (I used mingw32 instead of VC 6), works
OK, but no changes with winelib. Buggy winegcc???
Next test.
Here I use localized strings.
#include <windows.h>
void main() {
/* "Это тест" ("this is a test" in Russian) */
WCHAR russtr[]={0x044d, 0x0442, 0x043e,
0x0020, 0x0442, 0x0435,
0x0441, 0x0442, 0x0000};
wprintf(L"test with wprintf");
wprintf(russtr);
}
Result of mingw32-gcc version:
0000000 6574 7473 7720 7469 2068 7077 6972 746e
0000020 fd66 eef2 f220 f1e5 00f2
0000031
The localized string has been written in cp1251.
The results are the same "wine cmd a.exe" and "wine /k a.exe".
winconsole --backend=user does not work.
The same test under windows (mingw32 version): Only "test with wprintf" has
been printed.
No localized string. Mystic? Wine works, but windows does not???
Under simple "wine cmd /k ..." windows programs and wine produce the same
output (now). Under wineconsole embedded cmd commands like 'help' still does
not work. Windows The Native Ones - works OK. I suspect we output them in the
wrong way.
Thus, the bug where xcopy was writing out characters padded with gaps is
fixed,
but invalid codepage bug is still present. pf_vsnprintf is buggy??? (yes, it
sounds blasphemic, but it is the one thing I can imagine).
Thanks a lot!
--
Kirill