Commit f517022e authored by Hans Leidekker's avatar Hans Leidekker Committed by Alexandre Julliard

msi: Fix an invalid write in build_default_format (Valgrind).

parent e3af7371
...@@ -339,29 +339,28 @@ static WCHAR *deformat_literal( FORMAT *format, FORMSTR *str, BOOL *propfound, ...@@ -339,29 +339,28 @@ static WCHAR *deformat_literal( FORMAT *format, FORMSTR *str, BOOL *propfound,
return replaced; return replaced;
} }
static LPWSTR build_default_format(const MSIRECORD* record) static WCHAR *build_default_format( const MSIRECORD *record )
{ {
int i;
int count;
WCHAR *rc, buf[26];
static const WCHAR fmt[] = {'%','i',':',' ','[','%','i',']',' ',0}; static const WCHAR fmt[] = {'%','i',':',' ','[','%','i',']',' ',0};
DWORD size; int i, count = MSI_RecordGetFieldCount( record );
WCHAR *ret, *tmp, buf[26];
DWORD size = 1;
count = MSI_RecordGetFieldCount(record); if (!(ret = msi_alloc( sizeof(*ret) ))) return NULL;
ret[0] = 0;
rc = msi_alloc(1);
rc[0] = 0;
size = 1;
for (i = 1; i <= count; i++) for (i = 1; i <= count; i++)
{ {
sprintfW(buf, fmt, i, i); size += sprintfW( buf, fmt, i, i );
size += lstrlenW(buf); if (!(tmp = msi_realloc( ret, size * sizeof(*ret) )))
rc = msi_realloc(rc, size * sizeof(WCHAR)); {
lstrcatW(rc, buf); msi_free( ret );
return NULL;
}
ret = tmp;
strcatW( ret, buf );
} }
return ret;
return rc;
} }
static BOOL format_is_number(WCHAR x) static BOOL format_is_number(WCHAR x)
......
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