Search fix, overworked Makefile

A little fix that solves the forwards, backwards searching problem
and an overworked, cleaned up Makefile
This commit is contained in:
Moritz Lipp 2009-09-12 11:19:51 +02:00
parent 864c7dc29d
commit 96b0393531
3 changed files with 24 additions and 10 deletions

View file

@ -11,15 +11,12 @@ $(TARGET): zathura.c config.h
clean: clean:
rm -f $(TARGET) rm -f $(TARGET)
debug: $(TARGET) debug:
gcc $(FLAGS) -Wall -o $(TARGET) $(SOURCE) -g gcc $(FLAGS) -Wall -o $(TARGET) $(SOURCE) -g
valgrind: debug $(TARGET) valgrind: debug
valgrind --tool=memcheck --leak-check=yes --show-reachable=yes ./${TARGET} valgrind --tool=memcheck --leak-check=yes --show-reachable=yes ./${TARGET}
scrollbars: $(TARGET)
gcc $(FLAGS) -Wall -o $(TARGET) $(SOURCE) -DSHOW_SCROLLBARS
install: all install: all
@echo installing executeable to /usr/bin @echo installing executeable to /usr/bin
@mkdir -p /usr/bin @mkdir -p /usr/bin

View file

@ -7,6 +7,7 @@ static const int DEFAULT_WIDTH = 800;
static const int DEFAULT_HEIGHT = 600; static const int DEFAULT_HEIGHT = 600;
static const char BROWSER[] = "firefox %s"; static const char BROWSER[] = "firefox %s";
static const char PRINTER[] = "EPSON_AL-CX11_192.168.88.80"; static const char PRINTER[] = "EPSON_AL-CX11_192.168.88.80";
/* look */ /* look */
static const char font[] = "monospace normal 9"; static const char font[] = "monospace normal 9";
static const char default_bgcolor[] = "#000000"; static const char default_bgcolor[] = "#000000";
@ -29,6 +30,10 @@ static const char completion_hl_bgcolor[] = "#9FBC00";
static const char search_highlight[] = "#9FBC00"; static const char search_highlight[] = "#9FBC00";
/* additional settings */
#define SHOW_SCROLLBARS 0
#define INCREMENTAL_SEARCH 0
/* shortcuts */ /* shortcuts */
Shortcut shortcuts[] = { Shortcut shortcuts[] = {
// mask, key, function, argument // mask, key, function, argument

View file

@ -183,7 +183,7 @@ init()
gtk_viewport_set_shadow_type((GtkViewport*) gtk_bin_get_child(GTK_BIN(Zathura.view)), GTK_SHADOW_NONE); 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); 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); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(Zathura.view), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);
#else #else
gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(Zathura.view), GTK_POLICY_NEVER, GTK_POLICY_NEVER); 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); cairo_rotate(cairo, Zathura.PDF.rotate * G_PI / 180.0);
poppler_page_render(Zathura.PDF.page, cairo); poppler_page_render(Zathura.PDF.page, cairo);
cairo_restore(cairo); cairo_restore(cairo);
cairo_destroy(cairo); cairo_destroy(cairo);
@ -711,7 +712,7 @@ sc_search(Argument *argument)
GList* list; GList* list;
if(argument->data) if(argument->data)
search_item = (char*) argument->data; search_item = g_strdup((char*) argument->data);
if(!Zathura.PDF.document || !Zathura.PDF.page || !search_item) if(!Zathura.PDF.document || !Zathura.PDF.page || !search_item)
return; return;
@ -722,9 +723,10 @@ sc_search(Argument *argument)
if(argument->n) if(argument->n)
direction = (argument->n == BACKWARD) ? -1 : 1; 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); set_page(next_page);
results = poppler_page_find_text(Zathura.PDF.page, search_item); results = poppler_page_find_text(Zathura.PDF.page, search_item);
@ -749,6 +751,9 @@ sc_search(Argument *argument)
result->y2 = page_height - result->y2; result->y2 = page_height - result->y2;
highlight_result(result); highlight_result(result);
} }
if(argument->n == FORWARD || argument->n == BACKWARD)
update_status();
} }
else else
update_notification(search_status, DEFAULT, g_strdup_printf("No match for %s", search_item)); 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) cb_inputbar_key_released(GtkEntry *entry, GdkEventKey *event, gpointer data)
{ {
int length = gtk_entry_get_text_length(entry); int length = gtk_entry_get_text_length(entry);
#if INCREMENTAL_SEARCH
char* text = (char*) gtk_entry_get_text(entry); char* text = (char*) gtk_entry_get_text(entry);
#endif
Argument argument; Argument argument;
if(!length) if(!length)
@ -1262,14 +1271,17 @@ cb_inputbar_key_released(GtkEntry *entry, GdkEventKey *event, gpointer data)
argument.n = HIDE; argument.n = HIDE;
complete(&argument); complete(&argument);
} }
#if INCREMENTAL_SEARCH
else if(length > 1 && text[0] == '/') else if(length > 1 && text[0] == '/')
{ {
Argument argument; Argument argument;
argument.data = (char*) text + 1; argument.data = (char*) text + 1;
sc_search(&argument); //sc_search(&argument);
gtk_widget_grab_focus(GTK_WIDGET(Zathura.inputbar)); gtk_widget_grab_focus(GTK_WIDGET(Zathura.inputbar));
gtk_editable_set_position(GTK_EDITABLE(Zathura.inputbar), -1); gtk_editable_set_position(GTK_EDITABLE(Zathura.inputbar), -1);
} }
#endif
return FALSE; return FALSE;
} }