ethumb: fix wrong dirty detection.

Patch by SANS Mikael <sans.mikael@gmail.com>.


SVN revision: 63021
This commit is contained in:
Cedric BAIL 2011-08-31 09:28:54 +00:00
parent b8e42ad9cd
commit 8385a7dec0
2 changed files with 44 additions and 20 deletions

View File

@ -1 +1,3 @@
Rafael Antognolli <antognolli@profusion.mobi>
Cedric Bail <cedric.bail@free.fr>
Mikael SANS <sans.mikael@gmail.com>

View File

@ -100,6 +100,7 @@ struct _Ethumb_Client
Ethumb *ethumb;
int id_count;
Ethumb *old_ethumb_conf;
E_DBus_Connection *conn;
E_DBus_Signal_Handler *name_owner_changed_handler;
E_DBus_Signal_Handler *generated_signal;
@ -126,7 +127,6 @@ struct _Ethumb_Client
EINA_REFCOUNT;
Eina_Bool ethumb_dirty : 1;
Eina_Bool connected : 1;
Eina_Bool server_started : 1;
};
@ -324,6 +324,9 @@ end_connection:
if (client->pending_start_service_by_name)
dbus_pending_call_cancel(client->pending_start_service_by_name);
if (client->old_ethumb_conf)
ethumb_free(client->old_ethumb_conf);
ethumb_free(client->ethumb);
e_dbus_signal_handler_del(client->conn, client->name_owner_changed_handler);
@ -607,7 +610,6 @@ _ethumb_client_exists_end(void *data, Ecore_Thread *thread __UNUSED__)
Ethumb *tmp = async->source->ethumb;
async->source->ethumb = async->dup;
async->source->ethumb_dirty = ethumb_cmp(tmp, async->dup);
EINA_LIST_FREE(async->callbacks, cb)
{
@ -758,6 +760,7 @@ ethumb_client_connect(Ethumb_Client_Connect_Cb connect_cb, const void *data, Ein
goto err;
}
eclient->old_ethumb_conf = NULL;
eclient->connect.cb = connect_cb;
eclient->connect.data = (void *)data;
eclient->connect.free_data = free_data;
@ -948,7 +951,6 @@ ethumb_client_ethumb_setup(Ethumb_Client *client)
EINA_SAFETY_ON_NULL_RETURN(client);
EINA_SAFETY_ON_FALSE_RETURN(client->connected);
client->ethumb_dirty = 0;
msg = dbus_message_new_method_call(_ethumb_dbus_bus_name,
client->object_path,
@ -1455,7 +1457,8 @@ ethumb_client_fdo_set(Ethumb_Client *client, Ethumb_Thumb_FDO_Size s)
{
EINA_SAFETY_ON_NULL_RETURN(client);
client->ethumb_dirty = 1;
if (!client->old_ethumb_conf)
client->old_ethumb_conf = ethumb_dup(client->ethumb);
ethumb_thumb_fdo_set(client->ethumb, s);
}
@ -1473,7 +1476,8 @@ ethumb_client_size_set(Ethumb_Client *client, int tw, int th)
{
EINA_SAFETY_ON_NULL_RETURN(client);
client->ethumb_dirty = 1;
if (!client->old_ethumb_conf)
client->old_ethumb_conf = ethumb_dup(client->ethumb);
ethumb_thumb_size_set(client->ethumb, tw, th);
}
@ -1510,7 +1514,8 @@ ethumb_client_format_set(Ethumb_Client *client, Ethumb_Thumb_Format f)
{
EINA_SAFETY_ON_NULL_RETURN(client);
client->ethumb_dirty = 1;
if (!client->old_ethumb_conf)
client->old_ethumb_conf = ethumb_dup(client->ethumb);
ethumb_thumb_format_set(client->ethumb, f);
}
@ -1566,7 +1571,8 @@ ethumb_client_aspect_set(Ethumb_Client *client, Ethumb_Thumb_Aspect a)
{
EINA_SAFETY_ON_NULL_RETURN(client);
client->ethumb_dirty = 1;
if (!client->old_ethumb_conf)
client->old_ethumb_conf = ethumb_dup(client->ethumb);
ethumb_thumb_aspect_set(client->ethumb, a);
}
@ -1608,7 +1614,8 @@ ethumb_client_orientation_set(Ethumb_Client *client, Ethumb_Thumb_Orientation o)
{
EINA_SAFETY_ON_NULL_RETURN(client);
client->ethumb_dirty = 1;
if (!client->old_ethumb_conf)
client->old_ethumb_conf = ethumb_dup(client->ethumb);
ethumb_thumb_orientation_set(client->ethumb, o);
}
@ -1647,7 +1654,8 @@ ethumb_client_crop_align_set(Ethumb_Client *client, float x, float y)
{
EINA_SAFETY_ON_NULL_RETURN(client);
client->ethumb_dirty = 1;
if (!client->old_ethumb_conf)
client->old_ethumb_conf = ethumb_dup(client->ethumb);
ethumb_thumb_crop_align_set(client->ethumb, x, y);
}
@ -1761,7 +1769,8 @@ ethumb_client_frame_set(Ethumb_Client *client, const char *file, const char *gro
{
EINA_SAFETY_ON_NULL_RETURN_VAL(client, 0);
client->ethumb_dirty = 1;
if (!client->old_ethumb_conf)
client->old_ethumb_conf = ethumb_dup(client->ethumb);
return ethumb_frame_set(client->ethumb, file, group, swallow);
}
@ -1793,7 +1802,8 @@ ethumb_client_dir_path_set(Ethumb_Client *client, const char *path)
{
EINA_SAFETY_ON_NULL_RETURN(client);
client->ethumb_dirty = 1;
if (!client->old_ethumb_conf)
client->old_ethumb_conf = ethumb_dup(client->ethumb);
ethumb_thumb_dir_path_set(client->ethumb, path);
}
@ -1846,7 +1856,8 @@ ethumb_client_category_set(Ethumb_Client *client, const char *category)
{
EINA_SAFETY_ON_NULL_RETURN(client);
client->ethumb_dirty = 1;
if (!client->old_ethumb_conf)
client->old_ethumb_conf = ethumb_dup(client->ethumb);
ethumb_thumb_category_set(client->ethumb, category);
}
@ -1883,7 +1894,8 @@ ethumb_client_video_time_set(Ethumb_Client *client, float t)
{
EINA_SAFETY_ON_NULL_RETURN(client);
client->ethumb_dirty = 1;
if (!client->old_ethumb_conf)
client->old_ethumb_conf = ethumb_dup(client->ethumb);
ethumb_video_time_set(client->ethumb, t);
}
@ -1906,7 +1918,8 @@ ethumb_client_video_start_set(Ethumb_Client *client, float start)
EINA_SAFETY_ON_FALSE_RETURN(start >= 0.0);
EINA_SAFETY_ON_FALSE_RETURN(start <= 1.0);
client->ethumb_dirty = 1;
if (!client->old_ethumb_conf)
client->old_ethumb_conf = ethumb_dup(client->ethumb);
ethumb_video_start_set(client->ethumb, start);
}
@ -1934,7 +1947,8 @@ ethumb_client_video_interval_set(Ethumb_Client *client, float interval)
{
EINA_SAFETY_ON_NULL_RETURN(client);
client->ethumb_dirty = 1;
if (!client->old_ethumb_conf)
client->old_ethumb_conf = ethumb_dup(client->ethumb);
ethumb_video_interval_set(client->ethumb, interval);
}
@ -1956,7 +1970,8 @@ ethumb_client_video_ntimes_set(Ethumb_Client *client, unsigned int ntimes)
EINA_SAFETY_ON_NULL_RETURN(client);
EINA_SAFETY_ON_FALSE_RETURN(ntimes > 0);
client->ethumb_dirty = 1;
if (!client->old_ethumb_conf)
client->old_ethumb_conf = ethumb_dup(client->ethumb);
ethumb_video_ntimes_set(client->ethumb, ntimes);
}
@ -1982,7 +1997,8 @@ ethumb_client_video_fps_set(Ethumb_Client *client, unsigned int fps)
EINA_SAFETY_ON_NULL_RETURN(client);
EINA_SAFETY_ON_FALSE_RETURN(fps > 0);
client->ethumb_dirty = 1;
if (!client->old_ethumb_conf)
client->old_ethumb_conf = ethumb_dup(client->ethumb);
ethumb_video_fps_set(client->ethumb, fps);
}
@ -1999,7 +2015,8 @@ ethumb_client_document_page_set(Ethumb_Client *client, unsigned int page)
{
EINA_SAFETY_ON_NULL_RETURN(client);
client->ethumb_dirty = 1;
if (!client->old_ethumb_conf)
client->old_ethumb_conf = ethumb_dup(client->ethumb);
ethumb_document_page_set(client->ethumb, page);
}
@ -2291,8 +2308,13 @@ ethumb_client_generate(Ethumb_Client *client, Ethumb_Client_Generate_Cb generate
ethumb_thumb_path_get(client->ethumb, &thumb, &thumb_key);
if (client->ethumb_dirty)
ethumb_client_ethumb_setup(client);
if (client->old_ethumb_conf &&
ethumb_cmp(client->old_ethumb_conf, client->ethumb))
{
ethumb_client_ethumb_setup(client);
ethumb_free(client->old_ethumb_conf);
client->old_ethumb_conf = NULL;
}
id = _ethumb_client_queue_add(client, file, key, thumb, thumb_key,
generated_cb, data, free_data);