kernel32: Support deleting resources in UpdateResource.
This commit is contained in:
parent
467844765b
commit
d5cb11a45a
|
@ -706,7 +706,8 @@ static void res_free_str( LPWSTR str )
|
||||||
}
|
}
|
||||||
|
|
||||||
static BOOL update_add_resource( QUEUEDUPDATES *updates, LPCWSTR Type, LPCWSTR Name,
|
static BOOL update_add_resource( QUEUEDUPDATES *updates, LPCWSTR Type, LPCWSTR Name,
|
||||||
struct resource_data *resdata, BOOL overwrite_existing )
|
LANGID Lang, struct resource_data *resdata,
|
||||||
|
BOOL overwrite_existing )
|
||||||
{
|
{
|
||||||
struct resource_dir_entry *restype, *resname;
|
struct resource_dir_entry *restype, *resname;
|
||||||
struct resource_data *existing;
|
struct resource_data *existing;
|
||||||
|
@ -736,7 +737,7 @@ static BOOL update_add_resource( QUEUEDUPDATES *updates, LPCWSTR Type, LPCWSTR N
|
||||||
* If there's an existing resource entry with matching (Type,Name,Language)
|
* If there's an existing resource entry with matching (Type,Name,Language)
|
||||||
* it needs to be removed before adding the new data.
|
* it needs to be removed before adding the new data.
|
||||||
*/
|
*/
|
||||||
existing = find_resource_data( &resname->children, resdata->lang );
|
existing = find_resource_data( &resname->children, Lang );
|
||||||
if (existing)
|
if (existing)
|
||||||
{
|
{
|
||||||
if (!overwrite_existing)
|
if (!overwrite_existing)
|
||||||
|
@ -745,7 +746,8 @@ static BOOL update_add_resource( QUEUEDUPDATES *updates, LPCWSTR Type, LPCWSTR N
|
||||||
HeapFree( GetProcessHeap(), 0, existing );
|
HeapFree( GetProcessHeap(), 0, existing );
|
||||||
}
|
}
|
||||||
|
|
||||||
add_resource_data_entry( &resname->children, resdata );
|
if (resdata)
|
||||||
|
add_resource_data_entry( &resname->children, resdata );
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
@ -1007,7 +1009,7 @@ static BOOL enumerate_mapped_resources( QUEUEDUPDATES *updates,
|
||||||
resdata = allocate_resource_data( Lang, data->CodePage, p, data->Size, FALSE );
|
resdata = allocate_resource_data( Lang, data->CodePage, p, data->Size, FALSE );
|
||||||
if (resdata)
|
if (resdata)
|
||||||
{
|
{
|
||||||
if (!update_add_resource( updates, Type, Name, resdata, FALSE ))
|
if (!update_add_resource( updates, Type, Name, Lang, resdata, FALSE ))
|
||||||
HeapFree( GetProcessHeap(), 0, resdata );
|
HeapFree( GetProcessHeap(), 0, resdata );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1697,10 +1699,17 @@ BOOL WINAPI UpdateResourceW( HANDLE hUpdate, LPCWSTR lpType, LPCWSTR lpName,
|
||||||
updates = GlobalLock(hUpdate);
|
updates = GlobalLock(hUpdate);
|
||||||
if (updates)
|
if (updates)
|
||||||
{
|
{
|
||||||
struct resource_data *data;
|
if (lpData == NULL && cbData == 0) /* remove resource */
|
||||||
data = allocate_resource_data( wLanguage, 0, lpData, cbData, TRUE );
|
{
|
||||||
if (data)
|
ret = update_add_resource( updates, lpType, lpName, wLanguage, NULL, TRUE );
|
||||||
ret = update_add_resource( updates, lpType, lpName, data, TRUE );
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
struct resource_data *data;
|
||||||
|
data = allocate_resource_data( wLanguage, 0, lpData, cbData, TRUE );
|
||||||
|
if (data)
|
||||||
|
ret = update_add_resource( updates, lpType, lpName, wLanguage, data, TRUE );
|
||||||
|
}
|
||||||
GlobalUnlock(hUpdate);
|
GlobalUnlock(hUpdate);
|
||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
|
|
Loading…
Reference in New Issue