[WINESYNC] dbghelp: Use the ARRAY_SIZE() macro.

Signed-off-by: Michael Stefaniuc <mstefani@winehq.org>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>

wine commit id 053a7e225c8190fd7416b3f3c3186f1ac230eeb3 by Michael Stefaniuc <mstefani@winehq.org>
This commit is contained in:
winesync 2020-09-11 13:16:15 +02:00 committed by Jérôme Gardou
parent d3247b3f59
commit 4e89603929
11 changed files with 27 additions and 31 deletions

View file

@ -113,6 +113,7 @@ INT __WideCharToMultiByte( UINT page, DWORD flags, LPCWSTR src, INT srclen, LPST
// #define toupperW(n) towupper((n)) // #define toupperW(n) towupper((n))
// winnt.h // winnt.h
# define ARRAY_SIZE(x) (sizeof(x) / sizeof((x)[0]))
#define IMAGE_FILE_MACHINE_ARMNT 0x1c4 #define IMAGE_FILE_MACHINE_ARMNT 0x1c4
#define IMAGE_FILE_MACHINE_POWERPC 0x1f0 #define IMAGE_FILE_MACHINE_POWERPC 0x1f0
#define IMAGE_FILE_MACHINE_ARM64 0xaa64 #define IMAGE_FILE_MACHINE_ARM64 0xaa64

View file

@ -458,7 +458,7 @@ static BOOL i386_stack_walk(struct cpu_stack_walk* csw, LPSTACKFRAME64 frame, CO
* work if the parameter is in fact bigger than 16bit, but * work if the parameter is in fact bigger than 16bit, but
* there's no way to know that here * there's no way to know that here
*/ */
for (i = 0; i < sizeof(frame->Params) / sizeof(frame->Params[0]); i++) for (i = 0; i < ARRAY_SIZE(frame->Params); i++)
{ {
sw_read_mem(csw, p + (2 + i) * sizeof(WORD), &val16, sizeof(val16)); sw_read_mem(csw, p + (2 + i) * sizeof(WORD), &val16, sizeof(val16));
frame->Params[i] = val16; frame->Params[i] = val16;
@ -491,7 +491,7 @@ static BOOL i386_stack_walk(struct cpu_stack_walk* csw, LPSTACKFRAME64 frame, CO
frame->AddrReturn.Mode = AddrModeFlat; frame->AddrReturn.Mode = AddrModeFlat;
frame->AddrReturn.Offset = newctx.Eip; frame->AddrReturn.Offset = newctx.Eip;
#endif #endif
for (i = 0; i < sizeof(frame->Params) / sizeof(frame->Params[0]); i++) for (i = 0; i < ARRAY_SIZE(frame->Params); i++)
{ {
sw_read_mem(csw, frame->AddrFrame.Offset + (2 + i) * sizeof(DWORD), &val32, sizeof(val32)); sw_read_mem(csw, frame->AddrFrame.Offset + (2 + i) * sizeof(DWORD), &val32, sizeof(val32));
frame->Params[i] = val32; frame->Params[i] = val32;

View file

@ -257,9 +257,8 @@ static BOOL WINAPI process_invade_cb(PCWSTR name, ULONG64 base, ULONG size, PVOI
WCHAR tmp[MAX_PATH]; WCHAR tmp[MAX_PATH];
HANDLE hProcess = user; HANDLE hProcess = user;
if (!GetModuleFileNameExW(hProcess, (HMODULE)(DWORD_PTR)base, if (!GetModuleFileNameExW(hProcess, (HMODULE)(DWORD_PTR)base, tmp, ARRAY_SIZE(tmp)))
tmp, sizeof(tmp) / sizeof(WCHAR))) lstrcpynW(tmp, name, ARRAY_SIZE(tmp));
lstrcpynW(tmp, name, sizeof(tmp) / sizeof(WCHAR));
SymLoadModuleExW(hProcess, 0, tmp, name, base, size, NULL, 0); SymLoadModuleExW(hProcess, 0, tmp, name, base, size, NULL, 0);
return TRUE; return TRUE;

View file

@ -974,7 +974,7 @@ static BOOL elf_locate_debug_link(struct image_file_map* fmap, const char* filen
{ {
static const WCHAR globalDebugDirW[] = {'/','u','s','r','/','l','i','b','/','d','e','b','u','g','/'}; static const WCHAR globalDebugDirW[] = {'/','u','s','r','/','l','i','b','/','d','e','b','u','g','/'};
static const WCHAR dotDebugW[] = {'.','d','e','b','u','g','/'}; static const WCHAR dotDebugW[] = {'.','d','e','b','u','g','/'};
const size_t globalDebugDirLen = sizeof(globalDebugDirW) / sizeof(WCHAR); const size_t globalDebugDirLen = ARRAY_SIZE(globalDebugDirW);
size_t filename_len; size_t filename_len;
WCHAR* p = NULL; WCHAR* p = NULL;
WCHAR* slash; WCHAR* slash;
@ -999,7 +999,7 @@ static BOOL elf_locate_debug_link(struct image_file_map* fmap, const char* filen
/* testing execdir/.debug/filename */ /* testing execdir/.debug/filename */
memcpy(slash, dotDebugW, sizeof(dotDebugW)); memcpy(slash, dotDebugW, sizeof(dotDebugW));
MultiByteToWideChar(CP_UNIXCP, 0, filename, -1, slash + sizeof(dotDebugW) / sizeof(WCHAR), filename_len); MultiByteToWideChar(CP_UNIXCP, 0, filename, -1, slash + ARRAY_SIZE(dotDebugW), filename_len);
if (elf_check_debug_link(p, fmap_link, crc)) goto found; if (elf_check_debug_link(p, fmap_link, crc)) goto found;
/* testing globaldebugdir/execdir/filename */ /* testing globaldebugdir/execdir/filename */
@ -1049,9 +1049,9 @@ static BOOL elf_locate_build_id_target(struct image_file_map* fmap, const BYTE*
(idlen * 2 + 1) * sizeof(WCHAR) + sizeof(dotDebug0W)); (idlen * 2 + 1) * sizeof(WCHAR) + sizeof(dotDebug0W));
z = p; z = p;
memcpy(z, globalDebugDirW, sizeof(globalDebugDirW)); memcpy(z, globalDebugDirW, sizeof(globalDebugDirW));
z += sizeof(globalDebugDirW) / sizeof(WCHAR); z += ARRAY_SIZE(globalDebugDirW);
memcpy(z, buildidW, sizeof(buildidW)); memcpy(z, buildidW, sizeof(buildidW));
z += sizeof(buildidW) / sizeof(WCHAR); z += ARRAY_SIZE(buildidW);
if (id < idend) if (id < idend)
{ {
@ -1694,8 +1694,7 @@ static BOOL elf_enum_modules_internal(const struct process* pcs,
ReadProcessMemory(pcs->handle, lm.l_name, bufstr, sizeof(bufstr), NULL)) ReadProcessMemory(pcs->handle, lm.l_name, bufstr, sizeof(bufstr), NULL))
{ {
bufstr[sizeof(bufstr) - 1] = '\0'; bufstr[sizeof(bufstr) - 1] = '\0';
MultiByteToWideChar(CP_UNIXCP, 0, bufstr, -1, bufstrW, MultiByteToWideChar(CP_UNIXCP, 0, bufstr, -1, bufstrW, ARRAY_SIZE(bufstrW));
sizeof(bufstrW) / sizeof(WCHAR));
if (main_name && !bufstrW[0]) strcpyW(bufstrW, main_name); if (main_name && !bufstrW[0]) strcpyW(bufstrW, main_name);
if (!cb(bufstrW, (unsigned long)lm.l_addr, (unsigned long)lm.l_ld, FALSE, user)) if (!cb(bufstrW, (unsigned long)lm.l_addr, (unsigned long)lm.l_ld, FALSE, user))
break; break;
@ -1729,8 +1728,7 @@ static BOOL elf_enum_modules_internal(const struct process* pcs,
bufstr, sizeof(bufstr), NULL)) bufstr, sizeof(bufstr), NULL))
{ {
bufstr[sizeof(bufstr) - 1] = '\0'; bufstr[sizeof(bufstr) - 1] = '\0';
MultiByteToWideChar(CP_UNIXCP, 0, bufstr, -1, bufstrW, MultiByteToWideChar(CP_UNIXCP, 0, bufstr, -1, bufstrW, ARRAY_SIZE(bufstrW));
sizeof(bufstrW) / sizeof(WCHAR));
if (main_name && !bufstrW[0]) strcpyW(bufstrW, main_name); if (main_name && !bufstrW[0]) strcpyW(bufstrW, main_name);
if (!cb(bufstrW, (unsigned long)lm.l_addr, (unsigned long)lm.l_ld, FALSE, user)) if (!cb(bufstrW, (unsigned long)lm.l_addr, (unsigned long)lm.l_ld, FALSE, user))
break; break;

View file

@ -1672,7 +1672,7 @@ static BOOL macho_enum_modules_internal(const struct process* pcs,
{ {
bufstr[sizeof(bufstr) - 1] = '\0'; bufstr[sizeof(bufstr) - 1] = '\0';
TRACE("[%d] image file %s\n", i, debugstr_a(bufstr)); TRACE("[%d] image file %s\n", i, debugstr_a(bufstr));
MultiByteToWideChar(CP_UNIXCP, 0, bufstr, -1, bufstrW, sizeof(bufstrW) / sizeof(WCHAR)); MultiByteToWideChar(CP_UNIXCP, 0, bufstr, -1, bufstrW, ARRAY_SIZE(bufstrW));
if (main_name && !bufstrW[0]) strcpyW(bufstrW, main_name); if (main_name && !bufstrW[0]) strcpyW(bufstrW, main_name);
if (!cb(bufstrW, (unsigned long)info_array[i].imageLoadAddress, user)) break; if (!cb(bufstrW, (unsigned long)info_array[i].imageLoadAddress, user)) break;
} }

View file

@ -215,9 +215,9 @@ static BOOL add_module(struct dump_context* dc, const WCHAR* name,
if (is_elf || if (is_elf ||
!GetModuleFileNameExW(dc->hProcess, (HMODULE)(DWORD_PTR)base, !GetModuleFileNameExW(dc->hProcess, (HMODULE)(DWORD_PTR)base,
dc->modules[dc->num_modules].name, dc->modules[dc->num_modules].name,
sizeof(dc->modules[dc->num_modules].name) / sizeof(WCHAR))) ARRAY_SIZE(dc->modules[dc->num_modules].name)))
lstrcpynW(dc->modules[dc->num_modules].name, name, lstrcpynW(dc->modules[dc->num_modules].name, name,
sizeof(dc->modules[dc->num_modules].name) / sizeof(WCHAR)); ARRAY_SIZE(dc->modules[dc->num_modules].name));
dc->modules[dc->num_modules].base = base; dc->modules[dc->num_modules].base = base;
dc->modules[dc->num_modules].size = size; dc->modules[dc->num_modules].size = size;
dc->modules[dc->num_modules].timestamp = timestamp; dc->modules[dc->num_modules].timestamp = timestamp;

View file

@ -144,9 +144,8 @@ static void module_fill_module(const WCHAR* in, WCHAR* out, size_t size)
void module_set_module(struct module* module, const WCHAR* name) void module_set_module(struct module* module, const WCHAR* name)
{ {
module_fill_module(name, module->module.ModuleName, module_fill_module(name, module->module.ModuleName, ARRAY_SIZE(module->module.ModuleName));
sizeof(module->module.ModuleName) / sizeof(module->module.ModuleName[0])); module_fill_module(name, module->modulename, ARRAY_SIZE(module->modulename));
module_fill_module(name, module->modulename, sizeof(module->modulename) / sizeof(module->modulename[0]));
} }
#ifndef __REACTOS__ #ifndef __REACTOS__
@ -227,7 +226,7 @@ struct module* module_new(struct process* pcs, const WCHAR* name,
module->module.ImageSize = size; module->module.ImageSize = size;
module_set_module(module, name); module_set_module(module, name);
module->module.ImageName[0] = '\0'; module->module.ImageName[0] = '\0';
lstrcpynW(module->module.LoadedImageName, name, sizeof(module->module.LoadedImageName) / sizeof(WCHAR)); lstrcpynW(module->module.LoadedImageName, name, ARRAY_SIZE(module->module.LoadedImageName));
module->module.SymType = SymNone; module->module.SymType = SymNone;
module->module.NumSyms = 0; module->module.NumSyms = 0;
module->module.TimeDateStamp = stamp; module->module.TimeDateStamp = stamp;
@ -296,7 +295,7 @@ struct module* module_find_by_nameA(const struct process* pcs, const char* name)
{ {
WCHAR wname[MAX_PATH]; WCHAR wname[MAX_PATH];
MultiByteToWideChar(CP_ACP, 0, name, -1, wname, sizeof(wname) / sizeof(WCHAR)); MultiByteToWideChar(CP_ACP, 0, name, -1, wname, ARRAY_SIZE(wname));
return module_find_by_nameW(pcs, wname); return module_find_by_nameW(pcs, wname);
} }
@ -698,8 +697,7 @@ DWORD64 WINAPI SymLoadModuleExW(HANDLE hProcess, HANDLE hFile, PCWSTR wImageNam
if (wModuleName) if (wModuleName)
module_set_module(module, wModuleName); module_set_module(module, wModuleName);
if (wImageName) if (wImageName)
lstrcpynW(module->module.ImageName, wImageName, lstrcpynW(module->module.ImageName, wImageName, ARRAY_SIZE(module->module.ImageName));
sizeof(module->module.ImageName) / sizeof(WCHAR));
return module->module.BaseOfImage; return module->module.BaseOfImage;
} }
@ -963,9 +961,9 @@ BOOL WINAPI EnumerateLoadedModulesW64(HANDLE hProcess,
for (i = 0; i < sz; i++) for (i = 0; i < sz; i++)
{ {
if (!GetModuleInformation(hProcess, hMods[i], &mi, sizeof(mi)) || if (!GetModuleInformation(hProcess, hMods[i], &mi, sizeof(mi)) ||
!GetModuleBaseNameW(hProcess, hMods[i], baseW, sizeof(baseW) / sizeof(WCHAR))) !GetModuleBaseNameW(hProcess, hMods[i], baseW, ARRAY_SIZE(baseW)))
continue; continue;
module_fill_module(baseW, modW, sizeof(modW) / sizeof(modW[0])); module_fill_module(baseW, modW, ARRAY_SIZE(modW));
EnumLoadedModulesCallback(modW, (DWORD_PTR)mi.lpBaseOfDll, mi.SizeOfImage, EnumLoadedModulesCallback(modW, (DWORD_PTR)mi.lpBaseOfDll, mi.SizeOfImage,
UserContext); UserContext);
} }

View file

@ -2896,7 +2896,7 @@ static BOOL pdb_process_file(const struct process* pcs,
msc_dbg->module->module.PdbAge = pdb_info->pdb_files[0].age; msc_dbg->module->module.PdbAge = pdb_info->pdb_files[0].age;
MultiByteToWideChar(CP_ACP, 0, pdb_lookup->filename, -1, MultiByteToWideChar(CP_ACP, 0, pdb_lookup->filename, -1,
msc_dbg->module->module.LoadedPdbName, msc_dbg->module->module.LoadedPdbName,
sizeof(msc_dbg->module->module.LoadedPdbName) / sizeof(WCHAR)); ARRAY_SIZE(msc_dbg->module->module.LoadedPdbName));
/* FIXME: we could have a finer grain here */ /* FIXME: we could have a finer grain here */
msc_dbg->module->module.LineNumbers = TRUE; msc_dbg->module->module.LineNumbers = TRUE;
msc_dbg->module->module.GlobalSymbols = TRUE; msc_dbg->module->module.GlobalSymbols = TRUE;

View file

@ -345,7 +345,7 @@ struct ParseTypedefData
#ifdef PTS_DEBUG #ifdef PTS_DEBUG
static void stabs_pts_push(struct ParseTypedefData* ptd, unsigned line) static void stabs_pts_push(struct ParseTypedefData* ptd, unsigned line)
{ {
assert(ptd->err_idx < sizeof(ptd->errors) / sizeof(ptd->errors[0])); assert(ptd->err_idx < ARRAY_SIZE(ptd->errors));
ptd->errors[ptd->err_idx].line = line; ptd->errors[ptd->err_idx].line = line;
ptd->errors[ptd->err_idx].ptr = ptd->ptr; ptd->errors[ptd->err_idx].ptr = ptd->ptr;
ptd->err_idx++; ptd->err_idx++;
@ -357,7 +357,7 @@ static void stabs_pts_push(struct ParseTypedefData* ptd, unsigned line)
static int stabs_get_basic(struct ParseTypedefData* ptd, unsigned basic, struct symt** symt) static int stabs_get_basic(struct ParseTypedefData* ptd, unsigned basic, struct symt** symt)
{ {
PTS_ABORTIF(ptd, basic >= sizeof(stabs_basic) / sizeof(stabs_basic[0])); PTS_ABORTIF(ptd, basic >= ARRAY_SIZE(stabs_basic));
if (!stabs_basic[basic]) if (!stabs_basic[basic])
{ {
@ -1625,7 +1625,7 @@ BOOL stabs_parse(struct module* module, unsigned long load_offset,
break; break;
case N_BINCL: case N_BINCL:
stabs_add_include(stabs_new_include(ptr, n_value)); stabs_add_include(stabs_new_include(ptr, n_value));
assert(incl_stk < (int)(sizeof(incl) / sizeof(incl[0])) - 1); assert(incl_stk < (int) ARRAY_SIZE(incl) - 1);
incl[++incl_stk] = source_idx; incl[++incl_stk] = source_idx;
source_idx = source_new(module, NULL, ptr); source_idx = source_new(module, NULL, ptr);
break; break;

View file

@ -2130,7 +2130,7 @@ BOOL WINAPI SymAddSymbol(HANDLE hProcess, ULONG64 BaseOfDll, PCSTR name,
{ {
WCHAR nameW[MAX_SYM_NAME]; WCHAR nameW[MAX_SYM_NAME];
MultiByteToWideChar(CP_ACP, 0, name, -1, nameW, sizeof(nameW) / sizeof(WCHAR)); MultiByteToWideChar(CP_ACP, 0, name, -1, nameW, ARRAY_SIZE(nameW));
return SymAddSymbolW(hProcess, BaseOfDll, nameW, addr, size, flags); return SymAddSymbolW(hProcess, BaseOfDll, nameW, addr, size, flags);
} }

View file

@ -3,4 +3,4 @@ directories:
files: files:
include/dbghelp.h: sdk/include/psdk/dbghelp.h include/dbghelp.h: sdk/include/psdk/dbghelp.h
tags: tags:
wine: 3d482d3f9f0a3ffa69540af87594b3c1dc46e07b wine: 053a7e225c8190fd7416b3f3c3186f1ac230eeb3