opcservices: Use CRT allocation functions.

Signed-off-by: Nikolay Sivov <nsivov@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Nikolay Sivov 2022-03-29 09:51:57 +03:00 committed by Alexandre Julliard
parent 6549f1f3d2
commit ea15c212e3
5 changed files with 50 additions and 52 deletions

View File

@ -28,7 +28,6 @@
#include "opc_private.h" #include "opc_private.h"
#include "wine/debug.h" #include "wine/debug.h"
#include "wine/heap.h"
WINE_DEFAULT_DEBUG_CHANNEL(msopc); WINE_DEFAULT_DEBUG_CHANNEL(msopc);
@ -120,7 +119,7 @@ HRESULT compress_create_archive(IStream *output, struct zip_archive **out)
WORD date, time; WORD date, time;
FILETIME ft; FILETIME ft;
if (!(archive = heap_alloc(sizeof(*archive)))) if (!(archive = malloc(sizeof(*archive))))
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
archive->files = NULL; archive->files = NULL;
@ -180,9 +179,9 @@ void compress_finalize_archive(struct zip_archive *archive)
IStream_Release(archive->output); IStream_Release(archive->output);
for (i = 0; i < archive->file_count; i++) for (i = 0; i < archive->file_count; i++)
heap_free(archive->files[i]); free(archive->files[i]);
heap_free(archive->files); free(archive->files);
heap_free(archive); free(archive);
} }
static void compress_write_content(struct zip_archive *archive, IStream *content, static void compress_write_content(struct zip_archive *archive, IStream *content,
@ -270,7 +269,7 @@ HRESULT compress_add_file(struct zip_archive *archive, const WCHAR *path,
DWORD len; DWORD len;
len = WideCharToMultiByte(CP_ACP, 0, path, -1, NULL, 0, NULL, NULL); len = WideCharToMultiByte(CP_ACP, 0, path, -1, NULL, 0, NULL, NULL);
if (!(name = heap_alloc(len))) if (!(name = malloc(len)))
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
WideCharToMultiByte(CP_ACP, 0, path, -1, name, len, NULL, NULL); WideCharToMultiByte(CP_ACP, 0, path, -1, name, len, NULL, NULL);
@ -302,9 +301,9 @@ HRESULT compress_add_file(struct zip_archive *archive, const WCHAR *path,
return archive->write_result; return archive->write_result;
/* Set directory entry */ /* Set directory entry */
if (!(entry = heap_alloc_zero(sizeof(*entry) + local_header.name_length))) if (!(entry = calloc(1, sizeof(*entry) + local_header.name_length)))
{ {
heap_free(name); free(name);
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
} }
@ -320,12 +319,12 @@ HRESULT compress_add_file(struct zip_archive *archive, const WCHAR *path,
entry->name_length = local_header.name_length; entry->name_length = local_header.name_length;
entry->local_file_offset = local_header_pos; entry->local_file_offset = local_header_pos;
memcpy(entry + 1, name, entry->name_length); memcpy(entry + 1, name, entry->name_length);
heap_free(name); free(name);
if (!opc_array_reserve((void **)&archive->files, &archive->file_size, archive->file_count + 1, if (!opc_array_reserve((void **)&archive->files, &archive->file_size, archive->file_count + 1,
sizeof(*archive->files))) sizeof(*archive->files)))
{ {
heap_free(entry); free(entry);
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
} }

View File

@ -85,7 +85,7 @@ static ULONG WINAPI opc_filestream_Release(IStream *iface)
if (!refcount) if (!refcount)
{ {
CloseHandle(stream->hfile); CloseHandle(stream->hfile);
heap_free(stream); free(stream);
} }
return refcount; return refcount;
@ -263,14 +263,14 @@ static HRESULT opc_filestream_create(const WCHAR *filename, OPC_STREAM_IO_MODE i
return E_INVALIDARG; return E_INVALIDARG;
} }
if (!(stream = heap_alloc_zero(sizeof(*stream)))) if (!(stream = calloc(1, sizeof(*stream))))
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
stream->hfile = CreateFileW(filename, access, 0, sa, creation, flags, NULL); stream->hfile = CreateFileW(filename, access, 0, sa, creation, flags, NULL);
if (stream->hfile == INVALID_HANDLE_VALUE) if (stream->hfile == INVALID_HANDLE_VALUE)
{ {
HRESULT hr = HRESULT_FROM_WIN32(GetLastError()); HRESULT hr = HRESULT_FROM_WIN32(GetLastError());
heap_free(stream); free(stream);
return hr; return hr;
} }

View File

@ -17,7 +17,6 @@
*/ */
#include "msopc.h" #include "msopc.h"
#include "wine/heap.h"
static inline BOOL opc_array_reserve(void **elements, size_t *capacity, size_t count, size_t size) static inline BOOL opc_array_reserve(void **elements, size_t *capacity, size_t count, size_t size)
{ {
@ -37,7 +36,7 @@ static inline BOOL opc_array_reserve(void **elements, size_t *capacity, size_t c
if (new_capacity < count) if (new_capacity < count)
new_capacity = max_capacity; new_capacity = max_capacity;
if (!(new_elements = heap_realloc(*elements, new_capacity * size))) if (!(new_elements = realloc(*elements, new_capacity * size)))
return FALSE; return FALSE;
*elements = new_elements; *elements = new_elements;

View File

@ -170,8 +170,8 @@ static void opc_content_release(struct opc_content *content)
if (!refcount) if (!refcount)
{ {
heap_free(content->data); free(content->data);
heap_free(content); free(content);
} }
} }
@ -214,7 +214,7 @@ static ULONG WINAPI opc_part_enum_Release(IOpcPartEnumerator *iface)
if (!refcount) if (!refcount)
{ {
IOpcPartSet_Release(&part_enum->part_set->IOpcPartSet_iface); IOpcPartSet_Release(&part_enum->part_set->IOpcPartSet_iface);
heap_free(part_enum); free(part_enum);
} }
return refcount; return refcount;
@ -321,7 +321,7 @@ static HRESULT opc_part_enum_create(struct opc_part_set *part_set, IOpcPartEnume
{ {
struct opc_part_enum *part_enum; struct opc_part_enum *part_enum;
if (!(part_enum = heap_alloc_zero(sizeof(*part_enum)))) if (!(part_enum = calloc(1, sizeof(*part_enum))))
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
part_enum->IOpcPartEnumerator_iface.lpVtbl = &opc_part_enum_vtbl; part_enum->IOpcPartEnumerator_iface.lpVtbl = &opc_part_enum_vtbl;
@ -375,7 +375,7 @@ static ULONG WINAPI opc_rel_enum_Release(IOpcRelationshipEnumerator *iface)
if (!refcount) if (!refcount)
{ {
IOpcRelationshipSet_Release(&rel_enum->rel_set->IOpcRelationshipSet_iface); IOpcRelationshipSet_Release(&rel_enum->rel_set->IOpcRelationshipSet_iface);
heap_free(rel_enum); free(rel_enum);
} }
return refcount; return refcount;
@ -482,7 +482,7 @@ static HRESULT opc_rel_enum_create(struct opc_relationship_set *rel_set, IOpcRel
{ {
struct opc_rel_enum *rel_enum; struct opc_rel_enum *rel_enum;
if (!(rel_enum = heap_alloc_zero(sizeof(*rel_enum)))) if (!(rel_enum = calloc(1, sizeof(*rel_enum))))
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
rel_enum->IOpcRelationshipEnumerator_iface.lpVtbl = &opc_rel_enum_vtbl; rel_enum->IOpcRelationshipEnumerator_iface.lpVtbl = &opc_rel_enum_vtbl;
@ -535,7 +535,7 @@ static ULONG WINAPI opc_content_stream_Release(IStream *iface)
if (!refcount) if (!refcount)
{ {
opc_content_release(stream->content); opc_content_release(stream->content);
heap_free(stream); free(stream);
} }
return refcount; return refcount;
@ -578,7 +578,7 @@ static HRESULT WINAPI opc_content_stream_Write(IStream *iface, const void *data,
if (size > stream->content->size.QuadPart - stream->pos.QuadPart) if (size > stream->content->size.QuadPart - stream->pos.QuadPart)
{ {
void *ptr = heap_realloc(stream->content->data, stream->pos.QuadPart + size); void *ptr = realloc(stream->content->data, stream->pos.QuadPart + size);
if (!ptr) if (!ptr)
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
stream->content->data = ptr; stream->content->data = ptr;
@ -707,7 +707,7 @@ static HRESULT opc_content_stream_create(struct opc_content *content, IStream **
{ {
struct opc_content_stream *stream; struct opc_content_stream *stream;
if (!(stream = heap_alloc_zero(sizeof(*stream)))) if (!(stream = calloc(1, sizeof(*stream))))
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
stream->IStream_iface.lpVtbl = &opc_content_stream_vtbl; stream->IStream_iface.lpVtbl = &opc_content_stream_vtbl;
@ -780,7 +780,7 @@ static ULONG WINAPI opc_part_Release(IOpcPart *iface)
IOpcPartUri_Release(part->name); IOpcPartUri_Release(part->name);
CoTaskMemFree(part->content_type); CoTaskMemFree(part->content_type);
opc_content_release(part->content); opc_content_release(part->content);
heap_free(part); free(part);
} }
return refcount; return refcount;
@ -866,7 +866,7 @@ static HRESULT opc_part_create(struct opc_part_set *set, IOpcPartUri *name, cons
if (!opc_array_reserve((void **)&set->parts, &set->size, set->count + 1, sizeof(*set->parts))) if (!opc_array_reserve((void **)&set->parts, &set->size, set->count + 1, sizeof(*set->parts)))
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
if (!(part = heap_alloc_zero(sizeof(*part)))) if (!(part = calloc(1, sizeof(*part))))
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
part->IOpcPart_iface.lpVtbl = &opc_part_vtbl; part->IOpcPart_iface.lpVtbl = &opc_part_vtbl;
@ -880,7 +880,7 @@ static HRESULT opc_part_create(struct opc_part_set *set, IOpcPartUri *name, cons
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
} }
part->content = heap_alloc_zero(sizeof(*part->content)); part->content = calloc(1, sizeof(*part->content));
if (!part->content) if (!part->content)
{ {
IOpcPart_Release(&part->IOpcPart_iface); IOpcPart_Release(&part->IOpcPart_iface);
@ -951,8 +951,8 @@ static ULONG WINAPI opc_part_set_Release(IOpcPartSet *iface)
for (i = 0; i < part_set->count; ++i) for (i = 0; i < part_set->count; ++i)
IOpcPart_Release(&part_set->parts[i]->IOpcPart_iface); IOpcPart_Release(&part_set->parts[i]->IOpcPart_iface);
heap_free(part_set->parts); free(part_set->parts);
heap_free(part_set); free(part_set);
} }
return refcount; return refcount;
@ -1088,7 +1088,7 @@ static ULONG WINAPI opc_relationship_Release(IOpcRelationship *iface)
CoTaskMemFree(relationship->type); CoTaskMemFree(relationship->type);
IOpcUri_Release(relationship->source_uri); IOpcUri_Release(relationship->source_uri);
IUri_Release(relationship->target); IUri_Release(relationship->target);
heap_free(relationship); free(relationship);
} }
return refcount; return refcount;
@ -1183,7 +1183,7 @@ static HRESULT opc_relationship_create(struct opc_relationship_set *set, const W
if (!opc_array_reserve((void **)&set->relationships, &set->size, set->count + 1, sizeof(*set->relationships))) if (!opc_array_reserve((void **)&set->relationships, &set->size, set->count + 1, sizeof(*set->relationships)))
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
if (!(relationship = heap_alloc_zero(sizeof(*relationship)))) if (!(relationship = calloc(1, sizeof(*relationship))))
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
relationship->IOpcRelationship_iface.lpVtbl = &opc_relationship_vtbl; relationship->IOpcRelationship_iface.lpVtbl = &opc_relationship_vtbl;
@ -1272,8 +1272,8 @@ static ULONG WINAPI opc_relationship_set_Release(IOpcRelationshipSet *iface)
for (i = 0; i < relationship_set->count; ++i) for (i = 0; i < relationship_set->count; ++i)
IOpcRelationship_Release(&relationship_set->relationships[i]->IOpcRelationship_iface); IOpcRelationship_Release(&relationship_set->relationships[i]->IOpcRelationship_iface);
IOpcUri_Release(relationship_set->source_uri); IOpcUri_Release(relationship_set->source_uri);
heap_free(relationship_set->relationships); free(relationship_set->relationships);
heap_free(relationship_set); free(relationship_set);
} }
return refcount; return refcount;
@ -1398,7 +1398,7 @@ static HRESULT opc_relationship_set_create(IOpcUri *source_uri, IOpcRelationship
{ {
struct opc_relationship_set *relationship_set; struct opc_relationship_set *relationship_set;
if (!(relationship_set = heap_alloc_zero(sizeof(*relationship_set)))) if (!(relationship_set = calloc(1, sizeof(*relationship_set))))
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
relationship_set->IOpcRelationshipSet_iface.lpVtbl = &opc_relationship_set_vtbl; relationship_set->IOpcRelationshipSet_iface.lpVtbl = &opc_relationship_set_vtbl;
@ -1452,7 +1452,7 @@ static ULONG WINAPI opc_package_Release(IOpcPackage *iface)
IOpcRelationshipSet_Release(package->relationship_set); IOpcRelationshipSet_Release(package->relationship_set);
if (package->source_uri) if (package->source_uri)
IOpcUri_Release(package->source_uri); IOpcUri_Release(package->source_uri);
heap_free(package); free(package);
} }
return refcount; return refcount;
@ -1466,7 +1466,7 @@ static HRESULT WINAPI opc_package_GetPartSet(IOpcPackage *iface, IOpcPartSet **p
if (!package->part_set) if (!package->part_set)
{ {
struct opc_part_set *part_set = heap_alloc_zero(sizeof(*part_set)); struct opc_part_set *part_set = calloc(1, sizeof(*part_set));
if (!part_set) if (!part_set)
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
@ -1515,7 +1515,7 @@ HRESULT opc_package_create(IOpcFactory *factory, IOpcPackage **out)
struct opc_package *package; struct opc_package *package;
HRESULT hr; HRESULT hr;
if (!(package = heap_alloc_zero(sizeof(*package)))) if (!(package = calloc(1, sizeof(*package))))
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
package->IOpcPackage_iface.lpVtbl = &opc_package_vtbl; package->IOpcPackage_iface.lpVtbl = &opc_package_vtbl;
@ -1523,7 +1523,7 @@ HRESULT opc_package_create(IOpcFactory *factory, IOpcPackage **out)
if (FAILED(hr = IOpcFactory_CreatePackageRootUri(factory, &package->source_uri))) if (FAILED(hr = IOpcFactory_CreatePackageRootUri(factory, &package->source_uri)))
{ {
heap_free(package); free(package);
return hr; return hr;
} }
@ -1566,7 +1566,7 @@ static HRESULT opc_package_add_override_content_type(struct content_types *types
{ {
struct content_type *type; struct content_type *type;
if (!(type = heap_alloc(sizeof(*type)))) if (!(type = malloc(sizeof(*type))))
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
type->element = CONTENT_TYPE_OVERRIDE; type->element = CONTENT_TYPE_OVERRIDE;
@ -1583,7 +1583,7 @@ static HRESULT opc_package_add_default_content_type(struct content_types *types,
{ {
struct content_type *type; struct content_type *type;
if (!(type = heap_alloc(sizeof(*type)))) if (!(type = malloc(sizeof(*type))))
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
type->element = CONTENT_TYPE_DEFAULT; type->element = CONTENT_TYPE_DEFAULT;
@ -1593,7 +1593,7 @@ static HRESULT opc_package_add_default_content_type(struct content_types *types,
{ {
CoTaskMemFree(type->u.def.ext); CoTaskMemFree(type->u.def.ext);
CoTaskMemFree(type->u.def.type); CoTaskMemFree(type->u.def.type);
heap_free(type); free(type);
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
} }
@ -1810,7 +1810,7 @@ static HRESULT opc_package_write_contenttypes(IOpcPackage *package, struct zip_a
hr = IXmlWriter_WriteEndElement(writer); hr = IXmlWriter_WriteEndElement(writer);
list_remove(&content_type->entry); list_remove(&content_type->entry);
heap_free(content_type); free(content_type);
} }
if (SUCCEEDED(hr)) if (SUCCEEDED(hr))

View File

@ -79,7 +79,7 @@ static ULONG WINAPI opc_uri_Release(IOpcPartUri *iface)
if (uri->source_uri) if (uri->source_uri)
IOpcPartUri_Release(&uri->source_uri->IOpcPartUri_iface); IOpcPartUri_Release(&uri->source_uri->IOpcPartUri_iface);
IUri_Release(uri->uri); IUri_Release(uri->uri);
heap_free(uri); free(uri);
} }
return refcount; return refcount;
@ -485,7 +485,7 @@ static IUri *opc_part_uri_get_rels_uri(IUri *uri)
} }
} }
ret = heap_alloc((len + ARRAY_SIZE(relsextW) + ARRAY_SIZE(relsdirW)) * sizeof(WCHAR)); ret = malloc((len + ARRAY_SIZE(relsextW) + ARRAY_SIZE(relsdirW)) * sizeof(WCHAR));
if (!ret) if (!ret)
{ {
SysFreeString(path); SysFreeString(path);
@ -505,7 +505,7 @@ static IUri *opc_part_uri_get_rels_uri(IUri *uri)
if (FAILED(hr = CreateUri(ret, Uri_CREATE_ALLOW_RELATIVE, 0, &rels_uri))) if (FAILED(hr = CreateUri(ret, Uri_CREATE_ALLOW_RELATIVE, 0, &rels_uri)))
WARN("Failed to create rels uri, hr %#lx.\n", hr); WARN("Failed to create rels uri, hr %#lx.\n", hr);
heap_free(ret); free(ret);
SysFreeString(path); SysFreeString(path);
return rels_uri; return rels_uri;
@ -539,13 +539,13 @@ static HRESULT opc_source_uri_create(struct opc_uri *uri, IOpcUri **out)
if (!uri->source_uri) if (!uri->source_uri)
return OPC_E_RELATIONSHIP_URI_REQUIRED; return OPC_E_RELATIONSHIP_URI_REQUIRED;
if (!(obj = heap_alloc_zero(sizeof(*obj)))) if (!(obj = calloc(1, sizeof(*obj))))
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
if (FAILED(hr = opc_part_uri_init(obj, NULL, uri->source_uri->is_part_uri, uri->source_uri->uri))) if (FAILED(hr = opc_part_uri_init(obj, NULL, uri->source_uri->is_part_uri, uri->source_uri->uri)))
{ {
WARN("Failed to init part uri, hr %#lx.\n", hr); WARN("Failed to init part uri, hr %#lx.\n", hr);
heap_free(obj); free(obj);
return hr; return hr;
} }
@ -561,13 +561,13 @@ HRESULT opc_part_uri_create(IUri *uri, struct opc_uri *source_uri, IOpcPartUri *
struct opc_uri *obj; struct opc_uri *obj;
HRESULT hr; HRESULT hr;
if (!(obj = heap_alloc_zero(sizeof(*obj)))) if (!(obj = calloc(1, sizeof(*obj))))
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
if (FAILED(hr = opc_part_uri_init(obj, source_uri, TRUE, uri))) if (FAILED(hr = opc_part_uri_init(obj, source_uri, TRUE, uri)))
{ {
WARN("Failed to init part uri, hr %#lx.\n", hr); WARN("Failed to init part uri, hr %#lx.\n", hr);
heap_free(obj); free(obj);
return hr; return hr;
} }
@ -584,13 +584,13 @@ HRESULT opc_root_uri_create(IOpcUri **out)
*out = NULL; *out = NULL;
if (!(obj = heap_alloc_zero(sizeof(*obj)))) if (!(obj = calloc(1, sizeof(*obj))))
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
if (FAILED(hr = CreateUri(L"/", Uri_CREATE_ALLOW_RELATIVE, 0, &uri))) if (FAILED(hr = CreateUri(L"/", Uri_CREATE_ALLOW_RELATIVE, 0, &uri)))
{ {
WARN("Failed to create rels uri, hr %#lx.\n", hr); WARN("Failed to create rels uri, hr %#lx.\n", hr);
heap_free(obj); free(obj);
return hr; return hr;
} }
@ -599,7 +599,7 @@ HRESULT opc_root_uri_create(IOpcUri **out)
if (FAILED(hr)) if (FAILED(hr))
{ {
WARN("Failed to init uri, hr %#lx.\n", hr); WARN("Failed to init uri, hr %#lx.\n", hr);
heap_free(uri); free(uri);
return hr; return hr;
} }