mirror of
https://git.pwmt.org/pwmt/zathura.git
synced 2025-01-15 03:25:59 +01:00
Added mutex for scale variable
This commit is contained in:
parent
e4abffa259
commit
229ebe0a29
1 changed files with 25 additions and 1 deletions
26
zathura.c
26
zathura.c
|
@ -160,6 +160,12 @@ struct
|
||||||
GtkLabel *status_state;
|
GtkLabel *status_state;
|
||||||
} Global;
|
} Global;
|
||||||
|
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
pthread_mutex_t scale_lock;
|
||||||
|
pthread_mutex_t rotate_lock;
|
||||||
|
} Lock;
|
||||||
|
|
||||||
struct
|
struct
|
||||||
{
|
{
|
||||||
char* filename;
|
char* filename;
|
||||||
|
@ -245,6 +251,10 @@ gboolean cb_inputbar_activate(GtkEntry*, gpointer);
|
||||||
void
|
void
|
||||||
init_zathura()
|
init_zathura()
|
||||||
{
|
{
|
||||||
|
/* mutexes */
|
||||||
|
pthread_mutex_init(&(Zathura.Lock.scale_lock), NULL);
|
||||||
|
pthread_mutex_init(&(Zathura.Lock.rotate_lock), NULL);
|
||||||
|
|
||||||
/* look */
|
/* look */
|
||||||
gdk_color_parse(default_fgcolor, &(Zathura.Style.default_fg));
|
gdk_color_parse(default_fgcolor, &(Zathura.Style.default_fg));
|
||||||
gdk_color_parse(default_bgcolor, &(Zathura.Style.default_bg));
|
gdk_color_parse(default_bgcolor, &(Zathura.Style.default_bg));
|
||||||
|
@ -363,7 +373,10 @@ void draw(int page_id)
|
||||||
|
|
||||||
double page_width, page_height;
|
double page_width, page_height;
|
||||||
double width, height;
|
double width, height;
|
||||||
|
|
||||||
|
pthread_mutex_lock(&(Zathura.Lock.scale_lock));
|
||||||
double scale = ((double) Zathura.PDF.scale / 100.0);
|
double scale = ((double) Zathura.PDF.scale / 100.0);
|
||||||
|
pthread_mutex_unlock(&(Zathura.Lock.scale_lock));
|
||||||
|
|
||||||
Page *current_page = Zathura.PDF.pages[page_id];
|
Page *current_page = Zathura.PDF.pages[page_id];
|
||||||
|
|
||||||
|
@ -477,10 +490,11 @@ update_status()
|
||||||
gtk_label_set_markup((GtkLabel*) Zathura.Global.status_text, Zathura.State.filename);
|
gtk_label_set_markup((GtkLabel*) Zathura.Global.status_text, Zathura.State.filename);
|
||||||
|
|
||||||
/* update state */
|
/* update state */
|
||||||
|
pthread_mutex_lock(&(Zathura.Lock.scale_lock));
|
||||||
char* zoom_level = (Zathura.PDF.scale != 0) ? g_strdup_printf("%d%%", Zathura.PDF.scale) : "";
|
char* zoom_level = (Zathura.PDF.scale != 0) ? g_strdup_printf("%d%%", Zathura.PDF.scale) : "";
|
||||||
|
pthread_mutex_unlock(&(Zathura.Lock.scale_lock));
|
||||||
char* status_text = g_strdup_printf("%s %s", zoom_level, Zathura.State.pages);
|
char* status_text = g_strdup_printf("%s %s", zoom_level, Zathura.State.pages);
|
||||||
gtk_label_set_markup((GtkLabel*) Zathura.Global.status_state, status_text);
|
gtk_label_set_markup((GtkLabel*) Zathura.Global.status_state, status_text);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
GtkEventBox*
|
GtkEventBox*
|
||||||
|
@ -1076,7 +1090,9 @@ cmd_open(int argc, char** argv)
|
||||||
|
|
||||||
Zathura.PDF.number_of_pages = poppler_document_get_n_pages(Zathura.PDF.document);
|
Zathura.PDF.number_of_pages = poppler_document_get_n_pages(Zathura.PDF.document);
|
||||||
Zathura.PDF.file = file;
|
Zathura.PDF.file = file;
|
||||||
|
pthread_mutex_lock(&(Zathura.Lock.scale_lock));
|
||||||
Zathura.PDF.scale = 100;
|
Zathura.PDF.scale = 100;
|
||||||
|
pthread_mutex_unlock(&(Zathura.Lock.scale_lock));
|
||||||
Zathura.PDF.rotate = 0;
|
Zathura.PDF.rotate = 0;
|
||||||
Zathura.PDF.pages = malloc(Zathura.PDF.number_of_pages * sizeof(Page*));
|
Zathura.PDF.pages = malloc(Zathura.PDF.number_of_pages * sizeof(Page*));
|
||||||
Zathura.State.filename = file;
|
Zathura.State.filename = file;
|
||||||
|
@ -1238,6 +1254,7 @@ bcmd_goto(char* buffer, Argument* argument)
|
||||||
void
|
void
|
||||||
bcmd_zoom(char* buffer, Argument* argument)
|
bcmd_zoom(char* buffer, Argument* argument)
|
||||||
{
|
{
|
||||||
|
pthread_mutex_lock(&(Zathura.Lock.scale_lock));
|
||||||
if(argument->n == ZOOM_IN)
|
if(argument->n == ZOOM_IN)
|
||||||
{
|
{
|
||||||
if((Zathura.PDF.scale + ZOOM_STEP) <= ZOOM_MAX)
|
if((Zathura.PDF.scale + ZOOM_STEP) <= ZOOM_MAX)
|
||||||
|
@ -1250,6 +1267,7 @@ bcmd_zoom(char* buffer, Argument* argument)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
Zathura.PDF.scale = 100;
|
Zathura.PDF.scale = 100;
|
||||||
|
pthread_mutex_unlock(&(Zathura.Lock.scale_lock));
|
||||||
|
|
||||||
if(Zathura.PDF.render_thread)
|
if(Zathura.PDF.render_thread)
|
||||||
pthread_cancel(Zathura.PDF.render_thread);
|
pthread_cancel(Zathura.PDF.render_thread);
|
||||||
|
@ -1274,6 +1292,10 @@ cb_destroy(GtkWidget* widget, gpointer data)
|
||||||
if(Zathura.PDF.document)
|
if(Zathura.PDF.document)
|
||||||
free(Zathura.PDF.pages);
|
free(Zathura.PDF.pages);
|
||||||
|
|
||||||
|
/* mutexes */
|
||||||
|
pthread_mutex_destroy(&(Zathura.Lock.scale_lock));
|
||||||
|
pthread_mutex_destroy(&(Zathura.Lock.rotate_lock));
|
||||||
|
|
||||||
gtk_main_quit();
|
gtk_main_quit();
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
@ -1291,7 +1313,9 @@ gboolean cb_draw(GtkWidget* widget, GdkEventExpose* expose, gpointer data)
|
||||||
cairo_t *cairo = gdk_cairo_create(widget->window);
|
cairo_t *cairo = gdk_cairo_create(widget->window);
|
||||||
|
|
||||||
double page_width, page_height, width, height;
|
double page_width, page_height, width, height;
|
||||||
|
pthread_mutex_lock(&(Zathura.Lock.scale_lock));
|
||||||
double scale = ((double) Zathura.PDF.scale / 100.0);
|
double scale = ((double) Zathura.PDF.scale / 100.0);
|
||||||
|
pthread_mutex_unlock(&(Zathura.Lock.scale_lock));
|
||||||
|
|
||||||
poppler_page_get_size(Zathura.PDF.pages[page_id]->page, &page_width, &page_height);
|
poppler_page_get_size(Zathura.PDF.pages[page_id]->page, &page_width, &page_height);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue