From 96b0393531a5445eae1b676d357c55884e3ee860 Mon Sep 17 00:00:00 2001 From: Moritz Lipp Date: Sat, 12 Sep 2009 11:19:51 +0200 Subject: [PATCH] Search fix, overworked Makefile A little fix that solves the forwards, backwards searching problem and an overworked, cleaned up Makefile --- Makefile | 7 ++----- config.h | 5 +++++ zathura.c | 22 +++++++++++++++++----- 3 files changed, 24 insertions(+), 10 deletions(-) diff --git a/Makefile b/Makefile index 7f53c80..2e1068d 100644 --- a/Makefile +++ b/Makefile @@ -11,15 +11,12 @@ $(TARGET): zathura.c config.h clean: rm -f $(TARGET) -debug: $(TARGET) +debug: gcc $(FLAGS) -Wall -o $(TARGET) $(SOURCE) -g -valgrind: debug $(TARGET) +valgrind: debug valgrind --tool=memcheck --leak-check=yes --show-reachable=yes ./${TARGET} -scrollbars: $(TARGET) - gcc $(FLAGS) -Wall -o $(TARGET) $(SOURCE) -DSHOW_SCROLLBARS - install: all @echo installing executeable to /usr/bin @mkdir -p /usr/bin diff --git a/config.h b/config.h index 0642df1..f6b8d96 100644 --- a/config.h +++ b/config.h @@ -7,6 +7,7 @@ static const int DEFAULT_WIDTH = 800; static const int DEFAULT_HEIGHT = 600; static const char BROWSER[] = "firefox %s"; static const char PRINTER[] = "EPSON_AL-CX11_192.168.88.80"; + /* look */ static const char font[] = "monospace normal 9"; static const char default_bgcolor[] = "#000000"; @@ -29,6 +30,10 @@ static const char completion_hl_bgcolor[] = "#9FBC00"; static const char search_highlight[] = "#9FBC00"; +/* additional settings */ +#define SHOW_SCROLLBARS 0 +#define INCREMENTAL_SEARCH 0 + /* shortcuts */ Shortcut shortcuts[] = { // mask, key, function, argument diff --git a/zathura.c b/zathura.c index e5285ab..4310f96 100644 --- a/zathura.c +++ b/zathura.c @@ -183,7 +183,7 @@ init() gtk_viewport_set_shadow_type((GtkViewport*) gtk_bin_get_child(GTK_BIN(Zathura.view)), GTK_SHADOW_NONE); g_signal_connect(G_OBJECT(Zathura.view), "key-press-event", G_CALLBACK(cb_view_key_pressed), NULL); - #ifdef SHOW_SCROLLBARS + #if SHOW_SCROLLBARS gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(Zathura.view), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); #else gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(Zathura.view), GTK_POLICY_NEVER, GTK_POLICY_NEVER); @@ -396,6 +396,7 @@ draw() cairo_rotate(cairo, Zathura.PDF.rotate * G_PI / 180.0); poppler_page_render(Zathura.PDF.page, cairo); + cairo_restore(cairo); cairo_destroy(cairo); @@ -711,7 +712,7 @@ sc_search(Argument *argument) GList* list; if(argument->data) - search_item = (char*) argument->data; + search_item = g_strdup((char*) argument->data); if(!Zathura.PDF.document || !Zathura.PDF.page || !search_item) return; @@ -722,9 +723,10 @@ sc_search(Argument *argument) if(argument->n) direction = (argument->n == BACKWARD) ? -1 : 1; - for(page_counter = 0; page_counter < Zathura.PDF.number_of_pages; page_counter++) + for(page_counter = 1; page_counter <= Zathura.PDF.number_of_pages; page_counter++) { - int next_page = (Zathura.PDF.page_number + page_counter * direction) % Zathura.PDF.number_of_pages; + int next_page = (Zathura.PDF.number_of_pages + Zathura.PDF.page_number + + page_counter * direction) % Zathura.PDF.number_of_pages; set_page(next_page); results = poppler_page_find_text(Zathura.PDF.page, search_item); @@ -749,6 +751,9 @@ sc_search(Argument *argument) result->y2 = page_height - result->y2; highlight_result(result); } + + if(argument->n == FORWARD || argument->n == BACKWARD) + update_status(); } else update_notification(search_status, DEFAULT, g_strdup_printf("No match for %s", search_item)); @@ -1254,7 +1259,11 @@ gboolean cb_inputbar_key_released(GtkEntry *entry, GdkEventKey *event, gpointer data) { int length = gtk_entry_get_text_length(entry); + + #if INCREMENTAL_SEARCH char* text = (char*) gtk_entry_get_text(entry); + #endif + Argument argument; if(!length) @@ -1262,14 +1271,17 @@ cb_inputbar_key_released(GtkEntry *entry, GdkEventKey *event, gpointer data) argument.n = HIDE; complete(&argument); } + + #if INCREMENTAL_SEARCH else if(length > 1 && text[0] == '/') { Argument argument; argument.data = (char*) text + 1; - sc_search(&argument); + //sc_search(&argument); gtk_widget_grab_focus(GTK_WIDGET(Zathura.inputbar)); gtk_editable_set_position(GTK_EDITABLE(Zathura.inputbar), -1); } + #endif return FALSE; }