Commit 4deb599d authored by Piotr Caban's avatar Piotr Caban Committed by Alexandre Julliard

msvcp90: Use wide-char string literals.

parent 0237785d
...@@ -3198,21 +3198,20 @@ MSVCP_bool __thiscall basic_filebuf_char_is_open(const basic_filebuf_char *this) ...@@ -3198,21 +3198,20 @@ MSVCP_bool __thiscall basic_filebuf_char_is_open(const basic_filebuf_char *this)
/* ?_Fiopen@std@@YAPEAU_iobuf@@PEB_WHH@Z */ /* ?_Fiopen@std@@YAPEAU_iobuf@@PEB_WHH@Z */
FILE* __cdecl _Fiopen_wchar(const wchar_t *name, int mode, int prot) FILE* __cdecl _Fiopen_wchar(const wchar_t *name, int mode, int prot)
{ {
static const wchar_t rW[] = {'r',0};
static const struct { static const struct {
int mode; int mode;
const wchar_t str[4]; const wchar_t str[4];
const wchar_t str_bin[4]; const wchar_t str_bin[4];
} str_mode[] = { } str_mode[] = {
{OPENMODE_out, {'w',0}, {'w','b',0}}, {OPENMODE_out, L"w", L"wb"},
{OPENMODE_out|OPENMODE_app, {'a',0}, {'a','b',0}}, {OPENMODE_out|OPENMODE_app, L"a", L"ab"},
{OPENMODE_app, {'a',0}, {'a','b',0}}, {OPENMODE_app, L"a", L"ab"},
{OPENMODE_out|OPENMODE_trunc, {'w',0}, {'w','b',0}}, {OPENMODE_out|OPENMODE_trunc, L"w", L"wb"},
{OPENMODE_in, {'r',0}, {'r','b',0}}, {OPENMODE_in, L"r", L"rb"},
{OPENMODE_in|OPENMODE_out, {'r','+',0}, {'r','+','b',0}}, {OPENMODE_in|OPENMODE_out, L"r+", L"r+b"},
{OPENMODE_in|OPENMODE_out|OPENMODE_trunc, {'w','+',0}, {'w','+','b',0}}, {OPENMODE_in|OPENMODE_out|OPENMODE_trunc, L"w+", L"w+b"},
{OPENMODE_in|OPENMODE_out|OPENMODE_app, {'a','+',0}, {'a','+','b',0}}, {OPENMODE_in|OPENMODE_out|OPENMODE_app, L"a+", L"a+b"},
{OPENMODE_in|OPENMODE_app, {'a','+',0}, {'a','+','b',0}} {OPENMODE_in|OPENMODE_app, L"a+", L"a+b"}
}; };
int real_mode = mode & ~(OPENMODE_ate|OPENMODE__Nocreate|OPENMODE__Noreplace|OPENMODE_binary); int real_mode = mode & ~(OPENMODE_ate|OPENMODE__Nocreate|OPENMODE__Noreplace|OPENMODE_binary);
...@@ -3227,13 +3226,13 @@ FILE* __cdecl _Fiopen_wchar(const wchar_t *name, int mode, int prot) ...@@ -3227,13 +3226,13 @@ FILE* __cdecl _Fiopen_wchar(const wchar_t *name, int mode, int prot)
if(mode_idx == ARRAY_SIZE(str_mode)) if(mode_idx == ARRAY_SIZE(str_mode))
return NULL; return NULL;
if((mode & OPENMODE__Nocreate) && !(f = _wfopen(name, rW))) if((mode & OPENMODE__Nocreate) && !(f = _wfopen(name, L"r")))
return NULL; return NULL;
else if(f) else if(f)
fclose(f); fclose(f);
if((mode & OPENMODE__Noreplace) && (mode & (OPENMODE_out|OPENMODE_app)) if((mode & OPENMODE__Noreplace) && (mode & (OPENMODE_out|OPENMODE_app))
&& (f = _wfopen(name, rW))) { && (f = _wfopen(name, L"r"))) {
fclose(f); fclose(f);
return NULL; return NULL;
} }
...@@ -14959,9 +14958,6 @@ void* __cdecl tr2_sys__Open_dir_wchar(wchar_t* target, wchar_t const* dest, int* ...@@ -14959,9 +14958,6 @@ void* __cdecl tr2_sys__Open_dir_wchar(wchar_t* target, wchar_t const* dest, int*
HANDLE handle; HANDLE handle;
WIN32_FIND_DATAW data; WIN32_FIND_DATAW data;
wchar_t temppath[MAX_PATH]; wchar_t temppath[MAX_PATH];
static const wchar_t dot[] = {'.', 0};
static const wchar_t dotdot[] = {'.', '.', 0};
static const wchar_t asterisk[] = {'\\', '*', 0};
TRACE("(%p %s %p %p)\n", target, debugstr_w(dest), err_code, type); TRACE("(%p %s %p %p)\n", target, debugstr_w(dest), err_code, type);
if(wcslen(dest) > MAX_PATH - 3) { if(wcslen(dest) > MAX_PATH - 3) {
...@@ -14970,7 +14966,7 @@ void* __cdecl tr2_sys__Open_dir_wchar(wchar_t* target, wchar_t const* dest, int* ...@@ -14970,7 +14966,7 @@ void* __cdecl tr2_sys__Open_dir_wchar(wchar_t* target, wchar_t const* dest, int*
return NULL; return NULL;
} }
wcscpy(temppath, dest); wcscpy(temppath, dest);
wcscat(temppath, asterisk); wcscat(temppath, L"\\*");
handle = FindFirstFileW(temppath, &data); handle = FindFirstFileW(temppath, &data);
if(handle == INVALID_HANDLE_VALUE) { if(handle == INVALID_HANDLE_VALUE) {
...@@ -14978,7 +14974,7 @@ void* __cdecl tr2_sys__Open_dir_wchar(wchar_t* target, wchar_t const* dest, int* ...@@ -14978,7 +14974,7 @@ void* __cdecl tr2_sys__Open_dir_wchar(wchar_t* target, wchar_t const* dest, int*
*target = '\0'; *target = '\0';
return NULL; return NULL;
} }
while(!wcscmp(data.cFileName, dot) || !wcscmp(data.cFileName, dotdot)) { while(!wcscmp(data.cFileName, L".") || !wcscmp(data.cFileName, L"..")) {
if(!FindNextFileW(handle, &data)) { if(!FindNextFileW(handle, &data)) {
*err_code = ERROR_SUCCESS; *err_code = ERROR_SUCCESS;
*type = status_unknown; *type = status_unknown;
...@@ -15026,8 +15022,6 @@ void* __cdecl tr2_sys__Open_dir(char* target, char const* dest, int* err_code, e ...@@ -15026,8 +15022,6 @@ void* __cdecl tr2_sys__Open_dir(char* target, char const* dest, int* err_code, e
wchar_t* __cdecl tr2_sys__Read_dir_wchar(wchar_t* target, void* handle, enum file_type* type) wchar_t* __cdecl tr2_sys__Read_dir_wchar(wchar_t* target, void* handle, enum file_type* type)
{ {
WIN32_FIND_DATAW data; WIN32_FIND_DATAW data;
static const wchar_t dot[] = {'.', 0};
static const wchar_t dotdot[] = {'.', '.', 0};
TRACE("(%p %p %p)\n", target, handle, type); TRACE("(%p %p %p)\n", target, handle, type);
...@@ -15037,7 +15031,7 @@ wchar_t* __cdecl tr2_sys__Read_dir_wchar(wchar_t* target, void* handle, enum fil ...@@ -15037,7 +15031,7 @@ wchar_t* __cdecl tr2_sys__Read_dir_wchar(wchar_t* target, void* handle, enum fil
*target = '\0'; *target = '\0';
return target; return target;
} }
} while(!wcscmp(data.cFileName, dot) || !wcscmp(data.cFileName, dotdot)); } while(!wcscmp(data.cFileName, L".") || !wcscmp(data.cFileName, L".."));
wcscpy(target, data.cFileName); wcscpy(target, data.cFileName);
if(data.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY) if(data.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY)
......
...@@ -2287,10 +2287,8 @@ const wchar_t* __thiscall basic_string_wchar_const_ptr(const basic_string_wchar ...@@ -2287,10 +2287,8 @@ const wchar_t* __thiscall basic_string_wchar_const_ptr(const basic_string_wchar
DEFINE_THISCALL_WRAPPER(basic_string_wchar_eos, 8) DEFINE_THISCALL_WRAPPER(basic_string_wchar_eos, 8)
void __thiscall basic_string_wchar_eos(basic_string_wchar *this, size_t len) void __thiscall basic_string_wchar_eos(basic_string_wchar *this, size_t len)
{ {
static const wchar_t nullbyte_w = '\0';
this->size = len; this->size = len;
MSVCP_char_traits_wchar_assign(basic_string_wchar_ptr(this)+len, &nullbyte_w); MSVCP_char_traits_wchar_assign(basic_string_wchar_ptr(this)+len, L"");
} }
/* ?_Inside@?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@IAE_NPB_W@Z */ /* ?_Inside@?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@IAE_NPB_W@Z */
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment