mirror of
https://git.pwmt.org/pwmt/zathura.git
synced 2024-12-29 12:36:00 +01:00
Search thread
This commit is contained in:
parent
b21afc6319
commit
3972302569
1 changed files with 79 additions and 48 deletions
121
zathura.c
121
zathura.c
|
@ -181,6 +181,8 @@ struct
|
||||||
pthread_mutex_t scale_lock;
|
pthread_mutex_t scale_lock;
|
||||||
pthread_mutex_t rotate_lock;
|
pthread_mutex_t rotate_lock;
|
||||||
pthread_mutex_t render_lock;
|
pthread_mutex_t render_lock;
|
||||||
|
pthread_mutex_t search_lock;
|
||||||
|
pthread_mutex_t viewport_lock;
|
||||||
} Lock;
|
} Lock;
|
||||||
|
|
||||||
struct
|
struct
|
||||||
|
@ -199,6 +201,7 @@ struct
|
||||||
int scale;
|
int scale;
|
||||||
int rotate;
|
int rotate;
|
||||||
pthread_t render_thread;
|
pthread_t render_thread;
|
||||||
|
pthread_t search_thread;
|
||||||
} PDF;
|
} PDF;
|
||||||
|
|
||||||
} Zathura;
|
} Zathura;
|
||||||
|
@ -219,6 +222,7 @@ GtkEventBox* createCompletionRow(GtkBox*, char*, char*, gboolean);
|
||||||
|
|
||||||
/* thread declaration */
|
/* thread declaration */
|
||||||
void* render(void*);
|
void* render(void*);
|
||||||
|
void* search(void*);
|
||||||
|
|
||||||
/* shortcut declarations */
|
/* shortcut declarations */
|
||||||
void sc_abort(Argument*);
|
void sc_abort(Argument*);
|
||||||
|
@ -282,6 +286,8 @@ init_zathura()
|
||||||
pthread_mutex_init(&(Zathura.Lock.scale_lock), NULL);
|
pthread_mutex_init(&(Zathura.Lock.scale_lock), NULL);
|
||||||
pthread_mutex_init(&(Zathura.Lock.rotate_lock), NULL);
|
pthread_mutex_init(&(Zathura.Lock.rotate_lock), NULL);
|
||||||
pthread_mutex_init(&(Zathura.Lock.render_lock), NULL);
|
pthread_mutex_init(&(Zathura.Lock.render_lock), NULL);
|
||||||
|
pthread_mutex_init(&(Zathura.Lock.search_lock), NULL);
|
||||||
|
pthread_mutex_init(&(Zathura.Lock.viewport_lock), NULL);
|
||||||
|
|
||||||
/* look */
|
/* look */
|
||||||
gdk_color_parse(default_fgcolor, &(Zathura.Style.default_fg));
|
gdk_color_parse(default_fgcolor, &(Zathura.Style.default_fg));
|
||||||
|
@ -471,9 +477,12 @@ draw(int page_id)
|
||||||
current_page->surface = cairo_image_surface_create(CAIRO_FORMAT_RGB24, width, height);
|
current_page->surface = cairo_image_surface_create(CAIRO_FORMAT_RGB24, width, height);
|
||||||
cairo = cairo_create(current_page->surface);
|
cairo = cairo_create(current_page->surface);
|
||||||
|
|
||||||
|
cairo_save(cairo);
|
||||||
cairo_set_source_rgb(cairo, 1, 1, 1);
|
cairo_set_source_rgb(cairo, 1, 1, 1);
|
||||||
cairo_rectangle(cairo, 0, 0, width, height);
|
cairo_rectangle(cairo, 0, 0, width, height);
|
||||||
cairo_fill(cairo);
|
cairo_fill(cairo);
|
||||||
|
cairo_restore(cairo);
|
||||||
|
cairo_save(cairo);
|
||||||
|
|
||||||
switch(rotate)
|
switch(rotate)
|
||||||
{
|
{
|
||||||
|
@ -498,6 +507,9 @@ draw(int page_id)
|
||||||
|
|
||||||
poppler_page_render(current_page->page, cairo);
|
poppler_page_render(current_page->page, cairo);
|
||||||
|
|
||||||
|
cairo_restore(cairo);
|
||||||
|
cairo_destroy(cairo);
|
||||||
|
|
||||||
unsigned char* image = cairo_image_surface_get_data(current_page->surface);
|
unsigned char* image = cairo_image_surface_get_data(current_page->surface);
|
||||||
int x, y, z = 0;
|
int x, y, z = 0;
|
||||||
|
|
||||||
|
@ -735,11 +747,14 @@ set_page(int page)
|
||||||
void
|
void
|
||||||
switch_view(GtkWidget* widget)
|
switch_view(GtkWidget* widget)
|
||||||
{
|
{
|
||||||
if(gtk_bin_get_child(GTK_BIN(Zathura.UI.viewport)))
|
pthread_mutex_lock(&(Zathura.Lock.viewport_lock));
|
||||||
|
GtkWidget* child = gtk_bin_get_child(GTK_BIN(Zathura.UI.viewport));
|
||||||
|
if(child)
|
||||||
{
|
{
|
||||||
g_object_ref(gtk_bin_get_child(GTK_BIN(Zathura.UI.viewport)));
|
g_object_ref(child);
|
||||||
gtk_container_remove(GTK_CONTAINER(Zathura.UI.viewport), gtk_bin_get_child(GTK_BIN(Zathura.UI.viewport)));
|
gtk_container_remove(GTK_CONTAINER(Zathura.UI.viewport), child);
|
||||||
}
|
}
|
||||||
|
pthread_mutex_unlock(&(Zathura.Lock.viewport_lock));
|
||||||
|
|
||||||
gtk_container_add(GTK_CONTAINER(Zathura.UI.viewport), GTK_WIDGET(widget));
|
gtk_container_add(GTK_CONTAINER(Zathura.UI.viewport), GTK_WIDGET(widget));
|
||||||
}
|
}
|
||||||
|
@ -761,6 +776,56 @@ render(void* parameter)
|
||||||
pthread_exit(NULL);
|
pthread_exit(NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void* search(void* parameter)
|
||||||
|
{
|
||||||
|
Argument* argument = (Argument*) parameter;
|
||||||
|
|
||||||
|
static char* search_item;
|
||||||
|
static int direction;
|
||||||
|
int page_counter;
|
||||||
|
int next_page;
|
||||||
|
GList* results;
|
||||||
|
GList* list;
|
||||||
|
|
||||||
|
if(argument->data)
|
||||||
|
search_item = g_strdup((char*) argument->data);
|
||||||
|
|
||||||
|
if(!Zathura.PDF.document || !search_item || !strlen(search_item))
|
||||||
|
pthread_exit(NULL);
|
||||||
|
|
||||||
|
/* search document */
|
||||||
|
if(argument->n)
|
||||||
|
direction = (argument->n == BACKWARD) ? -1 : 1;
|
||||||
|
|
||||||
|
for(page_counter = 0; page_counter < Zathura.PDF.number_of_pages; page_counter++)
|
||||||
|
{
|
||||||
|
next_page = (Zathura.PDF.number_of_pages + Zathura.PDF.page_number +
|
||||||
|
page_counter * direction) % Zathura.PDF.number_of_pages;
|
||||||
|
|
||||||
|
pthread_mutex_lock(&(Zathura.PDF.pages[next_page]->lock));
|
||||||
|
results = poppler_page_find_text(Zathura.PDF.pages[next_page]->page, search_item);
|
||||||
|
pthread_mutex_unlock(&(Zathura.PDF.pages[next_page]->lock));
|
||||||
|
|
||||||
|
if(results)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* draw results */
|
||||||
|
if(results)
|
||||||
|
{
|
||||||
|
for(list = results; list && list->data; list = g_list_next(list))
|
||||||
|
highlight_result(next_page, (PopplerRectangle*) list->data);
|
||||||
|
|
||||||
|
set_page(next_page);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
printf("Nothing found for %s\n", search_item);
|
||||||
|
}
|
||||||
|
|
||||||
|
pthread_exit(NULL);
|
||||||
|
}
|
||||||
|
|
||||||
/* shortcut implementation */
|
/* shortcut implementation */
|
||||||
void
|
void
|
||||||
sc_abort(Argument* argument)
|
sc_abort(Argument* argument)
|
||||||
|
@ -876,48 +941,12 @@ sc_scroll(Argument* argument)
|
||||||
void
|
void
|
||||||
sc_search(Argument* argument)
|
sc_search(Argument* argument)
|
||||||
{
|
{
|
||||||
static char* search_item;
|
pthread_mutex_lock(&(Zathura.Lock.search_lock));
|
||||||
static int direction;
|
if(Zathura.PDF.search_thread)
|
||||||
int page_counter;
|
pthread_cancel(Zathura.PDF.search_thread);
|
||||||
int next_page;
|
|
||||||
GList* results;
|
|
||||||
GList* list;
|
|
||||||
|
|
||||||
if(argument->data)
|
pthread_create(&(Zathura.PDF.search_thread), NULL, search, (gpointer) argument);
|
||||||
search_item = g_strdup((char*) argument->data);
|
pthread_mutex_unlock(&(Zathura.Lock.search_lock));
|
||||||
|
|
||||||
if(!Zathura.PDF.document || !search_item || !strlen(search_item))
|
|
||||||
return;
|
|
||||||
|
|
||||||
/* search document */
|
|
||||||
if(argument->n)
|
|
||||||
direction = (argument->n == BACKWARD) ? -1 : 1;
|
|
||||||
|
|
||||||
for(page_counter = 0; page_counter < Zathura.PDF.number_of_pages; page_counter++)
|
|
||||||
{
|
|
||||||
next_page = (Zathura.PDF.number_of_pages + Zathura.PDF.page_number +
|
|
||||||
page_counter * direction) % Zathura.PDF.number_of_pages;
|
|
||||||
|
|
||||||
pthread_mutex_lock(&(Zathura.PDF.pages[next_page]->lock));
|
|
||||||
results = poppler_page_find_text(Zathura.PDF.pages[next_page]->page, search_item);
|
|
||||||
pthread_mutex_unlock(&(Zathura.PDF.pages[next_page]->lock));
|
|
||||||
|
|
||||||
if(results)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* draw results */
|
|
||||||
if(results)
|
|
||||||
{
|
|
||||||
for(list = results; list && list->data; list = g_list_next(list))
|
|
||||||
highlight_result(next_page, (PopplerRectangle*) list->data);
|
|
||||||
|
|
||||||
set_page(next_page);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
printf("Nothing found for %s\n", search_item);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -1908,6 +1937,8 @@ cb_destroy(GtkWidget* widget, gpointer data)
|
||||||
pthread_mutex_destroy(&(Zathura.Lock.scale_lock));
|
pthread_mutex_destroy(&(Zathura.Lock.scale_lock));
|
||||||
pthread_mutex_destroy(&(Zathura.Lock.rotate_lock));
|
pthread_mutex_destroy(&(Zathura.Lock.rotate_lock));
|
||||||
pthread_mutex_destroy(&(Zathura.Lock.render_lock));
|
pthread_mutex_destroy(&(Zathura.Lock.render_lock));
|
||||||
|
pthread_mutex_destroy(&(Zathura.Lock.search_lock));
|
||||||
|
pthread_mutex_destroy(&(Zathura.Lock.viewport_lock));
|
||||||
|
|
||||||
gtk_main_quit();
|
gtk_main_quit();
|
||||||
|
|
||||||
|
@ -1965,9 +1996,9 @@ gboolean cb_draw(GtkWidget* widget, GdkEventExpose* expose, gpointer data)
|
||||||
|
|
||||||
pthread_mutex_lock(&(Zathura.PDF.pages[page_id]->lock));
|
pthread_mutex_lock(&(Zathura.PDF.pages[page_id]->lock));
|
||||||
cairo_set_source_surface(cairo, Zathura.PDF.pages[page_id]->surface, offset_x, offset_y);
|
cairo_set_source_surface(cairo, Zathura.PDF.pages[page_id]->surface, offset_x, offset_y);
|
||||||
pthread_mutex_unlock(&(Zathura.PDF.pages[page_id]->lock));
|
|
||||||
cairo_paint(cairo);
|
cairo_paint(cairo);
|
||||||
cairo_destroy(cairo);
|
cairo_destroy(cairo);
|
||||||
|
pthread_mutex_unlock(&(Zathura.PDF.pages[page_id]->lock));
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue