g_signal_connect(G_OBJECT(cl->il), "done", (GCallback)cache_loader_phase1_done_cb, cl);
if (image_loader_start(cl->il))
{
- return FALSE;
+ return G_SOURCE_REMOVE;
}
cl->error = TRUE;
cl->idle_id = g_idle_add(cache_loader_phase2_idle_cb, cl);
- return FALSE;
+ return G_SOURCE_REMOVE;
}
static gboolean cache_loader_phase2_process(CacheLoader *cl)
cache_sim_data_set_similarity(cl->cd, sim);
image_sim_free(sim);
- cl->todo_mask &= ~CACHE_LOADER_SIMILARITY;
- cl->done_mask |= CACHE_LOADER_SIMILARITY;
+ cl->todo_mask = static_cast<CacheDataType>(cl->todo_mask & ~CACHE_LOADER_SIMILARITY);
+ cl->done_mask = static_cast<CacheDataType>(cl->done_mask | CACHE_LOADER_SIMILARITY);
}
/* we have the dimensions via pixbuf */
gdk_pixbuf_get_height(pixbuf));
if (cl->todo_mask & CACHE_LOADER_DIMENSIONS)
{
- cl->todo_mask &= ~CACHE_LOADER_DIMENSIONS;
- cl->done_mask |= CACHE_LOADER_DIMENSIONS;
+ cl->todo_mask = static_cast<CacheDataType>(cl->todo_mask & ~CACHE_LOADER_DIMENSIONS);
+ cl->done_mask = static_cast<CacheDataType>(cl->done_mask | CACHE_LOADER_DIMENSIONS);
}
}
}
image_loader_free(cl->il);
cl->il = NULL;
- cl->todo_mask &= ~CACHE_LOADER_SIMILARITY;
+ cl->todo_mask = static_cast<CacheDataType>(cl->todo_mask & ~CACHE_LOADER_SIMILARITY);
}
else if (cl->todo_mask & CACHE_LOADER_DIMENSIONS &&
!cl->cd->dimensions)
image_load_dimensions(cl->fd, &cl->cd->width, &cl->cd->height))
{
cl->cd->dimensions = TRUE;
- cl->done_mask |= CACHE_LOADER_DIMENSIONS;
+ cl->done_mask = static_cast<CacheDataType>(cl->done_mask | CACHE_LOADER_DIMENSIONS);
}
else
{
cl->error = TRUE;
}
- cl->todo_mask &= ~CACHE_LOADER_DIMENSIONS;
+ cl->todo_mask = static_cast<CacheDataType>(cl->todo_mask & ~CACHE_LOADER_DIMENSIONS);
}
else if (cl->todo_mask & CACHE_LOADER_MD5SUM &&
!cl->cd->have_md5sum)
if (md5_get_digest_from_file_utf8(cl->fd->path, cl->cd->md5sum))
{
cl->cd->have_md5sum = TRUE;
- cl->done_mask |= CACHE_LOADER_MD5SUM;
+ cl->done_mask = static_cast<CacheDataType>(cl->done_mask | CACHE_LOADER_MD5SUM);
}
else
{
cl->error = TRUE;
}
- cl->todo_mask &= ~CACHE_LOADER_MD5SUM;
+ cl->todo_mask = static_cast<CacheDataType>(cl->todo_mask & ~CACHE_LOADER_MD5SUM);
}
else if (cl->todo_mask & CACHE_LOADER_DATE &&
!cl->cd->have_date)
cl->cd->date = date;
cl->cd->have_date = TRUE;
- cl->done_mask |= CACHE_LOADER_DATE;
- cl->todo_mask &= ~CACHE_LOADER_DATE;
+ cl->done_mask = static_cast<CacheDataType>(cl->done_mask | CACHE_LOADER_DATE);
+ cl->todo_mask = static_cast<CacheDataType>(cl->todo_mask & ~CACHE_LOADER_DATE);
}
else
{
cl->done_func(cl, cl->error, cl->done_data);
}
- return FALSE;
+ return G_SOURCE_REMOVE;
}
- return TRUE;
+ return G_SOURCE_CONTINUE;
}
static gboolean cache_loader_phase1_idle_cb(gpointer data)