texture-cache: Don't share requests for uncachable textures

Make create_texture_and_ensure_request() aware of the caching
policy to avoid returning the same texture for different
images.

https://bugzilla.gnome.org/show_bug.cgi?id=660585
This commit is contained in:
Florian Müllner 2011-10-05 01:18:16 +02:00
parent 472b20d933
commit 23a4d4c69e

View File

@ -1115,6 +1115,7 @@ st_texture_cache_load (StTextureCache *cache,
* @cache: * @cache:
* @key: A cache key * @key: A cache key
* @size: Size in pixels * @size: Size in pixels
* @policy: Cache policy
* @request: (out): If no request is outstanding, one will be created and returned here * @request: (out): If no request is outstanding, one will be created and returned here
* @texture: (out): A new texture, also added to the request * @texture: (out): A new texture, also added to the request
* *
@ -1128,6 +1129,7 @@ static gboolean
create_texture_and_ensure_request (StTextureCache *cache, create_texture_and_ensure_request (StTextureCache *cache,
const char *key, const char *key,
guint size, guint size,
StTextureCachePolicy policy,
AsyncTextureLoadData **request, AsyncTextureLoadData **request,
ClutterActor **texture) ClutterActor **texture)
{ {
@ -1154,6 +1156,7 @@ create_texture_and_ensure_request (StTextureCache *cache,
{ {
/* Not cached and no pending request, create it */ /* Not cached and no pending request, create it */
*request = g_new0 (AsyncTextureLoadData, 1); *request = g_new0 (AsyncTextureLoadData, 1);
if (policy != ST_TEXTURE_CACHE_POLICY_NONE)
g_hash_table_insert (cache->priv->outstanding_requests, g_strdup (key), *request); g_hash_table_insert (cache->priv->outstanding_requests, g_strdup (key), *request);
} }
else else
@ -1203,7 +1206,7 @@ load_gicon_with_colors (StTextureCache *cache,
} }
g_free (gicon_string); g_free (gicon_string);
if (create_texture_and_ensure_request (cache, key, size, &request, &texture)) if (create_texture_and_ensure_request (cache, key, size, policy, &request, &texture))
{ {
g_free (key); g_free (key);
return texture; return texture;