mirror of
https://github.com/netsurf-browser/netsurf
synced 2025-01-03 01:34:25 +03:00
Fix heap corruption
svn path=/trunk/netsurf/; revision=10786
This commit is contained in:
parent
dafccf21d5
commit
db736f8378
@ -158,7 +158,7 @@ static nserror llcache_object_retrieve_from_cache(const char *url,
|
|||||||
llcache_object **result);
|
llcache_object **result);
|
||||||
static bool llcache_object_is_fresh(const llcache_object *object);
|
static bool llcache_object_is_fresh(const llcache_object *object);
|
||||||
static nserror llcache_object_cache_update(llcache_object *object);
|
static nserror llcache_object_cache_update(llcache_object *object);
|
||||||
static nserror llcache_object_clone_cache_data(const llcache_object *source,
|
static nserror llcache_object_clone_cache_data(llcache_object *source,
|
||||||
llcache_object *destination, bool deep);
|
llcache_object *destination, bool deep);
|
||||||
static nserror llcache_object_fetch(llcache_object *object, uint32_t flags,
|
static nserror llcache_object_fetch(llcache_object *object, uint32_t flags,
|
||||||
const char *referer, const llcache_post_data *post,
|
const char *referer, const llcache_post_data *post,
|
||||||
@ -845,8 +845,10 @@ nserror llcache_object_cache_update(llcache_object *object)
|
|||||||
* \param destination Destination object to clone cache data into
|
* \param destination Destination object to clone cache data into
|
||||||
* \param deep Whether to deep-copy the data or not
|
* \param deep Whether to deep-copy the data or not
|
||||||
* \return NSERROR_OK on success, appropriate error otherwise
|
* \return NSERROR_OK on success, appropriate error otherwise
|
||||||
|
*
|
||||||
|
* \post If \a deep is false, then any pointers in \a source will be set to NULL
|
||||||
*/
|
*/
|
||||||
nserror llcache_object_clone_cache_data(const llcache_object *source,
|
nserror llcache_object_clone_cache_data(llcache_object *source,
|
||||||
llcache_object *destination, bool deep)
|
llcache_object *destination, bool deep)
|
||||||
{
|
{
|
||||||
/* ETag must be first, as it can fail when deep cloning */
|
/* ETag must be first, as it can fail when deep cloning */
|
||||||
@ -858,6 +860,9 @@ nserror llcache_object_clone_cache_data(const llcache_object *source,
|
|||||||
etag = strdup(source->cache.etag);
|
etag = strdup(source->cache.etag);
|
||||||
if (etag == NULL)
|
if (etag == NULL)
|
||||||
return NSERROR_NOMEM;
|
return NSERROR_NOMEM;
|
||||||
|
} else {
|
||||||
|
/* Destination takes ownership */
|
||||||
|
source->cache.etag = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (destination->cache.etag != NULL)
|
if (destination->cache.etag != NULL)
|
||||||
|
Loading…
Reference in New Issue
Block a user