Commit 17ffb562 authored by Aric Stewart's avatar Aric Stewart Committed by Alexandre Julliard

msi: Fix some NULL checking in MSI_RecordGetStringA.

Includes a few record tests with a NULL buffer.
parent 5c779bfa
...@@ -358,6 +358,7 @@ UINT MSI_RecordGetStringA(MSIRECORD *rec, UINT iField, ...@@ -358,6 +358,7 @@ UINT MSI_RecordGetStringA(MSIRECORD *rec, UINT iField,
case MSIFIELD_WSTR: case MSIFIELD_WSTR:
len = WideCharToMultiByte( CP_ACP, 0, rec->fields[iField].u.szwVal, -1, len = WideCharToMultiByte( CP_ACP, 0, rec->fields[iField].u.szwVal, -1,
NULL, 0 , NULL, NULL); NULL, 0 , NULL, NULL);
if (szValue)
WideCharToMultiByte( CP_ACP, 0, rec->fields[iField].u.szwVal, -1, WideCharToMultiByte( CP_ACP, 0, rec->fields[iField].u.szwVal, -1,
szValue, *pcchValue, NULL, NULL); szValue, *pcchValue, NULL, NULL);
if( szValue && *pcchValue && len>*pcchValue ) if( szValue && *pcchValue && len>*pcchValue )
...@@ -366,7 +367,7 @@ UINT MSI_RecordGetStringA(MSIRECORD *rec, UINT iField, ...@@ -366,7 +367,7 @@ UINT MSI_RecordGetStringA(MSIRECORD *rec, UINT iField,
len--; len--;
break; break;
case MSIFIELD_NULL: case MSIFIELD_NULL:
if( *pcchValue > 0 ) if( szValue && *pcchValue > 0 )
szValue[0] = 0; szValue[0] = 0;
break; break;
default: default:
......
...@@ -362,6 +362,11 @@ static void test_MsiRecordGetString(void) ...@@ -362,6 +362,11 @@ static void test_MsiRecordGetString(void)
ok(rec != 0, "Expected a valid handle\n"); ok(rec != 0, "Expected a valid handle\n");
sz = MAX_PATH; sz = MAX_PATH;
r = MsiRecordGetString(rec, 1, NULL, &sz);
ok(r == ERROR_SUCCESS, "Expected ERROR_SUCCESS, got %d\n",r);
ok(sz == 0, "Expected 0, got %d\n",sz);
sz = MAX_PATH;
lstrcpyA(buf, "apple"); lstrcpyA(buf, "apple");
r = MsiRecordGetString(rec, 1, buf, &sz); r = MsiRecordGetString(rec, 1, buf, &sz);
ok(r == ERROR_SUCCESS, "Expected ERROR_SUCCESS, got %d\n", r); ok(r == ERROR_SUCCESS, "Expected ERROR_SUCCESS, got %d\n", r);
...@@ -384,6 +389,11 @@ static void test_MsiRecordGetString(void) ...@@ -384,6 +389,11 @@ static void test_MsiRecordGetString(void)
ok(r == ERROR_SUCCESS, "Expected ERROR_SUCCESS, got %d\n", r); ok(r == ERROR_SUCCESS, "Expected ERROR_SUCCESS, got %d\n", r);
sz = MAX_PATH; sz = MAX_PATH;
r = MsiRecordGetString(rec, 1, NULL, &sz);
ok(r == ERROR_SUCCESS, "Expected ERROR_SUCCESS, got %d\n",r);
ok(sz == 1, "Expected 1, got %d\n",sz);
sz = MAX_PATH;
lstrcpyA(buf, "apple"); lstrcpyA(buf, "apple");
r = MsiRecordGetString(rec, 1, buf, &sz); r = MsiRecordGetString(rec, 1, buf, &sz);
ok(r == ERROR_SUCCESS, "Expected ERROR_SUCCESS, got %d\n", r); ok(r == ERROR_SUCCESS, "Expected ERROR_SUCCESS, got %d\n", r);
......
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