mirror of
https://git.pwmt.org/pwmt/zathura.git
synced 2025-01-27 15:07:51 +01:00
Refactor
This commit is contained in:
parent
0c395610ff
commit
ab78c1ddb0
1 changed files with 161 additions and 304 deletions
465
zathura/render.c
465
zathura/render.c
|
@ -15,8 +15,8 @@
|
|||
|
||||
/* private data for ZathuraRenderer */
|
||||
typedef struct private_s {
|
||||
GThreadPool* pool; /**< Pool of threads */
|
||||
GMutex mutex; /**< Render lock */
|
||||
GThreadPool* pool; /**< Pool of threads */
|
||||
GMutex mutex; /**< Render lock */
|
||||
volatile bool about_to_close; /**< Render thread is to be freed */
|
||||
|
||||
/**
|
||||
|
@ -56,7 +56,8 @@ typedef struct request_private_s {
|
|||
|
||||
/* define the two types */
|
||||
G_DEFINE_TYPE_WITH_CODE(ZathuraRenderer, zathura_renderer, G_TYPE_OBJECT, G_ADD_PRIVATE(ZathuraRenderer))
|
||||
G_DEFINE_TYPE_WITH_CODE(ZathuraRenderRequest, zathura_render_request, G_TYPE_OBJECT, G_ADD_PRIVATE(ZathuraRenderRequest))
|
||||
G_DEFINE_TYPE_WITH_CODE(ZathuraRenderRequest, zathura_render_request, G_TYPE_OBJECT,
|
||||
G_ADD_PRIVATE(ZathuraRenderRequest))
|
||||
|
||||
/* private methods for ZathuraRenderer */
|
||||
static void renderer_finalize(GObject* object);
|
||||
|
@ -78,31 +79,27 @@ typedef struct render_job_s {
|
|||
|
||||
/* init, new and free for ZathuraRenderer */
|
||||
|
||||
static void
|
||||
zathura_renderer_class_init(ZathuraRendererClass* class)
|
||||
{
|
||||
static void zathura_renderer_class_init(ZathuraRendererClass* class) {
|
||||
/* overwrite methods */
|
||||
GObjectClass* object_class = G_OBJECT_CLASS(class);
|
||||
object_class->finalize = renderer_finalize;
|
||||
}
|
||||
|
||||
static void
|
||||
zathura_renderer_init(ZathuraRenderer* renderer)
|
||||
{
|
||||
static void zathura_renderer_init(ZathuraRenderer* renderer) {
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
priv->pool = g_thread_pool_new(render_job, renderer, 1, TRUE, NULL);
|
||||
priv->about_to_close = false;
|
||||
priv->pool = g_thread_pool_new(render_job, renderer, 1, TRUE, NULL);
|
||||
priv->about_to_close = false;
|
||||
g_thread_pool_set_sort_function(priv->pool, render_thread_sort, NULL);
|
||||
g_mutex_init(&priv->mutex);
|
||||
|
||||
/* recolor */
|
||||
priv->recolor.enabled = false;
|
||||
priv->recolor.hue = true;
|
||||
priv->recolor.enabled = false;
|
||||
priv->recolor.hue = true;
|
||||
priv->recolor.reverse_video = false;
|
||||
|
||||
/* page cache */
|
||||
priv->page_cache.size = 0;
|
||||
priv->page_cache.cache = NULL;
|
||||
priv->page_cache.size = 0;
|
||||
priv->page_cache.cache = NULL;
|
||||
priv->page_cache.num_cached_pages = 0;
|
||||
|
||||
zathura_renderer_set_recolor_colors_str(renderer, "#000000", "#FFFFFF");
|
||||
|
@ -110,9 +107,7 @@ zathura_renderer_init(ZathuraRenderer* renderer)
|
|||
priv->requests = girara_list_new();
|
||||
}
|
||||
|
||||
static bool
|
||||
page_cache_init(ZathuraRenderer* renderer, size_t cache_size)
|
||||
{
|
||||
static bool page_cache_init(ZathuraRenderer* renderer, size_t cache_size) {
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
|
||||
priv->page_cache.size = cache_size;
|
||||
|
@ -125,12 +120,10 @@ page_cache_init(ZathuraRenderer* renderer, size_t cache_size)
|
|||
return true;
|
||||
}
|
||||
|
||||
ZathuraRenderer*
|
||||
zathura_renderer_new(size_t cache_size)
|
||||
{
|
||||
ZathuraRenderer* zathura_renderer_new(size_t cache_size) {
|
||||
g_return_val_if_fail(cache_size > 0, NULL);
|
||||
|
||||
GObject* obj = g_object_new(ZATHURA_TYPE_RENDERER, NULL);
|
||||
GObject* obj = g_object_new(ZATHURA_TYPE_RENDERER, NULL);
|
||||
ZathuraRenderer* ret = ZATHURA_RENDERER(obj);
|
||||
|
||||
if (page_cache_init(ret, cache_size) == false) {
|
||||
|
@ -141,10 +134,8 @@ zathura_renderer_new(size_t cache_size)
|
|||
return ret;
|
||||
}
|
||||
|
||||
static void
|
||||
renderer_finalize(GObject* object)
|
||||
{
|
||||
ZathuraRenderer* renderer = ZATHURA_RENDERER(object);
|
||||
static void renderer_finalize(GObject* object) {
|
||||
ZathuraRenderer* renderer = ZATHURA_RENDERER(object);
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
|
||||
zathura_renderer_stop(renderer);
|
||||
|
@ -159,18 +150,12 @@ renderer_finalize(GObject* object)
|
|||
|
||||
/* (un)register requests at the renderer */
|
||||
|
||||
static void
|
||||
renderer_unregister_request(ZathuraRenderer* renderer,
|
||||
ZathuraRenderRequest* request)
|
||||
{
|
||||
static void renderer_unregister_request(ZathuraRenderer* renderer, ZathuraRenderRequest* request) {
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
girara_list_remove(priv->requests, request);
|
||||
}
|
||||
|
||||
static void
|
||||
renderer_register_request(ZathuraRenderer* renderer,
|
||||
ZathuraRenderRequest* request)
|
||||
{
|
||||
static void renderer_register_request(ZathuraRenderer* renderer, ZathuraRenderRequest* request) {
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
if (girara_list_contains(priv->requests, request) == false) {
|
||||
girara_list_append(priv->requests, request);
|
||||
|
@ -179,66 +164,35 @@ renderer_register_request(ZathuraRenderer* renderer,
|
|||
|
||||
/* init, new and free for ZathuraRenderRequest */
|
||||
|
||||
enum {
|
||||
REQUEST_COMPLETED,
|
||||
REQUEST_CACHE_ADDED,
|
||||
REQUEST_CACHE_INVALIDATED,
|
||||
REQUEST_LAST_SIGNAL
|
||||
};
|
||||
enum { REQUEST_COMPLETED, REQUEST_CACHE_ADDED, REQUEST_CACHE_INVALIDATED, REQUEST_LAST_SIGNAL };
|
||||
|
||||
static guint request_signals[REQUEST_LAST_SIGNAL] = { 0 };
|
||||
static guint request_signals[REQUEST_LAST_SIGNAL] = {0};
|
||||
|
||||
static void
|
||||
zathura_render_request_class_init(ZathuraRenderRequestClass* class)
|
||||
{
|
||||
static void zathura_render_request_class_init(ZathuraRenderRequestClass* class) {
|
||||
/* overwrite methods */
|
||||
GObjectClass* object_class = G_OBJECT_CLASS(class);
|
||||
object_class->dispose = render_request_dispose;
|
||||
object_class->finalize = render_request_finalize;
|
||||
|
||||
request_signals[REQUEST_COMPLETED] = g_signal_new("completed",
|
||||
ZATHURA_TYPE_RENDER_REQUEST,
|
||||
G_SIGNAL_RUN_LAST,
|
||||
0,
|
||||
NULL,
|
||||
NULL,
|
||||
g_cclosure_marshal_generic,
|
||||
G_TYPE_NONE,
|
||||
1,
|
||||
G_TYPE_POINTER);
|
||||
request_signals[REQUEST_COMPLETED] =
|
||||
g_signal_new("completed", ZATHURA_TYPE_RENDER_REQUEST, G_SIGNAL_RUN_LAST, 0, NULL, NULL,
|
||||
g_cclosure_marshal_generic, G_TYPE_NONE, 1, G_TYPE_POINTER);
|
||||
|
||||
request_signals[REQUEST_CACHE_ADDED] = g_signal_new("cache-added",
|
||||
ZATHURA_TYPE_RENDER_REQUEST,
|
||||
G_SIGNAL_RUN_LAST,
|
||||
0,
|
||||
NULL,
|
||||
NULL,
|
||||
g_cclosure_marshal_generic,
|
||||
G_TYPE_NONE,
|
||||
0);
|
||||
request_signals[REQUEST_CACHE_ADDED] = g_signal_new("cache-added", ZATHURA_TYPE_RENDER_REQUEST, G_SIGNAL_RUN_LAST, 0,
|
||||
NULL, NULL, g_cclosure_marshal_generic, G_TYPE_NONE, 0);
|
||||
|
||||
request_signals[REQUEST_CACHE_INVALIDATED] = g_signal_new("cache-invalidated",
|
||||
ZATHURA_TYPE_RENDER_REQUEST,
|
||||
G_SIGNAL_RUN_LAST,
|
||||
0,
|
||||
NULL,
|
||||
NULL,
|
||||
g_cclosure_marshal_generic,
|
||||
G_TYPE_NONE,
|
||||
0);
|
||||
request_signals[REQUEST_CACHE_INVALIDATED] =
|
||||
g_signal_new("cache-invalidated", ZATHURA_TYPE_RENDER_REQUEST, G_SIGNAL_RUN_LAST, 0, NULL, NULL,
|
||||
g_cclosure_marshal_generic, G_TYPE_NONE, 0);
|
||||
}
|
||||
|
||||
static void
|
||||
zathura_render_request_init(ZathuraRenderRequest* request)
|
||||
{
|
||||
static void zathura_render_request_init(ZathuraRenderRequest* request) {
|
||||
ZathuraRenderRequestPrivate* priv = zathura_render_request_get_instance_private(request);
|
||||
priv->renderer = NULL;
|
||||
priv->page = NULL;
|
||||
priv->renderer = NULL;
|
||||
priv->page = NULL;
|
||||
}
|
||||
|
||||
ZathuraRenderRequest*
|
||||
zathura_render_request_new(ZathuraRenderer* renderer, zathura_page_t* page)
|
||||
{
|
||||
ZathuraRenderRequest* zathura_render_request_new(ZathuraRenderer* renderer, zathura_page_t* page) {
|
||||
g_return_val_if_fail(renderer != NULL && page != NULL, NULL);
|
||||
|
||||
GObject* obj = g_object_new(ZATHURA_TYPE_RENDER_REQUEST, NULL);
|
||||
|
@ -246,11 +200,11 @@ zathura_render_request_new(ZathuraRenderer* renderer, zathura_page_t* page)
|
|||
return NULL;
|
||||
}
|
||||
|
||||
ZathuraRenderRequest* request = ZATHURA_RENDER_REQUEST(obj);
|
||||
ZathuraRenderRequest* request = ZATHURA_RENDER_REQUEST(obj);
|
||||
ZathuraRenderRequestPrivate* priv = zathura_render_request_get_instance_private(request);
|
||||
/* we want to make sure that renderer lives long enough */
|
||||
priv->renderer = g_object_ref(renderer);
|
||||
priv->page = page;
|
||||
priv->renderer = g_object_ref(renderer);
|
||||
priv->page = page;
|
||||
priv->active_jobs = girara_list_new();
|
||||
g_mutex_init(&priv->jobs_mutex);
|
||||
priv->render_plain = false;
|
||||
|
@ -261,10 +215,8 @@ zathura_render_request_new(ZathuraRenderer* renderer, zathura_page_t* page)
|
|||
return request;
|
||||
}
|
||||
|
||||
static void
|
||||
render_request_dispose(GObject* object)
|
||||
{
|
||||
ZathuraRenderRequest* request = ZATHURA_RENDER_REQUEST(object);
|
||||
static void render_request_dispose(GObject* object) {
|
||||
ZathuraRenderRequest* request = ZATHURA_RENDER_REQUEST(object);
|
||||
ZathuraRenderRequestPrivate* priv = zathura_render_request_get_instance_private(request);
|
||||
|
||||
if (priv->renderer != NULL) {
|
||||
|
@ -277,10 +229,8 @@ render_request_dispose(GObject* object)
|
|||
G_OBJECT_CLASS(zathura_render_request_parent_class)->dispose(object);
|
||||
}
|
||||
|
||||
static void
|
||||
render_request_finalize(GObject* object)
|
||||
{
|
||||
ZathuraRenderRequest* request = ZATHURA_RENDER_REQUEST(object);
|
||||
static void render_request_finalize(GObject* object) {
|
||||
ZathuraRenderRequest* request = ZATHURA_RENDER_REQUEST(object);
|
||||
ZathuraRenderRequestPrivate* priv = zathura_render_request_get_instance_private(request);
|
||||
|
||||
if (girara_list_size(priv->active_jobs) != 0) {
|
||||
|
@ -294,63 +244,48 @@ render_request_finalize(GObject* object)
|
|||
|
||||
/* renderer methods */
|
||||
|
||||
bool
|
||||
zathura_renderer_recolor_enabled(ZathuraRenderer* renderer)
|
||||
{
|
||||
bool zathura_renderer_recolor_enabled(ZathuraRenderer* renderer) {
|
||||
g_return_val_if_fail(ZATHURA_IS_RENDERER(renderer), false);
|
||||
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
return priv->recolor.enabled;
|
||||
}
|
||||
|
||||
void
|
||||
zathura_renderer_enable_recolor(ZathuraRenderer* renderer, bool enable)
|
||||
{
|
||||
void zathura_renderer_enable_recolor(ZathuraRenderer* renderer, bool enable) {
|
||||
g_return_if_fail(ZATHURA_IS_RENDERER(renderer));
|
||||
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
priv->recolor.enabled = enable;
|
||||
priv->recolor.enabled = enable;
|
||||
}
|
||||
|
||||
bool
|
||||
zathura_renderer_recolor_hue_enabled(ZathuraRenderer* renderer)
|
||||
{
|
||||
bool zathura_renderer_recolor_hue_enabled(ZathuraRenderer* renderer) {
|
||||
g_return_val_if_fail(ZATHURA_IS_RENDERER(renderer), false);
|
||||
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
return priv->recolor.hue;
|
||||
}
|
||||
|
||||
void
|
||||
zathura_renderer_enable_recolor_hue(ZathuraRenderer* renderer, bool enable)
|
||||
{
|
||||
void zathura_renderer_enable_recolor_hue(ZathuraRenderer* renderer, bool enable) {
|
||||
g_return_if_fail(ZATHURA_IS_RENDERER(renderer));
|
||||
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
priv->recolor.hue = enable;
|
||||
priv->recolor.hue = enable;
|
||||
}
|
||||
|
||||
bool
|
||||
zathura_renderer_recolor_reverse_video_enabled(ZathuraRenderer* renderer)
|
||||
{
|
||||
bool zathura_renderer_recolor_reverse_video_enabled(ZathuraRenderer* renderer) {
|
||||
g_return_val_if_fail(ZATHURA_IS_RENDERER(renderer), false);
|
||||
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
return priv->recolor.reverse_video;
|
||||
}
|
||||
|
||||
void
|
||||
zathura_renderer_enable_recolor_reverse_video(ZathuraRenderer* renderer, bool enable)
|
||||
{
|
||||
void zathura_renderer_enable_recolor_reverse_video(ZathuraRenderer* renderer, bool enable) {
|
||||
g_return_if_fail(ZATHURA_IS_RENDERER(renderer));
|
||||
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
priv->recolor.reverse_video = enable;
|
||||
priv->recolor.reverse_video = enable;
|
||||
}
|
||||
void
|
||||
zathura_renderer_set_recolor_colors(ZathuraRenderer* renderer,
|
||||
const GdkRGBA* light, const GdkRGBA* dark)
|
||||
{
|
||||
void zathura_renderer_set_recolor_colors(ZathuraRenderer* renderer, const GdkRGBA* light, const GdkRGBA* dark) {
|
||||
g_return_if_fail(ZATHURA_IS_RENDERER(renderer));
|
||||
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
|
@ -362,10 +297,7 @@ zathura_renderer_set_recolor_colors(ZathuraRenderer* renderer,
|
|||
}
|
||||
}
|
||||
|
||||
void
|
||||
zathura_renderer_set_recolor_colors_str(ZathuraRenderer* renderer,
|
||||
const char* light, const char* dark)
|
||||
{
|
||||
void zathura_renderer_set_recolor_colors_str(ZathuraRenderer* renderer, const char* light, const char* dark) {
|
||||
g_return_if_fail(ZATHURA_IS_RENDERER(renderer));
|
||||
|
||||
if (dark != NULL) {
|
||||
|
@ -382,10 +314,7 @@ zathura_renderer_set_recolor_colors_str(ZathuraRenderer* renderer,
|
|||
}
|
||||
}
|
||||
|
||||
void
|
||||
zathura_renderer_get_recolor_colors(ZathuraRenderer* renderer,
|
||||
GdkRGBA* light, GdkRGBA* dark)
|
||||
{
|
||||
void zathura_renderer_get_recolor_colors(ZathuraRenderer* renderer, GdkRGBA* light, GdkRGBA* dark) {
|
||||
g_return_if_fail(ZATHURA_IS_RENDERER(renderer));
|
||||
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
|
@ -397,33 +326,26 @@ zathura_renderer_get_recolor_colors(ZathuraRenderer* renderer,
|
|||
}
|
||||
}
|
||||
|
||||
void
|
||||
zathura_renderer_lock(ZathuraRenderer* renderer)
|
||||
{
|
||||
void zathura_renderer_lock(ZathuraRenderer* renderer) {
|
||||
g_return_if_fail(ZATHURA_IS_RENDERER(renderer));
|
||||
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
g_mutex_lock(&priv->mutex);
|
||||
}
|
||||
|
||||
void
|
||||
zathura_renderer_unlock(ZathuraRenderer* renderer)
|
||||
{
|
||||
void zathura_renderer_unlock(ZathuraRenderer* renderer) {
|
||||
g_return_if_fail(ZATHURA_IS_RENDERER(renderer));
|
||||
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
g_mutex_unlock(&priv->mutex);
|
||||
}
|
||||
|
||||
void
|
||||
zathura_renderer_stop(ZathuraRenderer* renderer)
|
||||
{
|
||||
void zathura_renderer_stop(ZathuraRenderer* renderer) {
|
||||
g_return_if_fail(ZATHURA_IS_RENDERER(renderer));
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
priv->about_to_close = true;
|
||||
priv->about_to_close = true;
|
||||
}
|
||||
|
||||
|
||||
/* ZathuraRenderRequest methods */
|
||||
|
||||
void zathura_render_request(ZathuraRenderRequest* request, gint64 last_view_time) {
|
||||
|
@ -475,20 +397,16 @@ void zathura_render_request_abort(ZathuraRenderRequest* request) {
|
|||
g_mutex_unlock(&request_priv->jobs_mutex);
|
||||
}
|
||||
|
||||
void
|
||||
zathura_render_request_update_view_time(ZathuraRenderRequest* request)
|
||||
{
|
||||
void zathura_render_request_update_view_time(ZathuraRenderRequest* request) {
|
||||
g_return_if_fail(ZATHURA_IS_RENDER_REQUEST(request));
|
||||
|
||||
ZathuraRenderRequestPrivate* request_priv = zathura_render_request_get_instance_private(request);
|
||||
request_priv->last_view_time = g_get_real_time();
|
||||
request_priv->last_view_time = g_get_real_time();
|
||||
}
|
||||
|
||||
/* render job */
|
||||
|
||||
static void
|
||||
remove_job_and_free(render_job_t* job)
|
||||
{
|
||||
static void remove_job_and_free(render_job_t* job) {
|
||||
ZathuraRenderRequestPrivate* request_priv = zathura_render_request_get_instance_private(job->request);
|
||||
|
||||
g_mutex_lock(&request_priv->jobs_mutex);
|
||||
|
@ -499,28 +417,23 @@ remove_job_and_free(render_job_t* job)
|
|||
g_free(job);
|
||||
}
|
||||
|
||||
typedef struct emit_completed_signal_s
|
||||
{
|
||||
typedef struct emit_completed_signal_s {
|
||||
render_job_t* job;
|
||||
cairo_surface_t* surface;
|
||||
} emit_completed_signal_t;
|
||||
|
||||
static gboolean
|
||||
emit_completed_signal(void* data)
|
||||
{
|
||||
emit_completed_signal_t* ecs = data;
|
||||
render_job_t* job = ecs->job;
|
||||
static gboolean emit_completed_signal(void* data) {
|
||||
emit_completed_signal_t* ecs = data;
|
||||
render_job_t* job = ecs->job;
|
||||
ZathuraRenderRequestPrivate* request_priv = zathura_render_request_get_instance_private(job->request);
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(request_priv->renderer);
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(request_priv->renderer);
|
||||
|
||||
if (priv->about_to_close == false && job->aborted == false) {
|
||||
/* emit the signal */
|
||||
girara_debug("Emitting signal for page %d",
|
||||
zathura_page_get_index(request_priv->page) + 1);
|
||||
girara_debug("Emitting signal for page %d", zathura_page_get_index(request_priv->page) + 1);
|
||||
g_signal_emit(job->request, request_signals[REQUEST_COMPLETED], 0, ecs->surface);
|
||||
} else {
|
||||
girara_debug("Rendering of page %d aborted",
|
||||
zathura_page_get_index(request_priv->page) + 1);
|
||||
girara_debug("Rendering of page %d aborted", zathura_page_get_index(request_priv->page) + 1);
|
||||
}
|
||||
/* mark the request as done */
|
||||
remove_job_and_free(job);
|
||||
|
@ -535,23 +448,21 @@ emit_completed_signal(void* data)
|
|||
/* Returns the maximum possible saturation for given h and l.
|
||||
Assumes that l is in the interval l1, l2 and corrects the value to
|
||||
force u=0 on l1 and l2 */
|
||||
static double
|
||||
colorumax(const double h[3], double l, double l1, double l2)
|
||||
{
|
||||
static double colorumax(const double h[3], double l, double l1, double l2) {
|
||||
if (fabs(h[0]) <= DBL_EPSILON && fabs(h[1]) <= DBL_EPSILON && fabs(h[2]) <= DBL_EPSILON) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
const double lv = (l - l1) / (l2 - l1); /* Remap l to the whole interval [0,1] */
|
||||
double u = DBL_MAX;
|
||||
double v = DBL_MAX;
|
||||
const double lv = (l - l1) / (l2 - l1); /* Remap l to the whole interval [0,1] */
|
||||
double u = DBL_MAX;
|
||||
double v = DBL_MAX;
|
||||
for (unsigned int k = 0; k < 3; ++k) {
|
||||
if (h[k] > DBL_EPSILON) {
|
||||
u = fmin(fabs((1-l)/h[k]), u);
|
||||
v = fmin(fabs((1-lv)/h[k]), v);
|
||||
u = fmin(fabs((1 - l) / h[k]), u);
|
||||
v = fmin(fabs((1 - lv) / h[k]), v);
|
||||
} else if (h[k] < -DBL_EPSILON) {
|
||||
u = fmin(fabs(l/h[k]), u);
|
||||
v = fmin(fabs(lv/h[k]), v);
|
||||
u = fmin(fabs(l / h[k]), u);
|
||||
v = fmin(fabs(lv / h[k]), v);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -562,10 +473,8 @@ colorumax(const double h[3], double l, double l1, double l2)
|
|||
return fmin(u, v);
|
||||
}
|
||||
|
||||
static void
|
||||
recolor(ZathuraRendererPrivate* priv, zathura_page_t* page, unsigned int page_width,
|
||||
unsigned int page_height, cairo_surface_t* surface)
|
||||
{
|
||||
static void recolor(ZathuraRendererPrivate* priv, zathura_page_t* page, unsigned int page_width,
|
||||
unsigned int page_height, cairo_surface_t* surface) {
|
||||
/* uses a representation of a rgb color as follows:
|
||||
- a lightness scalar (between 0,1), which is a weighted average of r, g, b,
|
||||
- a hue vector, which indicates a radian direction from the grey axis,
|
||||
|
@ -586,39 +495,35 @@ recolor(ZathuraRendererPrivate* priv, zathura_page_t* page, unsigned int page_wi
|
|||
unsigned char* image = cairo_image_surface_get_data(surface);
|
||||
|
||||
/* RGB weights for computing lightness. Must sum to one */
|
||||
static const double a[] = {0.30, 0.59, 0.11};
|
||||
static const double weights[] = {0.30, 0.59, 0.11};
|
||||
|
||||
const GdkRGBA rgb1 = priv->recolor.dark;
|
||||
const GdkRGBA rgb2 = priv->recolor.light;
|
||||
|
||||
const double l1 = a[0]*rgb1.red + a[1]*rgb1.green + a[2]*rgb1.blue;
|
||||
const double l2 = a[0]*rgb2.red + a[1]*rgb2.green + a[2]*rgb2.blue;
|
||||
const double l1 = weights[0] * rgb1.red + weights[1] * rgb1.green + weights[2] * rgb1.blue;
|
||||
const double l2 = weights[0] * rgb2.red + weights[1] * rgb2.green + weights[2] * rgb2.blue;
|
||||
const double negalph1 = 1. - rgb1.alpha;
|
||||
const double negalph2 = 1. - rgb2.alpha;
|
||||
|
||||
const double rgb_diff[] = {
|
||||
rgb2.red - rgb1.red,
|
||||
rgb2.green - rgb1.green,
|
||||
rgb2.blue - rgb1.blue
|
||||
};
|
||||
const double rgb_diff[] = {rgb2.red - rgb1.red, rgb2.green - rgb1.green, rgb2.blue - rgb1.blue};
|
||||
|
||||
const double h1[3] = {
|
||||
rgb1.red*rgb1.alpha - l1,
|
||||
rgb1.green*rgb1.alpha - l1,
|
||||
rgb1.blue*rgb1.alpha - l1,
|
||||
rgb1.red * rgb1.alpha - l1,
|
||||
rgb1.green * rgb1.alpha - l1,
|
||||
rgb1.blue * rgb1.alpha - l1,
|
||||
};
|
||||
|
||||
const double h2[3] = {
|
||||
rgb2.red*rgb2.alpha - l2,
|
||||
rgb2.green*rgb2.alpha - l2,
|
||||
rgb2.blue*rgb2.alpha - l2,
|
||||
rgb2.red * rgb2.alpha - l2,
|
||||
rgb2.green * rgb2.alpha - l2,
|
||||
rgb2.blue * rgb2.alpha - l2,
|
||||
};
|
||||
|
||||
/* Decide if we can use the older, faster formulas */
|
||||
const bool fast_formula = (!priv->recolor.hue || (
|
||||
fabs(rgb1.red - rgb1.blue) < DBL_EPSILON && fabs(rgb1.red - rgb1.green) < DBL_EPSILON &&
|
||||
fabs(rgb2.red - rgb2.blue) < DBL_EPSILON && fabs(rgb2.red - rgb2.green) < DBL_EPSILON
|
||||
)) && (rgb1.alpha >= 1. - DBL_EPSILON && rgb2.alpha >= 1. - DBL_EPSILON);
|
||||
const bool fast_formula =
|
||||
(!priv->recolor.hue || (fabs(rgb1.red - rgb1.blue) < DBL_EPSILON && fabs(rgb1.red - rgb1.green) < DBL_EPSILON &&
|
||||
fabs(rgb2.red - rgb2.blue) < DBL_EPSILON && fabs(rgb2.red - rgb2.green) < DBL_EPSILON)) &&
|
||||
(rgb1.alpha >= 1. - DBL_EPSILON && rgb2.alpha >= 1. - DBL_EPSILON);
|
||||
|
||||
girara_list_t* images = NULL;
|
||||
girara_list_t* rectangles = NULL;
|
||||
|
@ -626,7 +531,7 @@ recolor(ZathuraRendererPrivate* priv, zathura_page_t* page, unsigned int page_wi
|
|||
|
||||
/* If in reverse video mode retrieve images */
|
||||
if (priv->recolor.reverse_video == true) {
|
||||
images = zathura_page_images_get(page, NULL);
|
||||
images = zathura_page_images_get(page, NULL);
|
||||
found_images = (images != NULL);
|
||||
|
||||
rectangles = girara_list_new();
|
||||
|
@ -672,23 +577,15 @@ recolor(ZathuraRendererPrivate* priv, zathura_page_t* page, unsigned int page_wi
|
|||
}
|
||||
|
||||
/* Careful. data color components blue, green, red. */
|
||||
const double rgb[3] = {
|
||||
data[2] / 255.,
|
||||
data[1] / 255.,
|
||||
data[0] / 255.
|
||||
};
|
||||
const double rgb[3] = {data[2] / 255., data[1] / 255., data[0] / 255.};
|
||||
|
||||
/* compute h, s, l data */
|
||||
double l = a[0]*rgb[0] + a[1]*rgb[1] + a[2]*rgb[2];
|
||||
double l = weights[0] * rgb[0] + weights[1] * rgb[1] + weights[2] * rgb[2];
|
||||
|
||||
if (priv->recolor.hue == true) {
|
||||
/* adjusting lightness keeping hue of current color. white and black
|
||||
* go to grays of same ligtness as light and dark colors. */
|
||||
const double h[3] = {
|
||||
rgb[0] - l,
|
||||
rgb[1] - l,
|
||||
rgb[2] - l
|
||||
};
|
||||
const double h[3] = {rgb[0] - l, rgb[1] - l, rgb[2] - l};
|
||||
|
||||
/* u is the maximum possible saturation for given h and l. s is a
|
||||
* rescaled saturation between 0 and 1 */
|
||||
|
@ -703,34 +600,34 @@ recolor(ZathuraRendererPrivate* priv, zathura_page_t* page, unsigned int page_wi
|
|||
|
||||
if (fast_formula) {
|
||||
data[3] = 255;
|
||||
data[2] = (unsigned char)round(255.*(l + su * h[0]));
|
||||
data[1] = (unsigned char)round(255.*(l + su * h[1]));
|
||||
data[0] = (unsigned char)round(255.*(l + su * h[2]));
|
||||
data[2] = (unsigned char)round(255. * (l + su * h[0]));
|
||||
data[1] = (unsigned char)round(255. * (l + su * h[1]));
|
||||
data[0] = (unsigned char)round(255. * (l + su * h[2]));
|
||||
} else {
|
||||
/* Mix lightcolor, darkcolor and the original color, according to the
|
||||
* minimal and maximal channel of the original color */
|
||||
const double tr1 = (1. - fmax(fmax(rgb[0], rgb[1]), rgb[2]));
|
||||
const double tr2 = fmin(fmin(rgb[0], rgb[1]), rgb[2]);
|
||||
data[3] = (unsigned char)round(255.*(1. - tr1*negalph1 - tr2*negalph2));
|
||||
data[2] = (unsigned char)round(255.*fmin(1, fmax(0, tr1*h1[0] + tr2*h2[0] + (l + su * h[0]))));
|
||||
data[1] = (unsigned char)round(255.*fmin(1, fmax(0, tr1*h1[1] + tr2*h2[1] + (l + su * h[1]))));
|
||||
data[0] = (unsigned char)round(255.*fmin(1, fmax(0, tr1*h1[2] + tr2*h2[2] + (l + su * h[2]))));
|
||||
data[3] = (unsigned char)round(255. * (1. - tr1 * negalph1 - tr2 * negalph2));
|
||||
data[2] = (unsigned char)round(255. * fmin(1, fmax(0, tr1 * h1[0] + tr2 * h2[0] + (l + su * h[0]))));
|
||||
data[1] = (unsigned char)round(255. * fmin(1, fmax(0, tr1 * h1[1] + tr2 * h2[1] + (l + su * h[1]))));
|
||||
data[0] = (unsigned char)round(255. * fmin(1, fmax(0, tr1 * h1[2] + tr2 * h2[2] + (l + su * h[2]))));
|
||||
}
|
||||
} else {
|
||||
/* linear interpolation between dark and light with color ligtness as
|
||||
* a parameter */
|
||||
if (fast_formula) {
|
||||
data[3] = 255;
|
||||
data[2] = (unsigned char)round(255.*(l * rgb_diff[0] + rgb1.red));
|
||||
data[1] = (unsigned char)round(255.*(l * rgb_diff[1] + rgb1.green));
|
||||
data[0] = (unsigned char)round(255.*(l * rgb_diff[2] + rgb1.blue));
|
||||
data[2] = (unsigned char)round(255. * (l * rgb_diff[0] + rgb1.red));
|
||||
data[1] = (unsigned char)round(255. * (l * rgb_diff[1] + rgb1.green));
|
||||
data[0] = (unsigned char)round(255. * (l * rgb_diff[2] + rgb1.blue));
|
||||
} else {
|
||||
const double f1 = 1. - (1. - fmax(fmax(rgb[0], rgb[1]), rgb[2]))*negalph1;
|
||||
const double f2 = fmin(fmin(rgb[0], rgb[1]), rgb[2])*negalph2;
|
||||
data[3] = (unsigned char)round(255.*(f1 - f2));
|
||||
data[2] = (unsigned char)round(255.*(l * rgb_diff[0] - f2*rgb2.red + f1*rgb1.red));
|
||||
data[1] = (unsigned char)round(255.*(l * rgb_diff[1] - f2*rgb2.green + f1*rgb1.green));
|
||||
data[0] = (unsigned char)round(255.*(l * rgb_diff[2] - f2*rgb2.blue + f1*rgb1.blue));
|
||||
const double f1 = 1. - (1. - fmax(fmax(rgb[0], rgb[1]), rgb[2])) * negalph1;
|
||||
const double f2 = fmin(fmin(rgb[0], rgb[1]), rgb[2]) * negalph2;
|
||||
data[3] = (unsigned char)round(255. * (f1 - f2));
|
||||
data[2] = (unsigned char)round(255. * (l * rgb_diff[0] - f2 * rgb2.red + f1 * rgb1.red));
|
||||
data[1] = (unsigned char)round(255. * (l * rgb_diff[1] - f2 * rgb2.green + f1 * rgb1.green));
|
||||
data[0] = (unsigned char)round(255. * (l * rgb_diff[2] - f2 * rgb2.blue + f1 * rgb1.blue));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -746,9 +643,7 @@ recolor(ZathuraRendererPrivate* priv, zathura_page_t* page, unsigned int page_wi
|
|||
cairo_surface_mark_dirty(surface);
|
||||
}
|
||||
|
||||
static bool
|
||||
invoke_completed_signal(render_job_t* job, cairo_surface_t* surface)
|
||||
{
|
||||
static bool invoke_completed_signal(render_job_t* job, cairo_surface_t* surface) {
|
||||
emit_completed_signal_t* ecs = g_try_malloc0(sizeof(emit_completed_signal_t));
|
||||
if (ecs == NULL) {
|
||||
return false;
|
||||
|
@ -762,9 +657,8 @@ invoke_completed_signal(render_job_t* job, cairo_surface_t* surface)
|
|||
return true;
|
||||
}
|
||||
|
||||
static bool
|
||||
render_to_cairo_surface(cairo_surface_t* surface, zathura_page_t* page, ZathuraRenderer* renderer, double real_scale)
|
||||
{
|
||||
static bool render_to_cairo_surface(cairo_surface_t* surface, zathura_page_t* page, ZathuraRenderer* renderer,
|
||||
double real_scale) {
|
||||
cairo_t* cairo = cairo_create(surface);
|
||||
if (cairo_status(cairo) != CAIRO_STATUS_SUCCESS) {
|
||||
return false;
|
||||
|
@ -788,12 +682,10 @@ render_to_cairo_surface(cairo_surface_t* surface, zathura_page_t* page, ZathuraR
|
|||
return err == ZATHURA_ERROR_OK;
|
||||
}
|
||||
|
||||
static bool
|
||||
render(render_job_t* job, ZathuraRenderRequest* request, ZathuraRenderer* renderer)
|
||||
{
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
static bool render(render_job_t* job, ZathuraRenderRequest* request, ZathuraRenderer* renderer) {
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
ZathuraRenderRequestPrivate* request_priv = zathura_render_request_get_instance_private(request);
|
||||
zathura_page_t* page = request_priv->page;
|
||||
zathura_page_t* page = request_priv->page;
|
||||
|
||||
/* create cairo surface */
|
||||
unsigned int page_width = 0;
|
||||
|
@ -801,35 +693,32 @@ render(render_job_t* job, ZathuraRenderRequest* request, ZathuraRenderer* render
|
|||
|
||||
/* page size in points */
|
||||
zathura_document_t* document = zathura_page_get_document(page);
|
||||
const double height = zathura_page_get_height(page);
|
||||
const double width = zathura_page_get_width(page);
|
||||
const double height = zathura_page_get_height(page);
|
||||
const double width = zathura_page_get_width(page);
|
||||
|
||||
zathura_device_factors_t device_factors = { 0 };
|
||||
double real_scale = 1;
|
||||
zathura_device_factors_t device_factors = {0};
|
||||
double real_scale = 1;
|
||||
if (request_priv->render_plain == false) {
|
||||
/* page size in user pixels based on document zoom: if PPI information is
|
||||
* correct, 100% zoom will result in 72 documents points per inch of screen
|
||||
* (i.e. document size on screen matching the physical paper size). */
|
||||
real_scale = page_calc_height_width(document, height, width,
|
||||
&page_height, &page_width, false);
|
||||
real_scale = page_calc_height_width(document, height, width, &page_height, &page_width, false);
|
||||
|
||||
device_factors = zathura_document_get_device_factors(document);
|
||||
page_width *= device_factors.x;
|
||||
page_height *= device_factors.y;
|
||||
} else {
|
||||
page_width = width;
|
||||
page_width = width;
|
||||
page_height = height;
|
||||
}
|
||||
|
||||
cairo_format_t format;
|
||||
if (priv->recolor.enabled) {
|
||||
format = CAIRO_FORMAT_ARGB32;
|
||||
}
|
||||
else {
|
||||
} else {
|
||||
format = CAIRO_FORMAT_RGB24;
|
||||
}
|
||||
cairo_surface_t* surface = cairo_image_surface_create(format,
|
||||
page_width, page_height);
|
||||
cairo_surface_t* surface = cairo_image_surface_create(format, page_width, page_height);
|
||||
if (request_priv->render_plain == false) {
|
||||
cairo_surface_set_device_scale(surface, device_factors.x, device_factors.y);
|
||||
}
|
||||
|
@ -847,8 +736,7 @@ render(render_job_t* job, ZathuraRenderRequest* request, ZathuraRenderer* render
|
|||
|
||||
/* before recoloring, check if we've been aborted */
|
||||
if (priv->about_to_close == true || job->aborted == true) {
|
||||
girara_debug("Rendering of page %d aborted",
|
||||
zathura_page_get_index(request_priv->page) + 1);
|
||||
girara_debug("Rendering of page %d aborted", zathura_page_get_index(request_priv->page) + 1);
|
||||
remove_job_and_free(job);
|
||||
cairo_surface_destroy(surface);
|
||||
return true;
|
||||
|
@ -869,12 +757,10 @@ render(render_job_t* job, ZathuraRenderRequest* request, ZathuraRenderer* render
|
|||
return true;
|
||||
}
|
||||
|
||||
static void
|
||||
render_job(void* data, void* user_data)
|
||||
{
|
||||
render_job_t* job = data;
|
||||
static void render_job(void* data, void* user_data) {
|
||||
render_job_t* job = data;
|
||||
ZathuraRenderRequest* request = job->request;
|
||||
ZathuraRenderer* renderer = user_data;
|
||||
ZathuraRenderer* renderer = user_data;
|
||||
g_return_if_fail(ZATHURA_IS_RENDER_REQUEST(request));
|
||||
g_return_if_fail(ZATHURA_IS_RENDERER(renderer));
|
||||
|
||||
|
@ -886,19 +772,14 @@ render_job(void* data, void* user_data)
|
|||
}
|
||||
|
||||
ZathuraRenderRequestPrivate* request_priv = zathura_render_request_get_instance_private(request);
|
||||
girara_debug("Rendering page %d ...",
|
||||
zathura_page_get_index(request_priv->page) + 1);
|
||||
girara_debug("Rendering page %d ...", zathura_page_get_index(request_priv->page) + 1);
|
||||
if (render(job, request, renderer) != true) {
|
||||
girara_error("Rendering failed (page %d)\n",
|
||||
zathura_page_get_index(request_priv->page) + 1);
|
||||
girara_error("Rendering failed (page %d)\n", zathura_page_get_index(request_priv->page) + 1);
|
||||
remove_job_and_free(job);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
render_all(zathura_t* zathura)
|
||||
{
|
||||
void render_all(zathura_t* zathura) {
|
||||
if (zathura == NULL || zathura->document == NULL) {
|
||||
return;
|
||||
}
|
||||
|
@ -906,14 +787,14 @@ render_all(zathura_t* zathura)
|
|||
/* unmark all pages */
|
||||
const unsigned int number_of_pages = zathura_document_get_number_of_pages(zathura->document);
|
||||
for (unsigned int page_id = 0; page_id < number_of_pages; ++page_id) {
|
||||
zathura_page_t* page = zathura_document_get_page(zathura->document,
|
||||
page_id);
|
||||
zathura_page_t* page = zathura_document_get_page(zathura->document, page_id);
|
||||
unsigned int page_height = 0, page_width = 0;
|
||||
const double height = zathura_page_get_height(page);
|
||||
const double width = zathura_page_get_width(page);
|
||||
const double width = zathura_page_get_width(page);
|
||||
page_calc_height_width(zathura->document, height, width, &page_height, &page_width, true);
|
||||
|
||||
girara_debug("Queuing resize for page %u to %u x %u (%0.2f x %0.2f).", page_id, page_width, page_height, width, height);
|
||||
girara_debug("Queuing resize for page %u to %u x %u (%0.2f x %0.2f).", page_id, page_width, page_height, width,
|
||||
height);
|
||||
GtkWidget* widget = zathura_page_get_widget(zathura, page);
|
||||
if (widget != NULL) {
|
||||
gtk_widget_set_size_request(widget, page_width, page_height);
|
||||
|
@ -922,9 +803,7 @@ render_all(zathura_t* zathura)
|
|||
}
|
||||
}
|
||||
|
||||
static gint
|
||||
render_thread_sort(gconstpointer a, gconstpointer b, gpointer UNUSED(data))
|
||||
{
|
||||
static gint render_thread_sort(gconstpointer a, gconstpointer b, gpointer UNUSED(data)) {
|
||||
if (a == NULL || b == NULL) {
|
||||
return 0;
|
||||
}
|
||||
|
@ -935,8 +814,8 @@ render_thread_sort(gconstpointer a, gconstpointer b, gpointer UNUSED(data))
|
|||
ZathuraRenderRequestPrivate* priv_a = zathura_render_request_get_instance_private(job_a->request);
|
||||
ZathuraRenderRequestPrivate* priv_b = zathura_render_request_get_instance_private(job_b->request);
|
||||
|
||||
return priv_a->last_view_time < priv_b->last_view_time ? -1 :
|
||||
(priv_a->last_view_time > priv_b->last_view_time ? 1 : 0);
|
||||
return priv_a->last_view_time < priv_b->last_view_time ? -1
|
||||
: (priv_a->last_view_time > priv_b->last_view_time ? 1 : 0);
|
||||
}
|
||||
|
||||
/* sort aborted entries earlier so that they are thrown out of the queue */
|
||||
|
@ -945,16 +824,13 @@ render_thread_sort(gconstpointer a, gconstpointer b, gpointer UNUSED(data))
|
|||
|
||||
/* cache functions */
|
||||
|
||||
static bool
|
||||
page_cache_is_cached(ZathuraRenderer* renderer, unsigned int page_index)
|
||||
{
|
||||
static bool page_cache_is_cached(ZathuraRenderer* renderer, unsigned int page_index) {
|
||||
g_return_val_if_fail(renderer != NULL, false);
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
|
||||
if (priv->page_cache.num_cached_pages != 0) {
|
||||
for (size_t i = 0; i < priv->page_cache.size; ++i) {
|
||||
if (priv->page_cache.cache[i] >= 0 &&
|
||||
page_index == (unsigned int)priv->page_cache.cache[i]) {
|
||||
if (priv->page_cache.cache[i] >= 0 && page_index == (unsigned int)priv->page_cache.cache[i]) {
|
||||
girara_debug("Page %d is a cache hit", page_index + 1);
|
||||
return true;
|
||||
}
|
||||
|
@ -965,10 +841,8 @@ page_cache_is_cached(ZathuraRenderer* renderer, unsigned int page_index)
|
|||
return false;
|
||||
}
|
||||
|
||||
static int
|
||||
find_request_by_page_index(const void* req, const void* data)
|
||||
{
|
||||
ZathuraRenderRequest* request = (void*) req;
|
||||
static int find_request_by_page_index(const void* req, const void* data) {
|
||||
ZathuraRenderRequest* request = (void*)req;
|
||||
const unsigned int page_index = *((const int*)data);
|
||||
|
||||
ZathuraRenderRequestPrivate* priv = zathura_render_request_get_instance_private(request);
|
||||
|
@ -978,26 +852,24 @@ find_request_by_page_index(const void* req, const void* data)
|
|||
return 1;
|
||||
}
|
||||
|
||||
static ssize_t
|
||||
page_cache_lru_invalidate(ZathuraRenderer* renderer)
|
||||
{
|
||||
static ssize_t page_cache_lru_invalidate(ZathuraRenderer* renderer) {
|
||||
g_return_val_if_fail(renderer != NULL, -1);
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
g_return_val_if_fail(priv->page_cache.size != 0, -1);
|
||||
|
||||
ssize_t lru_index = 0;
|
||||
gint64 lru_view_time = G_MAXINT64;
|
||||
ssize_t lru_index = 0;
|
||||
gint64 lru_view_time = G_MAXINT64;
|
||||
ZathuraRenderRequest* request = NULL;
|
||||
for (size_t i = 0; i < priv->page_cache.size; ++i) {
|
||||
ZathuraRenderRequest* tmp_request = girara_list_find(priv->requests,
|
||||
find_request_by_page_index, &priv->page_cache.cache[i]);
|
||||
ZathuraRenderRequest* tmp_request =
|
||||
girara_list_find(priv->requests, find_request_by_page_index, &priv->page_cache.cache[i]);
|
||||
g_return_val_if_fail(tmp_request != NULL, -1);
|
||||
ZathuraRenderRequestPrivate* request_priv = zathura_render_request_get_instance_private(tmp_request);
|
||||
|
||||
if (request_priv->last_view_time < lru_view_time) {
|
||||
lru_view_time = request_priv->last_view_time;
|
||||
lru_index = i;
|
||||
request = tmp_request;
|
||||
lru_index = i;
|
||||
request = tmp_request;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1005,28 +877,23 @@ page_cache_lru_invalidate(ZathuraRenderer* renderer)
|
|||
|
||||
/* emit the signal */
|
||||
g_signal_emit(request, request_signals[REQUEST_CACHE_INVALIDATED], 0);
|
||||
girara_debug("Invalidated page %d at cache index %zd",
|
||||
zathura_page_get_index(request_priv->page) + 1, lru_index);
|
||||
girara_debug("Invalidated page %d at cache index %zd", zathura_page_get_index(request_priv->page) + 1, lru_index);
|
||||
priv->page_cache.cache[lru_index] = -1;
|
||||
--priv->page_cache.num_cached_pages;
|
||||
|
||||
return lru_index;
|
||||
}
|
||||
|
||||
static bool
|
||||
page_cache_is_full(ZathuraRenderer* renderer, bool* result)
|
||||
{
|
||||
static bool page_cache_is_full(ZathuraRenderer* renderer, bool* result) {
|
||||
g_return_val_if_fail(ZATHURA_IS_RENDERER(renderer) && result != NULL, false);
|
||||
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
*result = priv->page_cache.num_cached_pages == priv->page_cache.size;
|
||||
*result = priv->page_cache.num_cached_pages == priv->page_cache.size;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
static void
|
||||
page_cache_invalidate_all(ZathuraRenderer* renderer)
|
||||
{
|
||||
static void page_cache_invalidate_all(ZathuraRenderer* renderer) {
|
||||
g_return_if_fail(ZATHURA_IS_RENDERER(renderer));
|
||||
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
|
@ -1036,17 +903,14 @@ page_cache_invalidate_all(ZathuraRenderer* renderer)
|
|||
priv->page_cache.num_cached_pages = 0;
|
||||
}
|
||||
|
||||
void
|
||||
zathura_renderer_page_cache_add(ZathuraRenderer* renderer,
|
||||
unsigned int page_index)
|
||||
{
|
||||
void zathura_renderer_page_cache_add(ZathuraRenderer* renderer, unsigned int page_index) {
|
||||
g_return_if_fail(ZATHURA_IS_RENDERER(renderer));
|
||||
if (page_cache_is_cached(renderer, page_index) == true) {
|
||||
return;
|
||||
}
|
||||
|
||||
ZathuraRendererPrivate* priv = zathura_renderer_get_instance_private(renderer);
|
||||
bool full = false;
|
||||
bool full = false;
|
||||
if (page_cache_is_full(renderer, &full) == false) {
|
||||
return;
|
||||
} else if (full == true) {
|
||||
|
@ -1060,31 +924,24 @@ zathura_renderer_page_cache_add(ZathuraRenderer* renderer,
|
|||
girara_debug("Page %d is cached at cache index %zd", page_index + 1, idx);
|
||||
} else {
|
||||
priv->page_cache.cache[priv->page_cache.num_cached_pages++] = page_index;
|
||||
girara_debug("Page %d is cached at cache index %zu", page_index + 1,
|
||||
priv->page_cache.num_cached_pages - 1);
|
||||
girara_debug("Page %d is cached at cache index %zu", page_index + 1, priv->page_cache.num_cached_pages - 1);
|
||||
}
|
||||
|
||||
ZathuraRenderRequest* request = girara_list_find(priv->requests,
|
||||
find_request_by_page_index, &page_index);
|
||||
ZathuraRenderRequest* request = girara_list_find(priv->requests, find_request_by_page_index, &page_index);
|
||||
g_return_if_fail(request != NULL);
|
||||
g_signal_emit(request, request_signals[REQUEST_CACHE_ADDED], 0);
|
||||
}
|
||||
|
||||
void zathura_render_request_set_render_plain(ZathuraRenderRequest* request,
|
||||
bool render_plain)
|
||||
{
|
||||
void zathura_render_request_set_render_plain(ZathuraRenderRequest* request, bool render_plain) {
|
||||
g_return_if_fail(ZATHURA_IS_RENDER_REQUEST(request));
|
||||
|
||||
ZathuraRenderRequestPrivate* priv = zathura_render_request_get_instance_private(request);
|
||||
priv->render_plain =render_plain;
|
||||
priv->render_plain = render_plain;
|
||||
}
|
||||
|
||||
bool
|
||||
zathura_render_request_get_render_plain(ZathuraRenderRequest* request)
|
||||
{
|
||||
bool zathura_render_request_get_render_plain(ZathuraRenderRequest* request) {
|
||||
g_return_val_if_fail(ZATHURA_IS_RENDER_REQUEST(request), false);
|
||||
|
||||
ZathuraRenderRequestPrivate* priv = zathura_render_request_get_instance_private(request);
|
||||
return priv->render_plain;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue